input-service/src/app.py

97 lines
2.4 KiB
Python
Raw Normal View History

2020-03-25 01:19:22 +01:00
#!/usr/bin/env python3
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-11-19 00:30:26 +01:00
from healthcheck import HealthCheck
2020-03-25 01:19:22 +01:00
2021-08-17 17:53:16 +02:00
from redis_client import redis_client
2021-07-26 12:32:36 +02:00
from config import Config
2020-04-29 22:24:32 +02:00
from marshm import ma
2021-06-13 20:01:23 +02:00
from influxus import influx_db
2021-08-17 17:53:16 +02:00
from resources import SampleResource
2021-08-17 17:16:01 +02:00
from healthchecks import amqp_connection_status
2020-03-25 01:19:22 +01:00
2021-07-26 15:18:08 +02:00
import atexit
from apscheduler.schedulers.background import BackgroundScheduler
from magic_amqp import magic_amqp
from error_handlers import register_all_error_handlers
2021-07-26 15:18:08 +02:00
2021-08-10 14:16:32 +02:00
import jaeger_client
import opentracing
from flask_opentracing import FlaskTracing
2020-03-25 01:19:22 +01:00
"""
2021-07-26 12:32:36 +02:00
Main Flask RESTful API
2020-03-25 01:19:22 +01:00
"""
__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"
2021-07-26 12:32:36 +02:00
if Config.SENTRY_DSN:
2020-03-25 01:19:22 +01:00
sentry_sdk.init(
2021-07-26 12:32:36 +02:00
dsn=Config.SENTRY_DSN,
2021-08-17 18:19:30 +02:00
integrations=[FlaskIntegration()],
2021-08-10 14:16:32 +02:00
traces_sample_rate=0.0,
2020-03-25 01:19:22 +01:00
send_default_pii=True,
2021-07-26 12:32:36 +02:00
release=Config.RELEASE_ID,
environment=Config.RELEASEMODE,
2020-08-02 00:53:49 +02:00
_experiments={"auto_enabling_integrations": True}
2020-03-25 01:19:22 +01:00
)
app = Flask(__name__)
2021-07-26 12:32:36 +02:00
app.config.from_object(Config)
2020-03-25 01:19:22 +01:00
api = Api(app)
2020-12-06 11:16:09 +01:00
health = HealthCheck()
2020-04-29 22:24:32 +02:00
ma.init_app(app)
2021-07-26 15:18:08 +02:00
2021-08-17 17:53:16 +02:00
redis_client.init_app(app)
2021-07-26 15:18:08 +02:00
# ampq magic stuff
magic_amqp.init_app(app)
2021-07-26 15:18:08 +02:00
ampq_loop_scheduler = BackgroundScheduler()
ampq_loop_scheduler.add_job(func=lambda: magic_amqp.loop(), trigger="interval", seconds=5)
2021-07-26 15:18:08 +02:00
atexit.register(lambda: ampq_loop_scheduler.shutdown())
ampq_loop_scheduler.start()
2021-07-26 12:51:52 +02:00
if Config.ENABLE_INFLUXDB:
influx_db.init_app(app)
2020-03-25 02:54:59 +01:00
2021-07-26 12:32:36 +02:00
@app.before_first_request
def init_db():
2021-07-26 12:51:52 +02:00
if Config.ENABLE_INFLUXDB:
influx_db.database.create(Config.INFLUXDB_DATABASE)
2020-03-25 01:19:22 +01:00
2021-08-17 17:53:16 +02:00
2021-08-10 14:16:32 +02:00
# Setup tracing
def initialize_tracer():
app.logger.info("Initializing jaeger...")
jaeger_cfg = jaeger_client.Config(config={}, service_name='input-service', validate=True)
tracer = jaeger_cfg.initialize_tracer()
return tracer
tracing = FlaskTracing(initialize_tracer, True, app)
2021-07-26 12:32:36 +02:00
2021-08-16 15:19:51 +02:00
api.add_resource(SampleResource, "/input")
2020-03-25 01:19:22 +01:00
health.add_check(amqp_connection_status)
2021-07-26 15:24:17 +02:00
register_all_error_handlers(app)
2020-12-06 11:16:09 +01:00
app.add_url_rule("/healthz", "healthcheck", view_func=lambda: health.run())
2021-07-26 15:18:08 +02:00
2021-07-26 17:06:15 +02:00
if __name__ != '__main__':
import logging
2021-08-17 17:53:16 +02:00
2021-07-26 17:06:15 +02:00
gunicorn_logger = logging.getLogger('gunicorn.error')
app.logger.handlers = gunicorn_logger.handlers
app.logger.setLevel(gunicorn_logger.level)