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
|
2021-07-28 15:13:44 +02:00
|
|
|
from magic_amqp import magic_amqp
|
2021-07-26 17:01:10 +02:00
|
|
|
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
|
2021-07-28 15:13:44 +02:00
|
|
|
magic_amqp.init_app(app)
|
2021-07-26 15:18:08 +02:00
|
|
|
|
|
|
|
ampq_loop_scheduler = BackgroundScheduler()
|
2021-07-28 15:13:44 +02:00
|
|
|
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
|
|
|
|
2021-07-28 15:13:44 +02:00
|
|
|
health.add_check(amqp_connection_status)
|
2021-07-26 15:24:17 +02:00
|
|
|
|
2021-07-26 17:01:10 +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)
|