Unofficial library to automate aspects of British/Scottish/Welsh Cycling's club Membership Manager system
Project description
britishcycling-clubs
About
Unofficial, not affiliated or endorsed by British/Scottish/Welsh Cycling.
Library to automate aspects of British Cycling's Club Management Tool, in order to simplify administration for clubs using it. It probably works for Scottish/Welsh Cycling clubs too, but this hasn't been tested.
Priority is to read data in order to create reports/notifications to club administrators.
Prerequisites
- Credentials for a club using the Club Management Tool
Installation
Install from PyPI, e.g:
pip install britishcycling-clubs
Some functions use Playwright to automate a headless Chromium browser. This needs to be installed:
playwright install chromium
If you're installing in e.g. a bare-bones server/CI environment, you'll probably be prompted to install system dependencies, which you can do with:
playwright install-deps chromium
See also https://playwright.dev/python/docs/browsers#install-system-dependencies
Usage
def get_private_member_counts(
club_id: str,
username: str,
password: str,
manager_page_load_delay: int = 5,
) -> dict[str, int]:
Get numbers of active, pending, expired members from the club manager page.
Specifically, returns the counts from these tabs:
- Active Club Members
- New [i.e. pending] Club Subscriptions
- Expired Club Members
This takes about 10s.
get_public_club_info(club_id: str) -> dict[str, int | str]
Return information from the club's public profile page; doesn't require login.
Specifically, returns these values:
- Club name
- Total club members (note that this isn't always a live value even if the club uses the Club Management Tool to manage members)
Example scripts
You'll need to copy config_dist.ini
, rename to config.ini
and populate it with club
ID and (optionally) credentials.
example_private_member_counts.py
loads club ID and credentials from config.ini
.
It then retrieves and prints the number of active, expired and new/pending club member
counts from the club's Club Manager pages.
example_public_club_info.py
loads club ID from config.ini
. It then retrieves and
prints the club name and 'total member count' from the club's public profile page.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for britishcycling_clubs-0.7.0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 78f53a1749bf96ef1ec15ec42c47c4a0f153230de5e115d6c45750afae8737b6 |
|
MD5 | 20aae58c17e05ed9917ce349939c5acf |
|
BLAKE2b-256 | 778b9714bab690553e5ff748e532ad5543a95d68b677f89165fbb121e2d1b660 |
Hashes for britishcycling_clubs-0.7.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7d99f6a2d8821899cb20b87c0579966a2f299321d3c64a60b88d5525e793cf31 |
|
MD5 | d21bda7469168681e1353ee81ed5584b |
|
BLAKE2b-256 | 0df7641b1b136923c17beae46c20962492ae39a9baaecc34fa98b5584f4aae51 |