Skip to main content

Store and monitor site traffic.

Project description

flask-traffic 🚦

PyPI version License

Store and monitor site traffic.

pip install flask-traffic

🚨 Note:

SQLStore requires sqlalchmey

pip install sqlalchemy
# or
pip install "flask-traffic[sqlalchemy]"

SQLORMStore requires sqlalchmey but recommends flask-sqlalchemy

pip install flask-sqlalchemy
# or
pip install "flask-traffic[flask-sqlalchemy]"

RedisStore requires redis

pip install redis
# or
pip install "flask-traffic[redis]"

Minimal Example

from flask import Flask
from flask_traffic import Traffic
from flask_traffic.stores.json import JSONStore

traffic = Traffic()


def create_app():
    app = Flask(__name__)

    json_store = JSONStore()

    traffic.init_app(app, stores=json_store)

    @app.route('/')
    def index():
        return 'Hello, World!'

    @app.route('/traffic')
    def traffic():
        return json_store.read()

    return app

instance/traffic.json

...
{
"request_date": "2024-12-03T20:10:34.932025",
"request_method": "GET",
"request_path": "/",
"request_remote_address": "127.0.0.1",
"request_referrer": null,
"request_user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36",
"request_browser": null,
"request_platform": null,
"response_time": 1,
"response_size": 13,
"response_status_code": 200,
"response_exception": null,
"response_mimetype": "text/html"
}
...

The LogPolicy class

from flask_traffic import LogPolicy

The log policy is used to tell Flask-Traffic what data to store after a request is made in whatever store, or stores you have configured.

A new instance of LogPolicy will have all the log attributes set to True by default.

You can use the methods set_from_true or set_from_false to select which attributes to store.

set_from_true will allow you to disable certain attributes from being stored.

set_from_false will allow you to enable certain attributes to be stored.

If a store is created without a log policy passed in, one is created with all log attributes set to True.

only_on_exception, and skip_on_exception are set to False.

on_endpoints, skip_endpoints, on_status_codes, and skip_status_codes are used to scope or skip logging based on the endpoint or status code. These are disabled by default.

Here's an example of the LogPolicy class only storing the date and request path:

from flask_traffic.stores.json import JSONStore
from flask_traffic import LogPolicy

log_policy = LogPolicy().set_from_false(
    request_date=True,
    request_path=True
)

json_store = JSONStore(log_policy=log_policy)

Results in:

...
{
"request_date": "2024-12-03T20:33:43.051597",
"request_path": "/"
}
...

Here's an example of the LogPolicy class storing everything except the response size:

from flask_traffic.stores.json import JSONStore
from flask_traffic import LogPolicy

log_policy = LogPolicy().set_from_true(
    response_size=False
)

json_store = JSONStore(log_policy=log_policy)

Stores

JSONStore

from flask_traffic.stores.json import JSONStore

This store saves traffic data in a JSON file. The file is created in the instance folder of the Flask app by default.

CSVStore

from flask_traffic.stores.csv import CSVStore

This store saves traffic data in a CSV file. The file is created in the instance folder of the Flask app by default.

SQLStore

requires sqlalchmey

from flask_traffic.stores.sql import SQLStore

This store saves traffic data in a SQL type database. It defaults to using SQLite which is created in the instance folder of the Flask app by default.

You can specify a database URL, or pass in an already created SQLAlchemy engine.

This store is used if you want to store traffic data in a SQL type database.

SQLORMStore

requires flask-sqlalchmey

from flask_traffic.stores.sql_orm import SQLORMStore

This is an ORM version of the SQLStore. It is designed to integrate with an existing SQLAlchemy ORM environment like Flask-SQLAlchemy.

SQLORMModelMixin

from flask_traffic.stores.sql_orm import SQLORMModelMixin

This mixin is used to set the correct table columns for the SQLORMStore.

Example:

from flask_traffic.stores.sql_orm import SQLORMModelMixin

from app import db


class Traffic(db.Model, SQLORMModelMixin):
    pass

RedisStore

from flask_traffic.stores.redis import Redis

This store sends traffic data to a Redis event stream.

Reading store data

Each store has a read method that will return the data in the store as a list of dictionaries.

Here's an example of reading the data from a CSVStore:

@app.route("/read-csv")
def read_csv():
    return csv_store.read()

This will return the data as JSON.

You can also override the read method to change the default, or add more methods of course.

here's an example of overriding the read method in a SQLStore to only return data where the response status code is 200:

class MyStore(SQLStore):
    def read(self):
        with self.database_engine.connect() as connection:
            results = connection.execute(
                self.database_log_table.select().order_by(
                    self.database_log_table.c.traffic_id.desc()
                ).where(
                    self.database_log_table.c.response_status_code == 200
                )
            )
            return [row._asdict() for row in results.fetchall()]

Bigger Examples

SQLORMStore with Flask-SQLAlchemy, JSONStore for exceptions

This example will store traffic data in a SQL database using Flask-SQLAlchemy and store any traffic that causes exceptions in a JSON file.

from flask import Flask
from flask_sqlalchemy import SQLAlchemy

from flask_traffic import Traffic, LogPolicy
from flask_traffic.stores.json import JSONStore
from flask_traffic.stores.sql_orm import SQLORMStore, SQLORMModelMixin

db = SQLAlchemy()
traffic = Traffic()


class Cars(db.Model):
    car_id = db.Column(db.Integer, primary_key=True)
    make = db.Column(db.String(80), unique=True, nullable=False)
    model = db.Column(db.String(80), unique=True, nullable=False)


class Traffic(db.Model, SQLORMModelMixin):
    pass


def create_app():
    app = Flask(__name__)
    app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///instance/db.sqlite'

    db.init_app(app)

    # init traffic after db.init_app to find the db session
    traffic.init_app(
        app, stores=[
            JSONStore(
                log_policy=LogPolicy(only_on_exception=True)
            ),
            SQLORMStore(
                Traffic,
                log_policy=LogPolicy(skip_on_exception=True)
            )
        ])

    @app.route('/')
    def index():
        return 'Hello, World!'

    return app

CSVStore only IP Addresses

This example will store traffic data in a CSV file and only store the IP address

from flask import Flask

from flask_traffic import Traffic, LogPolicy
from flask_traffic.stores.csv import CSVStore

traffic = Traffic()


def create_app():
    app = Flask(__name__)

    traffic.init_app(
        app,
        stores=CSVStore(
            log_policy=LogPolicy().set_from_false(request_remote_address=True)
        )
    )

    @app.route('/')
    def index():
        return 'Hello, World!'

    return app

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

flask_traffic-0.8.2.tar.gz (56.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

flask_traffic-0.8.2-py3-none-any.whl (19.2 kB view details)

Uploaded Python 3

File details

Details for the file flask_traffic-0.8.2.tar.gz.

File metadata

  • Download URL: flask_traffic-0.8.2.tar.gz
  • Upload date:
  • Size: 56.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for flask_traffic-0.8.2.tar.gz
Algorithm Hash digest
SHA256 00c8a9316e6c14c9bfcc2d3b1ca0a1f0fddd3cd1d8c568e9c09208330169bfba
MD5 fe86a3c2c22d7711565fab5614a952a7
BLAKE2b-256 9a7a9ff446d7e4a715c13ac10c8b6de7485b2a2a99b054b03b02fa71aca79d1b

See more details on using hashes here.

Provenance

The following attestation bundles were made for flask_traffic-0.8.2.tar.gz:

Publisher: publish.yml on CheeseCake87/flask-traffic

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file flask_traffic-0.8.2-py3-none-any.whl.

File metadata

  • Download URL: flask_traffic-0.8.2-py3-none-any.whl
  • Upload date:
  • Size: 19.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for flask_traffic-0.8.2-py3-none-any.whl
Algorithm Hash digest
SHA256 f65a5c30a7d28e03b56c698684461d75c320e4cbe1cff9c0499bbee56bdb25c3
MD5 0786ddab555abe4b4272327d0a47d1d3
BLAKE2b-256 21b0f75215b40a37c1233a1c0a33d36c37f596ee9b1cff27219bceca7f88b8c9

See more details on using hashes here.

Provenance

The following attestation bundles were made for flask_traffic-0.8.2-py3-none-any.whl:

Publisher: publish.yml on CheeseCake87/flask-traffic

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page