Skip to main content

Build a personalized daily newspaper as a print-ready PDF.

Project description

Morning Paper

Your morning newspaper, built from your own sources.

Morning Paper is a Python CLI that builds a personalized daily paper as a print-ready PDF. It starts with deterministic collectors, writes durable file artifacts, and gives you a newspaper you can actually print and read.

No database. No Docker. No SaaS requirement.

What It Does

  • Builds a daily paper from Hacker News and RSS feeds
  • Prints one or more articles on demand with morning-paper print <url>
  • Produces JSON, Markdown, HTML, and PDF artifacts
  • Works without an LLM key
  • Uses a richer typewriter renderer when available and falls back cleanly

Quick Start

For the real product-quality print path, install the pretty renderer:

pip install "morning-paper[pretty]"
morning-paper init
morning-paper doctor
morning-paper build

That writes your paper under:

~/.local/share/morning-paper/<date>/

If you only want the basic fallback install:

pip install morning-paper

That path is functional, but it is not the renderer you should judge the product by.

Platform Support

  • macOS
    • recommended
    • install morning-paper[pretty]
    • may also need:
brew install pango gdk-pixbuf
  • Linux

    • recommended
    • install morning-paper[pretty]
    • may also need system libraries for WeasyPrint such as pango/cairo packages from your distro
  • Windows

    • CLI works
    • portable fallback works more reliably today
    • typewriter via WeasyPrint is best-effort, not the strongest supported path yet

Install Notes

Use morning-paper doctor after install.

  • renderer: typewriter ready
    • you are on the real print path
  • renderer: typewriter unavailable
    • you are on a fallback-only install
    • high-quality print output is not available until the pretty stack is working

On macOS, the richer renderer may also need:

brew install pango gdk-pixbuf

Example Commands

# Create a starter config
morning-paper init

# Build today's paper from your configured sources
morning-paper build

# Build a paper for a specific date
morning-paper build --date 2026-04-15

# Print an article right now
morning-paper print https://example.com/article

# Verify the install
morning-paper doctor

# Show the installed version
morning-paper --version

Current Sources

Source Auth needed? Status
Hacker News No Included
RSS feeds No Included
Article URLs No Included via print

Rendering

Morning Paper currently supports two renderers:

  • typewriter
    • the primary product look
    • the recommended install path
    • requires the pretty print stack
    • uses WeasyPrint
  • portable
    • explicit pure Python fallback
    • lower fidelity
    • do not use this as your default judgment of Morning Paper's design quality
    • only use this if you intentionally want the simpler output

Default config:

article_extractor: jina

outputs:
  renderer: typewriter

jina is the current default article extractor, but extraction is now a replaceable backend. The print renderer, validation, image pipeline, and metadata enrichment are designed to survive extractor upgrades.

If typewriter cannot render, Morning Paper now fails clearly instead of silently generating a lower-quality PDF. If you explicitly want the simpler fallback, set:

outputs:
  renderer: portable

Product Shape

Morning Paper is intentionally narrow.

It is:

  • a CLI
  • file-first
  • print-oriented
  • local-friendly

It is not:

  • a second-brain platform
  • a wiki
  • a database-heavy personal knowledge system
  • a closed feed or recommendation engine

Install for Development

git clone https://github.com/dmthepm/morning-paper.git
cd morning-paper
pip install -e ".[dev]"
python -m pytest tests/
morning-paper doctor

Roadmap

  1. Keep improving article print fidelity in the typewriter renderer
  2. Add queueing and staging commands for agent-driven daily workflows
  3. Add optional LLM scoring without making it a requirement

Contributing

See CONTRIBUTING.md.

Community

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

morning_paper-0.1.4.tar.gz (36.6 kB view details)

Uploaded Source

Built Distribution

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

morning_paper-0.1.4-py3-none-any.whl (31.4 kB view details)

Uploaded Python 3

File details

Details for the file morning_paper-0.1.4.tar.gz.

File metadata

  • Download URL: morning_paper-0.1.4.tar.gz
  • Upload date:
  • Size: 36.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for morning_paper-0.1.4.tar.gz
Algorithm Hash digest
SHA256 34e948d43249b60a4686dc975b405836d8e847f4a5f56e402b68c064374236fe
MD5 6218cb2bb5bbc64273e7e9a6ee596d70
BLAKE2b-256 f9af5544e00eb41f1a67691507615aeba23080086e13b71ae55400445dcbe8ba

See more details on using hashes here.

Provenance

The following attestation bundles were made for morning_paper-0.1.4.tar.gz:

Publisher: publish.yml on dmthepm/morning-paper

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file morning_paper-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: morning_paper-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 31.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for morning_paper-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 0e6c740ff7e273587f039a29f739d7435167f1274e8418668cedf71bd08b1249
MD5 a4133d342055be9cecfd882251f9e572
BLAKE2b-256 0259f228af0568f90a210eae6284e15a808de3ccf356c329e184bdacd6e1e4fa

See more details on using hashes here.

Provenance

The following attestation bundles were made for morning_paper-0.1.4-py3-none-any.whl:

Publisher: publish.yml on dmthepm/morning-paper

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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