handle every non-cryptic metadata that doesn’t need joins

This commit is contained in:
Guilhem Fauré 2023-04-21 16:49:09 +02:00
parent 18ac8d2047
commit a45a67b30b
2 changed files with 53 additions and 8 deletions

View File

@ -5,14 +5,56 @@ from slugify import slugify
class metadata: class metadata:
def __init__(self, article): def __init__(self, article):
self.id = article.id_article self.id = article.id_article
# self.surtitle = article.surtitre # Probably unused
self.title = article.titre self.title = article.titre
self.date = article.date self.subtitle = article.soustitre # Probably unused
# self.section = article.id_rubrique # TODO join
def get_title(self): self.caption = article.chapo # Probably unused
return "# {}\n".format(self.title) self.ps = article.ps # Probably unused
self.publicationDate = article.date
self.status = article.statut
# self.sector = article.id_secteur # TODO join
self.update = article.maj
# self.export = article.export # USELESS
self.creationDate = article.date_redac
# self.views = article.visites # USELESS in static
self.referers = article.referers # TODO Why?
# self.popularity = article.popularite # USELESS in static
self.acceptForum = article.accepter_forum # TODO Why?
self.contentUpdate = article.date_modif # Probably unused
self.lang = article.lang
self.choosenLang = article.langue_choisie # TODO Why?
# self.translation = article.id_trad # TODO join
self.extra = article.extra # Probably unused
# self.version = article.id_version # USELESS
self.sitename = article.nom_site # Probably useless
self.virtual = article.virtuel # TODO Why?
self.microblog = article.microblog # Probably unused
def get_slug(self): def get_slug(self):
return slugify("{}-{}".format(self.id, self.title)) return slugify("{}-{}".format(self.id, self.title))
def get_frontmatter(self): def get_frontmatter(self):
return "---\n{}---".format(yaml.dump({"title": self.title, "date": self.date})) return "---\n{}---".format(
yaml.dump(
{
"lang": self.lang,
"title": self.title,
"subtitle": self.subtitle,
"creation": self.creationDate,
"date": self.publicationDate,
"update": self.update,
"status": self.status,
}
)
)
# Contains things before the article like caption & titles
def get_starting(self):
return "{}\n\n# {}\n".format(self.caption, self.title)
# Contains things after the article like ps & extra
def get_ending(self):
return "# EXTRA\n\n{}\n\n# POST-SCRIPTUM\n\n{}\n\n# MICROBLOGGING\n\n{}".format(
self.extra, self.ps, self.microblog
)

View File

@ -2,7 +2,7 @@
import os import os
import shutil import shutil
import sys import sys
from datetime import * from datetime import date, time, datetime
# Modules # Modules
from config import CONFIG from config import CONFIG
@ -45,8 +45,11 @@ for article in articles:
os.mkdir(articleDir) os.mkdir(articleDir)
with open("{}/index.md".format(articleDir), "w") as f: with open("{}/index.md".format(articleDir), "w") as f:
f.write( f.write(
"{}\n{}\n{}".format( "{}\n{}\n{}\n{}".format(
meta.get_frontmatter(), meta.get_title(), body.get_markdown() meta.get_frontmatter(),
meta.get_starting(),
body.get_markdown(),
meta.get_ending(),
) )
) )
# End export if no more to export # End export if no more to export