Because everything on the Web eventually loops back onto itself.
- View all entries in the ring
- Automatically provided JavaScript to embed a simple rendering of all entries
- Create, update, and delete entries
- Linkrot checking, with Web Archive fallback url for dead links (when possible)
- Optional linkrot event logging to Discord channel
- Text error log fallback if disabled
Starting with version 1.3.0, TODO: write me!
Starting with version 1.3.0, a JavaScript file is provided to generate and embed a simple rendering of the webring into your site. It includes the entire ring in the script, preventing any additional requests to fetch ring entries.
TODO: noscript/no js backup
TODO: write me!
Note this could potentially be slow, depending on the number of entries in the ring. This script is also not minified, which could also increase your page load time. If you want or need greater control over loading and displaying the ring, it is suggested to manually call the ring's root URL to fetch the entries and display them as you desire.
- Flask secret key (
SECRET_KEY
) - Flask app environment (
FLASK_ENV
) set to"production"
- Absolute path to SQLite file (
DB_PATH
) - JSON list of auth keys for all non-GET operations (
AUTH_KEYS
) - Integer number of times supposed rotted links should be checked (
TIMES_FAILED_THRESHOLD
, default: 10) - Discord linkrot event logging boolean (
ENABLE_DISCORD_LOGGING
, default:False
)- Discord webhook URL (
DISCORD_WEBHOOK_URL
)
- Discord webhook URL (
- Install Python 3.11+, Poetry 1.2.0+, and VS Code
- Create required secret keys (default:
/app/secrets
or environment) - Run
poetry install
- Launch the API using the provided VS Code launch configuration
- Auto-generated API docs are available at
/docs
- Run tests with
poetry run pytest
or through VS Code
docker build -t webring:latest .
docker-compose up -d
2021-2024 Caleb