Skip to main content

Forward Datasette events to another instance

Project description

datasette-events-forward

PyPI Changelog Tests License

Forward Datasette events to another instance

Installation

Install this plugin in the same environment as Datasette.

datasette install datasette-events-forward

Configuration

Configure the plugin like so:

{
    "plugins": {
        "datasette-events-forward": {
            "api_token": "***",
            "api_url": "https://stats.datasette.cloud/data/-/create",
            "instance": "localhost"
        }
    }
}

The plugin will then gather all events and forward them to the specified instance, adding them to a table called datasette_events which will be created if it does not exist.

The instance key can be used to differentiate different instances that report to the same backend. Events are identified with a ULID to ensure they are unique even across different instances.

Events are forwarded in batches of up to 10, no more than once every 10 seconds.

Full list of configuration settings:

  • api_url: The write API URL of a Datasette instance to forward the events to.
  • api_token: The API token to use when sending events. Use {"$env": "FORWARD_TOKEN"} to read the token from the FORWARD_TOKEN environment variable.
  • instance: A string to identify the instance that is sending the events.

The api_url can be either a https://datasette.example.com/data/datasette_events/-/insert endpoint for inserting rows, or a https://datasette.example.com/data/-/create endpoint for creating a table and inserting rows into it. If the table does not yet exist you should use the /-/create variant, otherwise use the /-/insert variant.

If you use /-/insert your API token just needs insert-row permissions. For /-/create you will need create-table permissions as well.

And to control the rate at which batches of events are sent to the Datasette write API:

  • batch_limit: The number of events to send in each batch, defaults to 10. The Datasette write API has a 100 row limit by default so this should be set to a value less than that.
  • max_rate: The maximum number of deliver HTTP requests to send in the specified time period, defaults to 1.
  • time_period: The time period for the rate limiting in seconds, defaults to 10.

Development

To set up this plugin locally, first checkout the code. Then create a new virtual environment:

cd datasette-events-forward
python3 -m venv venv
source venv/bin/activate

Now install the dependencies and test dependencies:

pip install -e '.[test]'

To run the tests:

pytest

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

datasette_events_forward-0.1a4.tar.gz (9.8 kB view details)

Uploaded Source

Built Distribution

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

datasette_events_forward-0.1a4-py3-none-any.whl (9.2 kB view details)

Uploaded Python 3

File details

Details for the file datasette_events_forward-0.1a4.tar.gz.

File metadata

  • Download URL: datasette_events_forward-0.1a4.tar.gz
  • Upload date:
  • Size: 9.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for datasette_events_forward-0.1a4.tar.gz
Algorithm Hash digest
SHA256 2ab1fbd2729b5c51c7f1bf81cfcbf3df30d5319b011919a05dbd2d4cf9010839
MD5 fc229207915f619373b8dd871433be4b
BLAKE2b-256 d5b15578ac409f061341384191e6fa36c988e6c4865f92598c0a6d9f8f78b12a

See more details on using hashes here.

Provenance

The following attestation bundles were made for datasette_events_forward-0.1a4.tar.gz:

Publisher: publish.yml on datasette/datasette-events-forward

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

File details

Details for the file datasette_events_forward-0.1a4-py3-none-any.whl.

File metadata

File hashes

Hashes for datasette_events_forward-0.1a4-py3-none-any.whl
Algorithm Hash digest
SHA256 5a2d0fd8078301d1c371949188a95fd227b770bfef3ef6ece672027aa1ac8829
MD5 689114052d15466ddb3a56d20f236d86
BLAKE2b-256 78e86358ff3b4b207a3b74c80be798a950f353ebf061083516437014f9e715eb

See more details on using hashes here.

Provenance

The following attestation bundles were made for datasette_events_forward-0.1a4-py3-none-any.whl:

Publisher: publish.yml on datasette/datasette-events-forward

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