Skip to main content

A Python package that monitors UK legislation for material changes and sends notifications via email, Slack, or webhook

Project description

uk-reg-monitor

uk-reg-monitor is an open-source Python package that monitors UK employment legislation for material changes on a schedule. It acts as a companion client to the UK Employment Law Change Detector API: you configure which Acts of Parliament to watch and how often to check, and uk-reg-monitor handles the scheduling, calls the API on each cycle, and routes any detected changes to your team via email, Slack, or a generic webhook.


Installation

pip install uk-reg-monitor

For development (editable install with test dependencies):

git clone https://github.com/example/uk-reg-monitor.git
cd uk-reg-monitor
pip install -e ".[dev]"

Requires Python 3.12 or later.


Quickstart

Step 1 — Run the setup wizard

uk-reg-monitor init

The wizard guides you through choosing which Acts to monitor, how often to check, and how to receive notifications. It writes config.yaml to your working directory and validates it automatically.

Prefer to configure manually? Create config.yaml by hand:

api:
  base_url: "https://uk-employment-law-change-detector.onrender.com"
  timeout: 30

schedule:
  frequency: "daily"   # hourly | daily | weekly
  time: "08:00"        # HH:MM — used by daily and weekly
  day: "monday"        # day of week — used by weekly only

acts:
  - url: "https://www.legislation.gov.uk/ukpga/1996/18"
    name: "Employment Rights Act 1996"
  - url: "https://www.legislation.gov.uk/ukpga/2010/15"
    name: "Equality Act 2010"
  - url: "https://www.legislation.gov.uk/ukpga/1992/52"
    name: "Trade Union and Labour Relations (Consolidation) Act 1992"

notifications:
  email:
    enabled: false
    smtp_host: "smtp.example.com"
    smtp_port: 587
    use_tls: true
    username: ""
    password: ""
    from_addr: "monitor@example.com"
    to_addrs:
      - "team@example.com"

  slack:
    enabled: false
    webhook_url: ""

  webhook:
    enabled: false
    url: ""
    method: "POST"
    headers:
      Content-Type: "application/json"

Then run uk-reg-monitor validate to check it.

Step 2 — Start the monitor

uk-reg-monitor start

The monitor runs an immediate check on startup, then repeats on the configured schedule. Press Ctrl+C to stop.


CLI Commands

uk-reg-monitor init

Runs the interactive setup wizard. Guides you through choosing Acts, schedule frequency, and notification channels, then writes config.yaml and validates it automatically. Passwords are collected without echoing to the terminal.

uk-reg-monitor init
uk-reg-monitor init --config /path/to/config.yaml

uk-reg-monitor start

Starts the scheduled monitor. Runs an immediate check, then repeats according to schedule.frequency.

uk-reg-monitor start
uk-reg-monitor start --config /path/to/config.yaml
uk-reg-monitor start --verbose

uk-reg-monitor check

Runs a single immediate check across all configured Acts and prints the results to the terminal. Does not start the scheduler.

uk-reg-monitor check
uk-reg-monitor check --config /path/to/config.yaml

uk-reg-monitor validate

Validates config.yaml and prints a summary. Exits with a non-zero code if validation fails. Use this to verify configuration before deploying.

uk-reg-monitor validate
uk-reg-monitor validate --config /path/to/config.yaml

Global flags

Flag Description
--config PATH Path to config.yaml (default: ./config.yaml)
--verbose Enable debug logging

Schedule options

frequency Requires Behaviour
hourly Runs every 60 minutes
daily time: "HH:MM" Runs once per day at the specified time
weekly time: "HH:MM", day: "<weekday>" Runs once per week on the specified day and time

Notification channels

Enable any combination of channels in config.yaml. Notifications are only sent when at least one Act has a material change.

  • Email — plain-text email via SMTP (supports TLS)
  • Slack — POST to a Slack incoming webhook URL
  • Webhook — POST raw JSON to any HTTP endpoint

The UK Employment Law Change Detector API

uk-reg-monitor delegates all intelligence to the UK Employment Law Change Detector API. That API analyses legislation pages and determines whether a material legislative change has occurred. uk-reg-monitor provides the scheduling, configuration, and notification layer on top.

The package connects to the live hosted API at https://uk-employment-law-change-detector.onrender.com by default — no additional setup is required. Interactive API documentation is available at https://uk-employment-law-change-detector.onrender.com/docs.

If you need to point at a different instance, set api.base_url in your config.yaml.


Development

# Run tests
pytest

# Run tests with coverage
pytest --cov=uk_reg_monitor

License

MIT

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

uk_reg_monitor-0.2.3.tar.gz (19.5 kB view details)

Uploaded Source

Built Distribution

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

uk_reg_monitor-0.2.3-py3-none-any.whl (14.8 kB view details)

Uploaded Python 3

File details

Details for the file uk_reg_monitor-0.2.3.tar.gz.

File metadata

  • Download URL: uk_reg_monitor-0.2.3.tar.gz
  • Upload date:
  • Size: 19.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.7

File hashes

Hashes for uk_reg_monitor-0.2.3.tar.gz
Algorithm Hash digest
SHA256 6fe7911127085864daa9016fe5844367f6855146984035dc009fd3f8e140cb54
MD5 c34bd21c40c04b3c7521b75431e36136
BLAKE2b-256 a7792b244b700f2ac5413eaca15daaace359832dc83135d1270349fa2b166464

See more details on using hashes here.

File details

Details for the file uk_reg_monitor-0.2.3-py3-none-any.whl.

File metadata

  • Download URL: uk_reg_monitor-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 14.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.7

File hashes

Hashes for uk_reg_monitor-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 5eb8e2c3582a270a8789b19c50512e5a34c785b971ae5f302e4c9ac59c767142
MD5 0c0f1f3c3541c426ab1b9780c06be329
BLAKE2b-256 c071041bce95b9c62899c953504aaa32006f9c5e589e817a3cd163ab0a4dd6fe

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