from config import config from database import db from flask import Flask, render_template, request, session, url_for, redirect, jsonify from flask_sslify import SSLify from titanembeds.utils import cache, rate_limiter import blueprints.api import blueprints.user import blueprints.embed import os os.chdir(config['app-location']) app = Flask(__name__, static_folder="static") app.config['SQLALCHEMY_DATABASE_URI'] = config['database-uri'] app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False # Suppress the warning/no need this on for now. app.config['RATELIMIT_HEADERS_ENABLED'] = True app.secret_key = config['app-secret'] db.init_app(app) cache.init_app(app, config={'CACHE_TYPE': 'simple'}) rate_limiter.init_app(app) sslify = SSLify(app, permanent=True) app.register_blueprint(blueprints.api.api, url_prefix="/api", template_folder="/templates") app.register_blueprint(blueprints.user.user, url_prefix="/user", template_folder="/templates") app.register_blueprint(blueprints.embed.embed, url_prefix="/embed", template_folder="/templates") @app.route("/") def index(): return render_template("index.html.j2") @app.route("/oldembed//") def embed_get(guildid, channelid): if 'username' not in session: return redirect(url_for("get_set_username", guildid=guildid, channelid=channelid)) return render_template("embed.html")