import locale import os import pathlib from datetime import datetime from os import path import markdown import config import search ENTRY_DIR = config.ENTRY_DIR LANGUAGE = config.LANGUAGE LOCAL = "de_DE.UTF-8" if LANGUAGE == "de-de" else "en_US.UTF-8" locale.setlocale(locale.LC_TIME, LOCAL) def gen_arch_string(): """ Creates and returns a archive string of every file in ENTRY_DIR. Returns: string: html-formatted archive-string """ path_ex = ENTRY_DIR if path.exists(path_ex): name_list = os.listdir(path_ex) full_list = [os.path.join(path_ex, i) for i in name_list] contents = sorted(full_list, key=os.path.getmtime) content_string = "" last_month = "" for file in reversed(contents): curr_date = datetime.fromtimestamp(os.path.getmtime(file)).strftime("%Y-%m-%d") curr_month = datetime.fromtimestamp(os.path.getmtime(file)).strftime("%B %Y") if curr_month != last_month: if last_month != "": content_string += "\n" content_string += "

" + curr_month + "

\n" content_string += "\n" return content_string def gen_index_string(): """ Create and returns a string including every file in the ENTRY_DIR as an index. Returns: string: html-formatted index string """ path_ex = ENTRY_DIR content_string = "" if path.exists(path_ex): name_list = os.listdir(path_ex) full_list = [os.path.join(path_ex, i) for i in name_list] contents = sorted(full_list, key=os.path.getmtime) for file in reversed(contents): filename = pathlib.PurePath(file) # purefile = filename title = open(filename).readline().rstrip("\n") text = open(filename).readlines()[1:] filename = filename.name if filename[0] != ".": filename = filename.split(".", 1)[0] content_string += "
\n" content_string += "

" content_string += "" + \ title + "" +"

\n" content_string += "" + \ datetime.fromtimestamp(os.path.getmtime( file)).strftime("%Y-%m-%d") + "

" if file.endswith(".html"): for line in text: content_string += line if file.endswith(".md"): content_string += gen_md_content(file, 2) content_string += "
" return content_string def gen_stand_string(path_ex): """ Creates a html-string for a file. If the file is markdown it will convert it. This functions ensures upscaling for future formats. Parameters: path_ex: path to a file. Returns: string: html-formatted string string equivalent to the file """ filename = os.path.join(ENTRY_DIR, path_ex) content_string = "" if path.exists(filename): title = open(filename).readline().rstrip("\n") text = open(filename).readlines()[1:] curr_date = datetime.fromtimestamp(os.path.getmtime(filename)).strftime("%Y-%m-%d") filename_no_end = filename.split(".", 1)[0] filename_no_end = filename_no_end.split("/")[-1] content_string += "

" + title + "

\n" content_string += "" + curr_date + "" content_string += "

\n" if filename.endswith(".html"): for line in text: content_string += line if filename.endswith(".md"): content_string += gen_md_content(filename, 1) return content_string def gen_md_content(path_ex, depth): """ Convert a markdown file to a html string. Parameters: path_ex (string): path to the markdown file depth (int): starting depth for markdown headings Returns: string: html-formatted string string equivalent to the markdown file """ content_string = "" if path.exists(path_ex): filename = path_ex.split(".", 1) fileend = filename[len(filename) - 1] header = "#" for i in range(depth): header += "#" header += " " markdown_lines = open(path_ex, "r").readlines()[1:] markdown_text = "" for line in markdown_lines: markdown_text += line.replace("# ", header) content_string = markdown.markdown(markdown_text, extensions=["fenced_code", "tables"]) return content_string def get_rss_string(): """ Create a rss-string of the blog and return it. Returns: string: rss-string of everything that is in the ENTRY_DIR. """ path_ex = ENTRY_DIR content_string = "" if path.exists(path_ex): name_list = os.listdir(path_ex) full_list = [os.path.join(path_ex, i) for i in name_list] contents = sorted(full_list, key=os.path.getmtime) for file in reversed(contents): filename = pathlib.PurePath(file) title = open(filename).readline().rstrip("\n") text = open(filename).readlines()[1:] filename = filename.name if filename[0] != ".": filename = filename.split(".", 1)[0] content_string += "\n" content_string += "" + title + "\n" content_string += "" + config.WEBSITE + \ "/index.html#" + filename + "\n" content_string += "" + \ datetime.fromtimestamp(os.path.getmtime(file)).strftime( "%Y-%m-%d") + "\n" content_string += "" for line in text: content_string += line content_string += "\n" content_string += "\n" return content_string def gen_query_res_string(query_str): """ Return the results of a query. Parameters: query_str (string): term to search Returns: string: html-formated search result """ src_results = search.search(query_str) res_string = "" for result in src_results: title = result["title"] path = result["path"] filename = pathlib.PurePath(path) filename = filename.name if filename[0] != ".": filename = filename.split(".", 1)[0] curr_date = datetime.fromtimestamp(os.path.getmtime(path)).strftime("%Y-%m-%d") is_markdown = path.endswith(".md") preview = create_preview(path, is_markdown) path = "/entry/" + path.split("/", 2)[2] res_string += "
" res_string += "

" + title + "

" res_string += "" res_string += "" + curr_date + "" res_string += "

" res_string += preview + "
" return res_string def create_preview(path, is_markdown): """ Create a preview of a given article and return it. Parameters: path (string): path to the article Returns: string: html-formated preview """ file = open(path, "r", encoding="utf-8") first_lines = file.readlines() preview = "" preview_length = 3 for i, line in enumerate(first_lines): if i == 0: continue if i > preview_length: break if not line.isspace(): if is_markdown: preview += markdown.markdown(line) else: preview += line else: preview_length += 1 preview += "
...
" return preview