Skip to main content

A web application for running Python scripts.

Project description

script-runner

A tool for defining python functions, triggering their execution and displaying results via a user interface.

Used at Sentry to allow specific users to run predefined Python scripts on production data.

Deployment modes

Multi-region deployments enable aggregating results across multiple "regions" or "silos", whilst still enabling script execution to be performed in a single region.

  • set mode: main for the central region
  • set mode: region for each instance of the application deployed in each regions

For a single deployment in one region use mode:combined. Currently we only use this for dev and testing.

Writing custom scripts

Scripts are standard python functions organized into groups.

All of the arguments to a function must be annotated with one of the supported parameter types. The currently supported ones are:

  • Text
  • Textarea
  • Integer
  • Number
  • Autocomplete
  • DynamicAutocomplete

Example:

def print_value(input: Text) -> None:
    """
    for short text, renders <input type="text" /> in the ui
    """
    print(input.value)

def print_long_value(input: TextArea) -> None:
    """
    multiline text, renders <textarea /> in the ui
    """
    print(input.value)

The annotation controls how the element is displayed in the UI, and the Python type of the value (str, int or float)

The return value of the function can be anything, as long as it is json serializable

Any functions exported by a module via __all__ will be picked up automatically and displayed in the UI.

Writing tests

Use the execute_with_context helper from the testutils module to call your function with mock values.

Authentication

currently google iap (and no auth) are supported

for google iap, set the audience_code as well as iap_principals (group -> iap principal mapping) in the config

Example data:

  • These are in the examples/scripts directory

Configuration

check config.schema.json for configuration format and required fields. there is also an example of each mode in this repository: example_config_combined.yaml, example_config_main.yaml, example_config_local.yaml

Development

  • Run make devserver. The application will run on combined mode on http://127.0.0.1:5000

  • If you want UI hot reloading, you have to run the vite server separately.

  • Navigate to the frontend directory:

    cd script_runner/frontend
    
  • Install dependencies if you haven't already:

    npm install
    
  • Run the Vite development server:

    npm run dev
    
  • The frontend should now be running on http://localhost:5173 and will automatically proxy API requests to the backend thanks to the proxy configured in vite.config.ts.

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

sentry_script_runner-0.2.6.tar.gz (68.1 kB view details)

Uploaded Source

Built Distribution

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

sentry_script_runner-0.2.6-py3-none-any.whl (1.8 MB view details)

Uploaded Python 3

File details

Details for the file sentry_script_runner-0.2.6.tar.gz.

File metadata

  • Download URL: sentry_script_runner-0.2.6.tar.gz
  • Upload date:
  • Size: 68.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.2

File hashes

Hashes for sentry_script_runner-0.2.6.tar.gz
Algorithm Hash digest
SHA256 8554e2a17babbf480ed57d45b6fd9513ba67dbeea80130df5d35c0e75b497ee8
MD5 cc3b3932382c2ae1b6ce216213ec0f8d
BLAKE2b-256 e9ae491e1f2b42478e7090ee805768c9ed77a2c4c6463412450545ebcc17e1ce

See more details on using hashes here.

File details

Details for the file sentry_script_runner-0.2.6-py3-none-any.whl.

File metadata

File hashes

Hashes for sentry_script_runner-0.2.6-py3-none-any.whl
Algorithm Hash digest
SHA256 ff32d9fdd810fabd926c17799d5730e8461f62d0f6f9867fa86ab86c69bde4c0
MD5 222e77ccb9943ab079eb3a3d3708984a
BLAKE2b-256 9c87688e0aaf5f8f56ef473e4f735b7e642c5809db3025763af16501f97a6681

See more details on using hashes here.

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