Endpoint Pulse - a small FastAPI + Jinja app to organize and probe URLs
Project description
Endpoint Pulse
Project URL: https://github.com/zopyx/zopyx-url-checker-dashboard
Note: This repository is a vibe coding experiment.
A small FastAPI + Bootstrap application to organize and monitor website URLs. You can group URLs in folders (categories), toggle whether a URL is active, and probe availability with HTTP status and response time. The left sidebar shows a collapsible tree of folders/URLs; the right pane shows context forms. Everything is server-rendered with Bootstrap forms.
Purpose
This project provides a lightweight, self-hosted dashboard to:
- Keep URLs organized by category (folders)
- Quickly test the availability of a single URL or all URLs in a folder
- Track basic metadata (name, comment, active flag)
- Use a clean UI without writing any custom JavaScript
Typical use cases include health checking public endpoints, QA/staging links, and simple uptime spot checks.
Tech Stack
- Python 3.12
- FastAPI (server + JSON API)
- Jinja2 templates (server-rendered UI)
- Bootstrap 5 (styling) + Bootstrap Icons
- httpx (HTTP client)
- Pydantic v2 (validation)
Installation
- Ensure Python 3.12 is installed.
- Create and activate a virtual environment, then install dependencies:
python -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
Installing the package from TestPyPI
When installing from TestPyPI, most third-party dependencies are not available on TestPyPI. Use the main PyPI as an extra index so pip can resolve dependencies like FastAPI and setuptools from PyPI while fetching this package from TestPyPI:
pip install --index-url https://test.pypi.org/simple/ \
--extra-index-url https://pypi.org/simple \
endpoint-pulse
Note: We constrain FastAPI to < 1.0 to avoid a known problematic fastapi==1.0 build on TestPyPI which requires setuptools from TestPyPI (not available). The extra-index-url ensures dependencies are pulled from the official PyPI.
Running the App
Start the development server with auto-reload:
uvicorn main:app --reload
Or use the packaged console script (after installing the package):
endpoint-pulse --host 0.0.0.0 --port 8000 --reload
Environment variables are also supported when flags are omitted:
- ENDPOINT_PULSE_HOST (default: 127.0.0.1)
- ENDPOINT_PULSE_PORT (default: 8000)
- ENDPOINT_PULSE_RELOAD (set to 1/true/on to enable)
Open your browser at:
Testing
Unit/Integration tests with coverage
pip install -r requirements.txt
make tests
This runs pytest (excluding Playwright/browser tests) with coverage and prints a term-missing coverage report for main.py. Tests run against a temporary, isolated database by overriding environment variables in fixtures, so your production data is not modified.
Alternatively, without make:
python -m pytest -m "not playwright" --cov=main --cov-report=term-missing
End-to-end (Playwright) tests
Install browsers once:
python -m playwright install
Run E2E tests:
python -m pytest -m playwright tests_e2e
The E2E harness launches uvicorn on a random local port with an isolated data store.
Data Persistence
Data and configuration are stored in a local SQLite database at data.sqlite3 in the project root (override with DB_FILE). The schema has folders, nodes, and a small meta table for ID counters.
Architecture Notes
- Startup initialization: The database schema is initialized once at app startup via FastAPI's lifespan. This avoids redundant schema checks per request and improves efficiency.
- Modularity: The current codebase is intentionally compact. Future work may extract database access and request handlers into separate modules (e.g., db.py, services.py, api_routes.py) and adopt an ORM like SQLAlchemy for more maintainable data access.
UI Overview (Server-rendered)
- Left: collapsible tree of folders and their URLs.
- Right: context forms for adding/renaming/deleting folders, adding/editing/deleting/testing URLs.
- Test results show below the forms in a compact table.
- Preferences modal with a dark mode toggle (stored in a cookie).
Notes
- Authentication/authorization: none (intended for local/network use). Place behind a reverse proxy with auth if needed.
- Timeouts: Configurable via Preferences (default 10 seconds) per request when probing URLs.
- Redirects: HTTP redirects are followed during probes.
- Dark mode preference is stored in a cookie (
theme=light/dark).
Visualization
- After running tests, the page shows a compact response time chart (inline SVG) beneath the results table, including number of requests (measured/total) and average response time.
Author
Andreas Jung info@zopyx.com
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file endpoint_pulse-0.2.2.tar.gz.
File metadata
- Download URL: endpoint_pulse-0.2.2.tar.gz
- Upload date:
- Size: 34.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4cadb171908be1f0ed6bf912b294b9291f645bfc4ce21a1ea81f52dbb520c7d1
|
|
| MD5 |
5d0e01e55548b373ea072433c00c07fc
|
|
| BLAKE2b-256 |
d52238d631e1ef9e412e2c684509a8d3521ab07ad87d1115310a2aa52f9846d8
|
File details
Details for the file endpoint_pulse-0.2.2-py3-none-any.whl.
File metadata
- Download URL: endpoint_pulse-0.2.2-py3-none-any.whl
- Upload date:
- Size: 28.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2a67047bb38150d9a0010d8e3e0670b9d8a8848df27f23119a4e4abd5d1f6970
|
|
| MD5 |
6d4e5838e7f8fe1671fb2e8c545e9e3f
|
|
| BLAKE2b-256 |
32d5c17f31187d0956065a7e3516a49991ffb5e99752cc2190177c1f8d1d6372
|