mirror of
https://github.com/pds-nest/nest.git
synced 2024-11-22 21:14:18 +00:00
bbf7c1e360
Warning: breaking changes ahead! All the data that gets returned by functions is now incapsulated within "data" (response['data']).
53 lines
2 KiB
Python
53 lines
2 KiB
Python
"""
|
|
This is the runner for the server.
|
|
"""
|
|
from flask import Flask
|
|
import os
|
|
import werkzeug.middleware.proxy_fix
|
|
from .routes import *
|
|
from .database import Base, tables
|
|
import psycopg2
|
|
from .gestione import *
|
|
from flask_cors import CORS
|
|
from flask_jwt_extended import *
|
|
|
|
app = Flask(__name__)
|
|
if os.getenv('COOKIE_SECRET'):
|
|
app.secret_key = os.getenv('COOKIE_SECRET')
|
|
else:
|
|
app.secret_key = "testing"
|
|
if os.getenv("JWT_SECRET_KEY"):
|
|
app.config["JWT_SECRET_KEY"] = os.getenv("JWT_SECRET_KEY")
|
|
else:
|
|
app.config["JWT_SECRET_KEY"] = "testing"
|
|
|
|
reverse_proxy_app = werkzeug.middleware.proxy_fix.ProxyFix(app=app, x_for=1, x_proto=0, x_host=1, x_port=0, x_prefix=0)
|
|
if os.getenv("DATABASE_URI"):
|
|
app.config['SQLALCHEMY_DATABASE_URI'] = os.getenv('DATABASE_URI')
|
|
else:
|
|
app.config['SQLALCHEMY_DATABASE_URI'] = 'postgresql://postgres:password@localhost:5432/PdSDev'
|
|
Base.app = app
|
|
Base.init_app(app)
|
|
jwt = JWTManager(app)
|
|
cors = CORS(app)
|
|
app.config['CORS_HEADERS'] = 'Content-Type'
|
|
# Routes setup
|
|
|
|
app.add_url_rule("/doa", view_func=page_doa, methods=["GET", "POST"])
|
|
app.add_url_rule("/api/login", view_func=page_login, methods=["POST"])
|
|
app.add_url_rule("/api/user/create", view_func=page_user_create, methods=["POST"])
|
|
app.add_url_rule("/api/user/remove", view_func=page_user_delete, methods=["POST"])
|
|
app.add_url_rule("/api/repository/list", view_func=page_repository_list, methods=["POST"])
|
|
app.add_url_rule("/api/repository/create", view_func=page_repository_create, methods=["POST"])
|
|
app.add_url_rule("/api/repository/edit", view_func=page_repository_edit, methods=["POST"])
|
|
app.add_url_rule("/api/repository/add_condition", view_func=page_repository_add_condition, methods=["POST"])
|
|
|
|
if __name__ == "__main__":
|
|
Base.create_all()
|
|
if not User.query.filter_by(isAdmin=True).all():
|
|
Base.session.add(User(email="admin@admin.com", password=gen_password("password"), username="admin", isAdmin=True))
|
|
Base.session.commit()
|
|
debug = True
|
|
if os.getenv("DISABLE_DEBUG"):
|
|
debug = False
|
|
app.run(debug=debug)
|