input-service/src/app.py

60 lines
1.4 KiB
Python
Raw Normal View History

2020-03-25 01:19:22 +01:00
#!/usr/bin/env python3
import logging
from flask import Flask
from flask_restful import Api
2020-03-31 16:51:31 +02:00
import sentry_sdk
2020-03-25 01:19:22 +01:00
from sentry_sdk.integrations.flask import FlaskIntegration
2020-03-31 16:51:31 +02:00
import rabbitmqqueue
2020-03-31 14:46:46 +02:00
from config import *
2020-03-31 15:10:58 +02:00
from db import db
2020-03-31 16:51:31 +02:00
from resources import SampleResource, SampleParameterResource
2020-03-25 01:19:22 +01:00
"""
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
)
2020-03-31 14:46:46 +02:00
2020-03-25 01:19:22 +01:00
app = Flask(__name__)
2020-03-31 14:46:46 +02:00
app.config['SQLALCHEMY_DATABASE_URI'] = f"postgresql://{POSTGRES_USERNAME}:{POSTGRES_PASSWORD}@{POSTGRES_HOSTNAME}:5432/{POSTGRES_DB}"
2020-03-25 01:19:22 +01:00
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")
2020-03-31 16:51:31 +02:00
api.add_resource(SampleParameterResource, '/v1/input/sample/<tag>')
2020-03-25 01:19:22 +01:00
if __name__ == "__main__":
app.run(
debug=bool(DEBUG),
host="0.0.0.0",
port=int(PORT),
)