Skip to content

News Aggregator - Aggregates news articles from several RSS feeds, fetches full-text if possible, sorts them by relevance (based on user settings), and display on distraction-free homepage.

License

Notifications You must be signed in to change notification settings

vanalmsick/news_platform

Repository files navigation

Personal News Platform

Go to Documentation & How-To
Go to DockerHub Container: vanalmsick/news_platform

News Aggregator - Aggregates news articles from several RSS feeds, fetches full-text if possible, sorts them by relevance (based on user settings), and display on distraction-free homepage.

PC Home Page:

PC Home Page

Article Reading View:

Article Reading View

Phone Home Page:

Phone Home Page

Features:

  • News article fetching from RSS feeds and videos from YouTube channels
  • Full-text article fetching where possible (currently using fivefilters.org full-text fetcher - later own full-text fetcher)
  • Market data fetching
  • Light/dark modus website
  • Responsive optimized for very large screens, large screens, tablets, phones
  • Webapp
  • Push notifications
  • Custom news sources, article sorting, news-sections/pages, news-ticker/sidebar
  • Article previews when sharing a link e.g. via iMessage, WhatsApp, MS Teams
  • Reading list & archive
  • Still functioning in browsers with JavaScript disabled (aka paranoid-modus)
  • All self-hosted without cookies & tracker (except required ones from Bootstrap style)
  • Optimized to run on low-power servers like RaspberryPi 3 and later

Quick Start / TL;DR

(Make sure Docker is installed: go to docker.com)

Minimal Docker Run Command (CMD):

docker run \
    -p 80:80 \
    -v /your/local/data/dir/news_platform:/news_platform/data \
    --name my_news_platform \
    vanalmsick/news_platform

All out docker_compose.yml setup:
docker_compose.yml:

version: "3.9"

services:

  # The News Platform
  news-platform:
    image: vanalmsick/news_platform
    container_name: news-platform
    restart: always
    ports:
      - 9380:80    # for gui/website
      - 9381:5555  # for Celery Flower Task Que
      - 9382:9001  # for Docker Supervisor Process Manager
    depends_on:
      - news-platform-letsencrypt
    volumes:
      - /your/local/data/dir/news_platform:/news_platform/data
    environment:
      MAIN_HOST: 'https://news.yourwebsite.com'
      HOSTS: 'http://localhost,http://127.0.0.1,http://0.0.0.0,http://docker-container-name,http://news.yourwebsite.com,https://news.yourwebsite.com'
      CUSTOM_PLATFORM_NAME: 'Personal News Platform'
      SIDEBAR_TITLE: 'Latest News'
      TIME_ZONE: 'Europe/London'
      ALLOWED_LANGUAGES: 'en,de'
      FULL_TEXT_URL: 'http://fivefilters:80/full-text-rss/'
      FEED_CREATOR_URL: 'http://fivefilters:80/feed-creator/'
      WEBPUSH_PUBLIC_KEY: '<YOUR_WEBPUSH_PUBLIC_KEY>'
      WEBPUSH_PRIVATE_KEY: '<YOUR_WEBPUSH_PRIVATE_KEY>'
      WEBPUSH_ADMIN_EMAIL: '[email protected]'
      OPENAI_API_KEY: '<YOUR_OPEN_AI_API_KEY>'
    labels:
      - "com.centurylinklabs.watchtower.enable=true"  # if you use Watchtower for container updates


  # HTTPS container for secure https connection [not required - only if you want https]
  news-platform-letsencrypt:
    image: linuxserver/letsencrypt
    container_name: news-platform-letsencrypt
    restart: always
    ports:
      - 9480:80   # incoming http
      - 9443:443  # incoming https
    volumes:
      - news_platform_letsencrypt:/config
    environment:
      - EMAIL=<YOUR_EMAIL>
      - URL=yourwebsite.com
      - SUBDOMAINS=news
      - VALIDATION=http
      - TZ=Europe/London
      - DNSPLUGIN=cloudflare
      - ONLY_SUBDOMAINS=true
    labels:
      - "com.centurylinklabs.watchtower.enable=true"  # if you use Watchtower for container updates


volumes:
  news_platform:
  news_platform_letsencrypt:

start-up command (CMD):

docker compose -f "/your/local/path/docker_compose.yml" up --pull "always" -d

Environmental Variables:

ENV-KEY Default Value / Data Type Description
MAIN_HOST "http://localhost" (any str) Public/local-network facing main URL. Used for links e.g. for webpush push notifications e.g. "https://news.yourwebsite.com" or "http://19.168.172.100"
HOSTS "http://localhost,http://127.0.0.1/" (any str) List of urls to access news platform from. Required to avoid CSRF errors from CSRF attack protection e.g. "http://localhost,http://127.0.0.1,http://0.0.0.0,http://docker-container-name,http://news.yourwebsite.com,https://news.yourwebsite.com"
CUSTOM_PLATFORM_NAME "Personal News Platform" (any str) Name of news platform e.g. "John doe's Personal News Platform"
SIDEBAR_TITLE "Latest News" (any str) Name of sidebar news section e.g. "News Ticker"
TIME_ZONE "Europe/London" (iso str per ICANN tz name) Server time-zone as per official ICANN tz name e.g "Europe/Berlin"
ALLOWED_LANGUAGES "_" _(str list of ISO 639-2)* List of languages in which articles are allowed e.g. "en,de". This is to exclude languages the user does not understand that might be from topic feeds e.g. all articles tagged with "Tech" which might be in English, German, Chines, Spanish etc.
LANGUAGE_CODE "en-UK" (two letter language-country ISO code) ISO code of News Plattform's language and localization for internet browser e.g. "en-US" or "de-DE"
FULL_TEXT_URL "http://ftr.fivefilters.org/" (None or str url) A local instance of fivefilters full-text-rss for full-text fetching. Only required for full-text fetching - currently working on own full-text fetcher.
FEED_CREATOR_URL None (None or str url) Local instance of fivefilters feed-creator if webpages don't have a rss feed to create an rss feed - working on own feed-creator.
WEBPUSH_PUBLIC_KEY "" (str of public vapid-key) Get your own public & private keys for webpush push-notifications e.g. from web-push-codelab.glitch.me or follow these instructions Google Dev Documentation.
WEBPUSH_PRIVATE_KEY "" (str of private vapid-key) Get your own public & private keys for webpush push-notifications e.g. from web-push-codelab.glitch.me or follow these instructions Google Dev Documentation.
WEBPUSH_ADMIN_EMAIL "[email protected]" (str email address) Email address to get notified in case something is wrong with the webpush push notification sending.
OPENAI_API_KEY None (str of openai api key or None) Open AI API key for article summaries.
SECRET_KEY "" (str of django secret key) Django's production secret key.
DEBUG True (bool - currently only True working) To run the news platform in production / dev modus. Currently the production modus does not work.
TESTING False (bool) To run the news platform in real-life testing modus - i.e. fetiching only 10% of news sources to avoid waiting.

These environmental variables can be

  • included in the dockercompose.yml file in section "environment:" as arguments (as above in the dockercompose.yml example),
  • saved as an .env file (example) and passed to the docker_compose.yml file as argument "env_file: /your/local/dir/.env", or
  • saved as an .env file (example) in the news platform container's data directory e.g. " /your/local/data/dir/news_platform/.env"

More information available in the Documentation

About

News Aggregator - Aggregates news articles from several RSS feeds, fetches full-text if possible, sorts them by relevance (based on user settings), and display on distraction-free homepage.

Topics

Resources

License

Stars

Watchers

Forks

Languages