aboutsummaryrefslogtreecommitdiffstats
path: root/resources/tools/dash/app/pal/__init__.py
blob: bb110a254d9f19c63180e3beb49bdfbb19673096 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
# Copyright (c) 2022 Cisco and/or its affiliates.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at:
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

"""Initialize Flask app.
"""

import logging

from flask import Flask
from flask_assets import Environment


# Maximal value of TIME_PERIOD in days.
# Do not change without a good reason.
MAX_TIME_PERIOD = 180

# It defines the time period in days from now back to the past from which data
# is read to dataframes.
# TIME_PERIOD = None means all data (max MAX_TIME_PERIOD days) is read.
# TIME_PERIOD = MAX_TIME_PERIOD is the default value
TIME_PERIOD = MAX_TIME_PERIOD  # [days]

# List of releases used for iterative data processing.
# The releases MUST be in the order from the current (newest) to the last
# (oldest).
RELEASES=["rls2202", ]

def init_app():
    """Construct core Flask application with embedded Dash app.
    """

    logging.basicConfig(
        format=u"%(asctime)s: %(levelname)s: %(message)s",
        datefmt=u"%Y/%m/%d %H:%M:%S",
        level=logging.INFO
    )

    logging.info("Application started.")

    app = Flask(__name__, instance_relative_config=False)
    app.config.from_object(u"config.Config")

    with app.app_context():
        # Import parts of our core Flask app.
        from . import routes

        assets = Environment()
        assets.init_app(app)

        if TIME_PERIOD is None or TIME_PERIOD > MAX_TIME_PERIOD:
            time_period = MAX_TIME_PERIOD
        else:
            time_period = TIME_PERIOD

        # Import Dash applications.
        from .stats.stats import init_stats
        app = init_stats(app, time_period=time_period)

        from .trending.trending import init_trending
        app = init_trending(app, time_period=time_period)

        from .report.report import init_report
        app = init_report(app, releases=RELEASES)

    return app


app = init_app()