245 lines
6.1 KiB
Bash
245 lines
6.1 KiB
Bash
#!/bin/bash
|
|
# Name: Statique Littérateur
|
|
# Type: Article manager
|
|
# file: manage__articles
|
|
# Folder: /var/lib/stl/scripts/
|
|
# By echolib (XMPP: im@echolib.re)
|
|
# License: GNU AFFERO GENERAL PUBLIC LICENSE Version 3, 19 November 2007
|
|
|
|
#------------
|
|
# funny stats
|
|
#------------
|
|
# lines: 245
|
|
# functions: 7
|
|
#-----------------------------------------------------------------------
|
|
|
|
#**********************************************************************
|
|
|
|
#======================================================================
|
|
# Argument remove
|
|
# Remove article in wip/, www/ if wip, publish
|
|
# $1: remove
|
|
# $2: argument
|
|
#======================================================================
|
|
remove__OPTIONS() {
|
|
case "$2" in
|
|
wip) wip_remove=true;srv="WIP" ;;
|
|
www) www_remove=true;srv="WWW" ;;
|
|
*) noarg "$2" "Use: wip,www (ARTICLE)" ;;
|
|
esac
|
|
|
|
case "$3" in
|
|
*".stl") article__hash "$3" ;;
|
|
*) noarg "$3" "Use: (ARTICLE).stl" ;;
|
|
esac
|
|
|
|
if__article_db "$article_db"
|
|
if ! [[ $db_exists ]];then
|
|
echo "! $this_article must be checked first"
|
|
exit
|
|
fi
|
|
|
|
# Checking wip status
|
|
if [[ $wip_remove ]];then
|
|
! [[ $article_wip_hash ]] \
|
|
&& echo "! $3 is not in wip/ server" \
|
|
&& exit
|
|
|
|
dir_target="$domain_dir_wip"
|
|
|
|
# Checking www status
|
|
elif [[ $www_remove ]];then
|
|
[[ $stl_server == "server" ]] \
|
|
&& echo "! STL install: $stl_install. Unuse www/" \
|
|
&& exit
|
|
|
|
! [[ $article_www_hash ]] \
|
|
&& echo "! Article '$3' is not in www/ server" \
|
|
&& exit
|
|
|
|
dir_target="$domain_dir_www"
|
|
fi
|
|
|
|
# Remove .html, .stl from server
|
|
for rm_file in "$dir_target$article_uri_srv" \
|
|
"$dir_target$article_uri_src"
|
|
do
|
|
if [[ -f "$rm_file" ]];then
|
|
rm -f "$rm_file"
|
|
log__add -w "$srv" -rm \
|
|
"file from server"
|
|
fi
|
|
done
|
|
|
|
# in manage__publish: remove included files used by article
|
|
get__article_files_inluded
|
|
|
|
# Remove empty directories
|
|
find "$dir_target" -type d -empty -delete
|
|
|
|
# Remove www hash to DB
|
|
db__srv_status_hash "$srv" Unset
|
|
|
|
}
|
|
|
|
|
|
#======================================================================
|
|
# Argument read
|
|
# $1: read
|
|
# $2: argument
|
|
#======================================================================
|
|
read__OPTIONS() {
|
|
! [[ "$2" ]] \
|
|
&& noarg "Cannot be empty"
|
|
|
|
case "$2" in
|
|
*".stl") article__hash "$2" ;;
|
|
conf) domain__get;uri_article="$stl_file_pwd_conf" ;;
|
|
sidebar) domain__get;uri_article="$domain_file_sidebar_load" ;;
|
|
*) noarg "$2" ;;
|
|
esac
|
|
|
|
if__file "$uri_article" read
|
|
}
|
|
|
|
|
|
#======================================================================
|
|
# Argument edit
|
|
# $1: edit
|
|
# $2: argument
|
|
#======================================================================
|
|
edit__OPTIONS() {
|
|
! [[ "$2" ]] \
|
|
&& noarg "Cannot be empty"
|
|
|
|
domain__get
|
|
case "$2" in
|
|
*".stl") article__hash "$2" ;;
|
|
conf) uri_article="$domain_conf" ;;
|
|
sidebar) uri_article="$domain_file_sidebar_load" ;;
|
|
*) noarg "$2" ;;
|
|
esac
|
|
|
|
nano --linenumbers "$uri_article"
|
|
exit
|
|
}
|
|
|
|
|
|
#======================================================================
|
|
# Split article in 2 files : metas + content
|
|
# Get begining article content line
|
|
# $1: article > $uri_article
|
|
#======================================================================
|
|
split_article() {
|
|
article_tmp_head=`mktemp` # Metas
|
|
article_tmp_post=`mktemp` # Content
|
|
|
|
article_begin=`
|
|
grep -n "^-----" "$1" \
|
|
| head -n 1 \
|
|
| awk -F: '{print $1}'`
|
|
|
|
if ! [[ $article_begin ]];then
|
|
log__add -e -C -A \
|
|
"No separator before content: use '-----'"
|
|
return
|
|
fi
|
|
|
|
# Create file with metas only
|
|
awk -v end="$article_begin" \
|
|
'NR >=1 && NR < end-1 {print}' \
|
|
"$1" \
|
|
> "$article_tmp_head"
|
|
|
|
((article_begin++))
|
|
|
|
# Create file with content only
|
|
awk -v end="$article_begin" \
|
|
'NR >= end {print}' \
|
|
"$1" \
|
|
> "$article_tmp_post"
|
|
|
|
}
|
|
|
|
#======================================================================
|
|
# Get article line for article_tmp_post. Count from begin - 1
|
|
#======================================================================
|
|
article__line() {
|
|
ln=$(( ln + article_begin - 1 ))
|
|
}
|
|
|
|
#======================================================================
|
|
# Get article hash + article_db ID from uri
|
|
# $1: file *.stl from argument
|
|
#======================================================================
|
|
article__hash() {
|
|
domain__get
|
|
this_article="$1"
|
|
this_article_bkp="$1"
|
|
uri_article="$domain_dir_articles/$1"
|
|
if__file "$uri_article"
|
|
|
|
# Get Hash, Size, Uri
|
|
while read -r "H" "S" "U"
|
|
do
|
|
article_hash="$H"
|
|
article_size="$S"
|
|
article_id=`echo "$U" | cksum | awk '{print $1}'`
|
|
article_db="$article_id.db"
|
|
article_log="$article_id.log"
|
|
done < <(cksum "$uri_article")
|
|
|
|
if [[ $article_size -lt 10 ]];then
|
|
echo "! This article is nearly empty..."
|
|
exit
|
|
|
|
elif [[ $article_size -lt 60 ]];then
|
|
echo "! This article is too small to be checked"
|
|
exit
|
|
fi
|
|
}
|
|
|
|
|
|
#======================================================================
|
|
# Get values from OPTIONAL metas
|
|
# $1: marker
|
|
# $2: from split mktemp > $article_tmp_head
|
|
# $3: check | make
|
|
# $4: $article_tmp_post
|
|
#======================================================================
|
|
get__content_metas() {
|
|
unset meta
|
|
|
|
while IFS=: read -r "ln" "content"
|
|
do
|
|
meta=true
|
|
header_f0=`awk -F"$1" '{print $2}' <<<"$content"`
|
|
header_f1=`awk -F" : " '{print $1}' <<<"$header_f0"`
|
|
header_f2=`awk -F" : " '{print $2}' <<<"$header_f0"`
|
|
header_f3=`awk -F" : " '{print $3}' <<<"$header_f0"`
|
|
|
|
case "$3" in
|
|
check)
|
|
case "$1" in
|
|
"^link: ") check__link ;;
|
|
"^image: ") check__image ;;
|
|
"^code: ") check__precode ;;
|
|
"^brut: ") check__brut ;;
|
|
"^abbr: ") check__abbr ;;
|
|
"^file: ") check__link_file ;;
|
|
esac
|
|
;;
|
|
|
|
make)
|
|
case "$1" in
|
|
"^abbr: ") make__abbrs "$4" ;;
|
|
"^link: ") make__links "$4" ;;
|
|
"^file: ") make__links_file "$4" ;;
|
|
"^image: ") make__images "$4" ;;
|
|
"^code: ") make__precode "$4" ;;
|
|
"^brut: ") make__brut "$4" ;;
|
|
esac
|
|
;;
|
|
esac
|
|
done < <(grep -n "$1" "$2" )
|
|
}
|