stl-statilque-litterateur/var/lib/stl/scripts/manage__HTML

276 lines
8.3 KiB
Bash

#!/bin/bash
# Name: Statique Littérateur
# Type: Manage HTML template
# file: manage__HTML
# Folder: /var/lib/stl/scripts/
# By echolib (XMPP: im@echolib.re)
# License: GNU AFFERO GENERAL PUBLIC LICENSE Version 3, 19 November 2007
#======================================================================
# HTML code for <header>
# You can edit this function
# header.html is used in create_HTML_page
#======================================================================
create__HTML_header() {
cat <<EOHEADER
<header id="${domain_css}_banner">
<div id="${domain_css}_site-logo">
<a href="/">
<img src="$sub_genuri_srv/template/$domain_logo"
alt="Logo: $domain_title"
title="Logo: $domain_title"/>
</a>
</div>
<div id="${domain_css}_site-title">
<h1 id="${domain_css}_site-name">
<a href="/"
title="$stl_welcome $domain_title">
$domain_title
</a>
</h1>
<h2 id="${domain_css}_site-description">$domain_about</h2>
</div>
</header>
EOHEADER
}
#======================================================================
# HTML code for <footer>
# Do not edit this function
# footer.html is created - IF NOT EXISTS
# Uri: $domain_dir_wip_tpl/footer.html
# (i.e. /var/www/DOMAIN/wip/template/)
#======================================================================
create__HTML_footer() {
cat <<EOFOOTER > "$domain_dir_wip_tpl/footer.html"
<footer id="${domain_css}_footer">
<h1>$stl_about $domain_title</h1>
<div id="${domain_css}_footer-infos">
<p>$site_about<p>
</div>
<div id="${domain_css}_footer-about">
<ul>
<li><a href="$domain_url"><b>$domain_title</b></a>: $domain_about</li>
<li>Contact: $domain_mail</li>
<li>Copyright: $domain_cr</li>
<li>$stl_gen: <a href="https://git.a-lec.org/echolib/stl.git" target="_blank"><b>STL: Statique Littérateur</b></a></li>
<li>RSS: <a type="application/rss+xml" href="$domain_url/rss.xml">$domain_url/rss.xml</a></li>
</ul>
</div>
</footer>
EOFOOTER
}
#======================================================================
# HTML code for <footer>
# Do not edit this function
# metas.html is created - IF NOT EXISTS
# Uri: $domain_dir_wip_tpl/metas.html
# (i.e. /var/www/DOMAIN/wip/template/)
#======================================================================
create__HTML_metas() {
cat <<EOMETAS > "$domain_dir_wip_tpl/metas.html"
<meta charset="UTF-8" />
<meta name='viewport' content="width=device-width, initial-scale=1.0">
<meta name='robots' content="all">
<meta name='medium' content='website'>
<meta name='revisit-after' content="3 days">
<meta name='language' content="$domaine_lang">
<meta name='reply-to' content="$domain_mail">
<meta name='copyright' content="$domain_cr">
EOMETAS
}
#======================================================================
# Translate some static words according to domain_lang
#======================================================================
create__HTML_translation() {
if [[ `grep -i "fr" <<<"$domain_lang"` ]];then
stl_welcome="Page d'accueil de"
stl_written="Écrit par"
stl_about=" À propos de"
stl_gen="Propulsé par"
stl_the="le"
stl_by="par"
stl_read="Lire l'article de"
stl_rss_info="Tous les titres de"
# Convert date from INT to shit FR format (Yes, i love it...)
stl_date_y=`awk -F- '{print $1}' <<<"$article_date"`
stl_date_m=`awk -F- '{print $2}' <<<"$article_date"`
stl_date_d=`awk -F- '{print $3}' <<<"$article_date"`
stl_date="$stl_date_d/$stl_date_m/$stl_date_y"
else
stl_welcome="Welcome page of"
stl_written="Written by"
stl_bout="About"
stl_gen="Generated with"
stl_the="The"
stl_by="by"
stl_read="Read the post of"
stl_rss_info="All titles from"
stl_date="${article_date}"
fi
}
#======================================================================
# Page Template
#======================================================================
create__HTML_page() {
create__HTML_translation
! [[ -f "$domain_dir_wip_tpl/metas.html" ]] \
&& create__HTML_metas
! [[ -f "$domain_dir_wip_tpl/footer.html" ]] \
&& create__HTML_footer
# Ceeate uri articl folders
mkdir -p "$domain_dir_wip/$article_dir_srv"
rsync -a "articles/$article_dir_srv/" "$domain_dir_wip/$article_dir_srv/"
cat <<EOPAGE > "$domain_dir_wip/$article_uri_srv"
<!DOCTYPE html>
<html lang="${domain_lang: :2}">
<head>
$(cat "$domain_dir_wip_tpl/metas.html")
<meta name='generator' content="STL: Statique Littérateur">
<meta name='title' content="$article_title | $site_title">
<meta name='author' content="$article_author">
<meta name='description' content="$article_info">
<meta name='keywords' content="$domain_tags,$article_tags">
<meta name='search_date' content="$article_date">
<link rel="alternate" type="application/rss+xml" href="$domain_url/rss.xml" title="RSS: $stl_rss_info $domain_title" />
<link rel="stylesheet" media="screen" href="$sub_genuri_srv/templates/styles.css" />
<link rel="shortcut icon" type="image/png" href="$sub_genuri_srv/templates/favicon.png" />
<link rel='me' type='text/html' href="$domain_ext_url">
<title>$article_title - $domain_title</title>
</head>
<body id="${domain_css}_body $database_id">
$(create__HTML_header)
<section id="${domain_css}_page-wrapper">
<article id="${domain_css}_article ">
<div id="${domain_css}_metas">
<p id="${domain_css}_auteur">$stl_written <strong>$article_author</strong> $stl_the $stl_date</p>
</div>
$(cat "$article_tmp_post")
</article>
<aside id="${domain_css}_sidebar">
<div class="${domain_css}_wrapper" role="navigation">
<nav id="${domain_css}_latest-posts">
<h1 class="${domain_css}_latest-posts">$domain_sidebar_title</h1>
<ul class="${domain_css}_latest-posts"
aria-label="$domain_sidebar_title">
<!--# include file="$sub_genuri_srv/templates/sidebar.html" -->
</ul>
</nav>
</div>
</aside>
</section>
$(cat "$domain_dir_wip_tpl/footer.html")
</body>
</html>
EOPAGE
}
#======================================================================
# ATOM/RSS Creator
# File is at root wip server ; filename=rss.xml
# reverse sort time from DB | newest first
#======================================================================
create__RSS_feed() {
create__HTML_translation
rss_file="$domain_dir_wip/rss.xml"
cat <<EORSS > "$rss_file"
<?xml version="1.0" encoding="utf-8"?>
<rss version="2.0">
<channel>
<title>$domain_title - $domain_name - Flux RSS 2.0</title>
<link>$domain_url</link>
<description>$stl_rss_info $domain_title</description>
<language>$domain_lang</language>
<lastBuildDate>$(date)</lastBuildDate>
<copyright>$domain_cr</copyright>
<webMaster>$domain_mail</webMaster>
<generator>STL: Statique Littérateur</generator>
EORSS
while IFS=: read -r 'file' 'timestamp'
do
source "$file"
! [[ $article_wip_hash -gt 0 ]] \
&& continue
cat <<EOITEM >> "$rss_file"
<item>
<title>$article_title</title>
<link>$domain_url$article_uri_srv</link>
<guid>$domain_url$article_uri_srv</guid>
<pubDate>$(date -d @$article_timestamp)</pubDate>
<description>$article_about</description>
<author>$article_author</author>
</item>
EOITEM
done < <(grep -H "article_timestamp" "$domain_db_articles/"*.db \
| sort -t= -k2r)
cat <<EORSS >> "$rss_file"
</channel>
</rss>
EORSS
this_article="$rss_file"
log__add -i -M RSS "Created feed"
}
#======================================================================
# Sync WIp to WWW
# Before sync, create RSS FEED in wip
#======================================================================
sync_wip_to_www() {
domain__get
[[ $stl_install == "local" ]] \
&& echo "! $stl_install Installation. Useless sync" \
&& return
create__RSS_feed
# Create www hash status in DB
db__get_wip_articles "set_www_hash" # manage__db
# Statistics
if [[ $domain_stats == "yes" ]];then
stats__init
db__get_wip_articles "stats"
stats__statoolinfos
fi
# Sync wip to www
rsync -a --exclude ".*" "$domain_dir_wip/" "$domain_dir_www/"
# Log
this_article="$domain_dir_www"
log__add -i -M WWW "Synced WIP server to WWW server"
}