2020-03-25 01:19:22 +01:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
import logging
|
|
|
|
import sentry_sdk
|
|
|
|
from flask import Flask
|
|
|
|
from flask_restful import Api
|
|
|
|
from sentry_sdk.integrations.flask import FlaskIntegration
|
|
|
|
|
|
|
|
from config import SENTRY_DSN, RELEASE_ID, RELEASEMODE, PORT, DEBUG
|
2020-03-25 02:54:59 +01:00
|
|
|
import db
|
2020-03-25 01:19:22 +01:00
|
|
|
from resources import *
|
|
|
|
|
|
|
|
"""
|
|
|
|
Main Flask RESTful API
|
|
|
|
"""
|
|
|
|
|
|
|
|
__author__ = "@tormakris"
|
2020-03-25 02:36:05 +01:00
|
|
|
__copyright__ = "Copyright 2020, Birbnetes Team"
|
2020-03-25 01:19:22 +01:00
|
|
|
__module_name__ = "app"
|
|
|
|
__version__text__ = "1"
|
|
|
|
|
|
|
|
if SENTRY_DSN:
|
|
|
|
sentry_sdk.init(
|
|
|
|
dsn=SENTRY_DSN,
|
|
|
|
integrations=[FlaskIntegration()],
|
|
|
|
send_default_pii=True,
|
|
|
|
release=RELEASE_ID,
|
|
|
|
environment=RELEASEMODE
|
|
|
|
)
|
|
|
|
|
|
|
|
app = Flask(__name__)
|
|
|
|
api = Api(app)
|
2020-03-25 02:54:59 +01:00
|
|
|
db.init_app(app)
|
|
|
|
|
|
|
|
with app.app_context():
|
|
|
|
db.create_all()
|
2020-03-25 01:19:22 +01:00
|
|
|
|
|
|
|
formatter = logging.Formatter(
|
|
|
|
fmt="%(asctime)s - %(levelname)s - %(module)s - %(message)s"
|
|
|
|
)
|
|
|
|
|
|
|
|
handler = logging.StreamHandler()
|
|
|
|
handler.setFormatter(formatter)
|
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
logger.setLevel(logging.DEBUG)
|
|
|
|
logger.addHandler(handler)
|
|
|
|
|
|
|
|
api.add_resource(SampleResource, "/v1/input/sample")
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
app.run(
|
|
|
|
debug=bool(DEBUG),
|
|
|
|
host="0.0.0.0",
|
|
|
|
port=int(PORT),
|
|
|
|
)
|