A FastAPI web server for creating RSS and ActivityPub feeds for scholarly literature with the magic of adversarial interoperability
Project description
paper-feeds
A FastAPI web server for creating RSS feeds for scholarly journals with the magic of adversarial interoperability
Many journals still have RSS feeds. Some don't though, as they try and squeeze everyone onto their platforms to monetize our engagement data.
This is a simple web app for creating feeds (currently RSS, soon ActivityPub and Atom) for academic papers by collecting metadata from multiple data sources. It intended to be a publicly- and self-hostable toolkit for subscribing to and curating scholarly literature!
Dependencies are kept minimal, as is deployment - No webpack, no complex build, no postgres, just pip install and press play :).
usage
(to be completed when main docs are, for now here's something brief)
After creating and activating a virtual environment...
pip install paper-feeds
python -m paper_feeds
# then open http://localhost:8000 in your browser
Note: we are still working out the packaging here, so you may need to clone the repository and run the server from the repo root until we can figure that out :)
And see CONTRIBUTING.md for more information on setting up a development environment
progress
Everything is just getting started! things will break and change! To be moved to docs when made. Help wanted on all, open an issue <3
API:
- Query Crossref for journal
- Write journal metadata to db
- Paginate papers by journal
- Store papers in db
- Populate papers when feed created
- Periodic database updates
- Cache Feed output
- Scheduled update of feed metadata
- Backfill Abstracts and other additional data
- Feed statistics
Frontend
- Search for journal
- Display list of journals
- Pages for each journal
- Create new feed button
- Copy feed link
- Export feeds
- Show existing feeds, stats, threads
Feed Types
- Journals
- Authors (via ORCID)
- Keywords
Feed Formats
- RSS
- RSS feed from papers by issn
- Linked Data-enriched RSS feeds (see crossref's advice)
- HTML formatting for item details
- Activitypub
- Actors for feeds
- LD-enriched ActivityStreams actions
- Bot-Actor for instance
- DOI mention detection & crossref events data
- Hashtag -> keyword detection
- Create threads under feed actor with mention
Data Sources
- Crossref
- Journals
- Papers
- Events
- OpenAlex
- ORCID
- PubPeer
- RetractionWatch
- Hypothes.is
Meta
- Docs
- We need em! Sphinx & RTD!
- Move this list to there
- Scope
- Design
- Usage
- Configuration
- Tests
- Basic CI
Credits
- El Duvelle, whose need for RSS feeds inspired this project
- @lambdaloop (list PRs)
- @roaldarbol (list PRs)
References
- https://github.com/marty331/fasthtmx/
- https://samherbert.net/svg-loaders/
- https://htmx.org/examples/active-search/
See also
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 paper_feeds-0.0.5-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 72c0c26439422bbd8b91b46ca8c103aceb1fcb76fca1a6f928119729e1bd00fc |
|
MD5 | ac4d3ea5d6f7900ad4ae9b0cc6feb8a9 |
|
BLAKE2b-256 | c6aef67ba3dbc1c76ca21bb03e04224917095f93d25df38caf609e6c4a86866c |