-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhelper.py
208 lines (141 loc) · 6.38 KB
/
helper.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
import re
import os
import sys
import random
import hashlib
import datetime
import subprocess
import json
import language_helper
from typing import Optional
from bmod.result import Result, Status
from bmod.eval_result import EvaluationResult
from bs4 import BeautifulSoup
from flask import render_template, send_file
from werkzeug.utils import secure_filename
from jinja2 import Environment, FileSystemLoader, BaseLoader, Template
file_loader = FileSystemLoader(
[os.path.join(os.path.dirname(__file__), "templates"),
os.path.join(os.path.dirname(__file__), "posts"),
os.path.join(os.path.dirname(__file__), "")])
env = Environment(loader=file_loader)
POST_FILE_PATTERN = "^\d{4}\-\d{2}-\d{2}_[\S\s]+\.html.(en|cs)$"
def get_random_file(dir_path, extensions):
files = [f for f in os.listdir(dir_path) if f.lower().endswith(extensions)]
random.seed()
random_number = random.randint(0, len(files))
file = files[random_number]
return os.path.join(dir_path, file)
def enrich_filename(filename):
suffix = hashlib.sha512((str(datetime.datetime.now()) + str(random.randint(0, sys.maxsize))).encode()).hexdigest()
parts = filename.split(".")
parts.insert(len(parts) - 1, suffix)
result = ".".join(parts)
return result
def is_allowed(file, extensions):
if str(file.filename).lower().endswith(extensions):
return True
return False
def create_dirs(path):
if not os.path.exists(path):
os.makedirs(path)
def save_files(request, language, input_name, path, extensions):
create_dirs(path)
success = True
extensions_error_printed = False
status = Status.FAILURE
message = language_helper.texts[language_helper.Message.save_files_failure][language]
if input_name in request.files:
files = request.files.getlist(input_name)
for file in files:
if file.filename != '' and is_allowed(file, extensions):
filename = secure_filename(file.filename)
filename = enrich_filename(filename)
file_path = os.path.join(path, filename)
file.save(file_path)
if not os.path.isfile(file_path):
success = False
else:
success = False
if not is_allowed(file, extensions) and not extensions_error_printed:
message += " {allowed_extensions}: {extensions}.".format(allowed_extensions=language_helper.texts[language_helper.Message.allowed_extensions][language], extensions=", ".join(extensions))
extensions_error_printed = True
if success:
status = Status.SUCCESS
message = language_helper.texts[language_helper.Message.files_saved_successfully][language]
return Result(status, None, message)
def show_page(page, language, *args, **kwargs):
path = localize_path(page, language)
if path is None:
not_found_path = localize_path("static/not_found.html", language)
if not_found_path is None:
return None
else:
path = not_found_path
template = env.get_template(path)
return template.render(*args, **kwargs)
def localize_path(page, language):
path = None
localized_path = "{page}.{lang}".format(page=page, lang=language_helper.Language.to_string(language))
english_path = "{page}.{lang}".format(page=page, lang=language_helper.Language.to_string(language_helper.Language.english))
original_path = page
if os.path.isfile(localized_path):
path = localized_path
elif os.path.isfile(english_path):
path = english_path
elif os.path.isfile(original_path):
path = original_path
return path
def sort_posts(posts):
return sorted(posts, reverse=True)
def get_bmod_page(evaluation_results, result: Optional[Result] = None, path="pages/brno_mobile_ocr_dataset.html", language=language_helper.Language.english):
if result is not None:
if result.status == Status.SUCCESS:
output = show_page(path, language=language, success=True, message=result.message, evaluation_results=evaluation_results)
else:
output = show_page(path, language=language, success=False, message=result.message, evaluation_results=evaluation_results)
else:
output = show_page(path, language=language, evaluation_results=evaluation_results)
return output
def get_hwr_page(result: Optional[Result] = None, path="pages/handwritten_dataset.html", language=language_helper.Language.english):
if result is not None:
if result.status == Status.SUCCESS:
output = show_page(path, language=language, success=True, message=result.message)
else:
output = show_page(path, language=language, success=False, message=result.message)
else:
output = show_page(path, language=language)
return output
def get_posts_preview(limit=3, sort=True, language=language_helper.Language.english):
posts = get_all_posts(language=language)
if sort:
posts = sort_posts(posts)
if limit is not None:
posts = posts[:limit]
return render_posts_preview(posts)
def get_all_posts(path="posts", language=language_helper.Language.english):
all_posts = [f for f in os.listdir(path) if is_post_file(f)]
all_posts_set = set([post.rsplit(".", maxsplit=1)[0] for post in all_posts])
return filter(None, [localize_path(path + "/" + post, language) for post in all_posts_set])
def is_post_file(filename):
if re.match(POST_FILE_PATTERN, filename):
return True
return False
def render_posts_preview(posts):
previews = []
for post in posts:
post_content = ""
with open(post, "r") as f:
for line in f:
line = re.sub(r"{%\s*extends\s+.+?\s*%}", "{% extends 'post_preview.html' %}", line)
post_content += line
file_name_without_extension = os.path.basename(post).split(".")[0]
post_link = "post/{name}".format(name=file_name_without_extension)
post_content = BeautifulSoup(post_content, "lxml").text
preview = env.from_string(post_content)
previews.append(preview.render(link=post_link))
return "<hr>".join(previews)
def get_language(ip):
location = subprocess.check_output('curl http://ip-api.com/json/' + ip, shell=True)
country = json.loads(location.decode('ascii'))["countryCode"]
return language_helper.Language.from_string(country)