csv-library-website/library/app.py

86 lines
2.5 KiB
Python
Raw Normal View History

import csv
import os
2023-11-26 17:52:21 +01:00
import tomllib
import flask_apscheduler
2023-12-03 14:19:53 +01:00
from application.csvparser import CsvParser
from flask import Flask
from flask_bcrypt import Bcrypt
2023-12-03 14:19:53 +01:00
from flask_login import LoginManager
from flask_migrate import Migrate
2023-12-03 14:19:53 +01:00
from flask_sqlalchemy import SQLAlchemy
from flask_wtf.csrf import CSRFProtect
from whoosh.fields import *
from whoosh.index import create_in
from whoosh.qparser import QueryParser
db = SQLAlchemy()
migrate = Migrate()
bcrypt = Bcrypt()
login_manager = LoginManager()
SCRIPT_DIR = os.path.dirname(__file__)
DATA_DIR = os.path.abspath(os.path.join(SCRIPT_DIR, "data"))
2023-12-03 14:19:53 +01:00
def create_app():
2023-11-26 17:52:21 +01:00
settings = settings_from_file()
APP = Flask(__name__, static_folder="static")
APP.config["SECRET_KEY"] = os.urandom(24)
APP.config["UPLOAD_FOLDER"] = "tmpupload"
2023-11-26 17:52:21 +01:00
APP.config["IMAGE_FOLDER"] = "static/images"
APP.config["SQLALCHEMY_DATABASE_URI"] = "sqlite:///libraryusers.db"
APP.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = True
APP.config["LIBRARY_FILENAME"] = settings["libaryfilename"]
APP.config["TITLE"] = settings["title"]
csrf = CSRFProtect(APP)
csrf.init_app(APP)
login_manager.init_app(APP)
db.init_app(APP)
migrate.init_app(APP, db, render_as_batch=True)
bcrypt.init_app(APP)
scheduler = flask_apscheduler.APScheduler()
scheduler.api_enabled = False
scheduler.init_app(APP)
scheduler.start()
2023-11-26 17:52:21 +01:00
index_books(APP.config["LIBRARY_FILENAME"], APP.config["IMAGE_FOLDER"])
@scheduler.task("interval", id="update", minutes=10)
def update():
2023-11-26 17:52:21 +01:00
index_books(APP.config["LIBRARY_FILENAME"], APP.config["IMAGE_FOLDER"])
return APP
2023-11-26 17:52:21 +01:00
def get_app():
APP = Flask(__name__, static_folder="static")
return APP
def index_books(filename: str, image_folder: str):
csvparser = CsvParser(filename, image_folder)
filename = os.path.join(DATA_DIR, csvparser.csv_file)
schema = Schema(
title=TEXT(stored=True), path=ID(stored=True), content=TEXT
)
ix = create_in(DATA_DIR, schema)
writer = ix.writer()
with open(filename, "r", encoding="utf_8_sig") as libcsv:
csv_as_dict = csv.DictReader(libcsv)
for row in csv_as_dict:
2023-11-26 17:52:21 +01:00
rowcontent = csvparser.concatenate_csv_row(row)
writer.add_document(title=row["Id"], path="/a", content=rowcontent)
writer.commit()
2023-11-26 17:52:21 +01:00
def settings_from_file():
settings = {}
with open("settings.toml", "rb") as settings_file:
settings = tomllib.load(settings_file)
return settings