Skip to main content

Meshtastic Firmware and APK Downloader

Project description

Fetchtastic

A simple, cross-platform utility for downloading and managing Meshtastic firmware and client app releases.

Fetchtastic automatically downloads the latest Meshtastic firmware and selected client app assets from GitHub, with support for notifications, scheduling, and repository browsing.

Requires Python 3.10+; Python 3.9 and earlier are unsupported.

โœจ Features

  • ๐Ÿ”„ Automatic Downloads: Latest firmware and Meshtastic client app assets
  • โšก Async Download Engine: aiohttp-based downloads with connection pooling and retry/backoff
  • ๐Ÿ“ฑ Cross-Platform: Linux, macOS, Windows, and Android (Termux)
  • ๐Ÿ—‚๏ธ Repository Browser: Browse and download files from meshtastic.github.io
  • ๐Ÿ”” Notifications: Push notifications via NTFY
  • โฐ Scheduling: Automatic downloads via cron/startup scripts
  • ๐ŸŽฏ Smart Selection: Choose specific devices, APKs, and desktop installers
  • ๐Ÿ“ฆ Auto-extraction: Extract firmware files from zip archives
  • โœ… Stronger Integrity Checks: Hash-based verification and ZIP integrity validation
  • ๐Ÿšฆ GitHub API Resilience: Centralized release fetching, defensive parsing, caching, and rate-limit-aware behavior
  • ๐Ÿงต Parallel Validation: Release completeness checks run in parallel for faster scans
  • ๐Ÿ”ง Easy Setup: One-command installation with guided setup

๐Ÿš€ Quick Start

One-Line Installation

Requires Python 3.10+.

Linux/MacOS/Android (Termux):

curl -sSL https://raw.githubusercontent.com/jeremiah-k/fetchtastic/main/src/fetchtastic/tools/setup_fetchtastic.sh | bash

Security Note: For security-conscious users, you can inspect the script before running it.

Windows (PowerShell):

irm https://raw.githubusercontent.com/jeremiah-k/fetchtastic/main/src/fetchtastic/tools/setup_fetchtastic.ps1 | iex

Security Note: For security-conscious users, you can inspect the script before running it.

Basic Usage

# Run setup (first time)
fetchtastic setup

# Download latest releases
fetchtastic download

# Browse repository files
fetchtastic repo browse

๐Ÿ“– Documentation

Installation Guides

Usage

๐Ÿ”ง Commands

fetchtastic setup         # Run the setup process
fetchtastic download      # Download firmware and client app assets
fetchtastic cache clear   # Clear cached API data
fetchtastic repo browse   # Browse repository files
fetchtastic repo clean    # Clean repository downloads
fetchtastic topic         # Show NTFY topic
fetchtastic version       # Show version
fetchtastic clean         # Remove all configuration

๐Ÿ—๏ธ Architecture Highlights

  • Shared GitHub release source: Release parsing and validation are centralized for consistency across firmware and client app assets.
  • Async + sync compatibility: Async download paths are first-class, with sync fallbacks when async libraries are unavailable.
  • Defensive verification flow: Size checks, hash baselines, and ZIP integrity checks are combined to reduce false positives.
  • Better retry semantics: Retryable vs non-retryable errors are preserved to improve behavior and diagnostics.

๐Ÿ“ File Organization

Downloads are organized in a clean structure:

~/Downloads/Meshtastic/
โ”œโ”€โ”€ app/
โ”‚   โ”œโ”€โ”€ v2.7.14/
โ”‚   โ”‚   โ”œโ”€โ”€ app-fdroid-universal-release.apk
โ”‚   โ”‚   โ”œโ”€โ”€ Meshtastic-2.7.14.dmg
โ”‚   โ”‚   โ””โ”€โ”€ release_notes-v2.7.14.md
โ”‚   โ””โ”€โ”€ prerelease/   # Pre-release client app builds (optional)
โ”œโ”€โ”€ firmware/
โ”‚   โ”œโ”€โ”€ v2.3.2/
โ”‚   โ”œโ”€โ”€ v2.3.1/
โ”‚   โ”œโ”€โ”€ repo-dls/      # Repository browser downloads
โ”‚   โ””โ”€โ”€ prerelease/    # Pre-release firmware (optional)

APKs and desktop installers intentionally share app/<version>/ because they are treated as client app assets from the same release pipeline.

๐Ÿ”” Notifications

Get notified when new releases are downloaded:

  1. Enable NTFY during setup
  2. Install the ntfy app or use the web interface
  3. Subscribe to your unique topic
  4. Receive push notifications for new downloads

โฐ Scheduling

Set up automatic downloads:

  • Linux/macOS: Cron jobs (daily at 3 AM)
  • Windows: Startup folder shortcuts
  • Termux: Boot scripts and cron jobs

๐Ÿ†™ Upgrading

Automatic (recommended):

  • Windows: Use Start Menu โ†’ Fetchtastic โ†’ "Check for Updates"
  • Linux/macOS/Termux: Re-run the installation script

Manual:

pipx upgrade fetchtastic

๐Ÿค Contributing

Contributions are welcome! Please feel free to:

  • Report bugs and issues
  • Suggest new features
  • Submit pull requests
  • Improve documentation

Visit the GitHub repository to get started.

๐Ÿงช Development & Testing

# create and activate environment
python3 -m venv .venv
. .venv/bin/activate

# install dependencies
pip install -r requirements.txt
pip install -r requirements-dev.txt

# run tests
python -m pytest tests/

Test suite organization uses markers such as unit, integration, core_downloads, user_interface, configuration, and infrastructure.

๐Ÿ“„ License

MIT License - see LICENSE for details.

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

fetchtastic-0.10.10.tar.gz (497.8 kB view details)

Uploaded Source

Built Distribution

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

fetchtastic-0.10.10-py3-none-any.whl (269.1 kB view details)

Uploaded Python 3

File details

Details for the file fetchtastic-0.10.10.tar.gz.

File metadata

  • Download URL: fetchtastic-0.10.10.tar.gz
  • Upload date:
  • Size: 497.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for fetchtastic-0.10.10.tar.gz
Algorithm Hash digest
SHA256 e82d3c85af53409a773204228d18c6df970b6fa101b4812984b54c5129f5bce0
MD5 bca0b2b3ff63d292833f100bbaf171f6
BLAKE2b-256 2be22b693d61956ab65b2358dd954619272a9e272cb3f67aaa87a652ebadb6c9

See more details on using hashes here.

Provenance

The following attestation bundles were made for fetchtastic-0.10.10.tar.gz:

Publisher: pypi-publish.yml on jeremiah-k/fetchtastic

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

File details

Details for the file fetchtastic-0.10.10-py3-none-any.whl.

File metadata

  • Download URL: fetchtastic-0.10.10-py3-none-any.whl
  • Upload date:
  • Size: 269.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for fetchtastic-0.10.10-py3-none-any.whl
Algorithm Hash digest
SHA256 9716e5b15e54c9dc37847839a63f217a3dda797325c653ca6d279553a2482b8f
MD5 4e5f424a1e1aac66e7b457ae5389996a
BLAKE2b-256 98c2f256b2d6575887f6f5535266f0007a5b725acac405ba9c84d8e4eef749ed

See more details on using hashes here.

Provenance

The following attestation bundles were made for fetchtastic-0.10.10-py3-none-any.whl:

Publisher: pypi-publish.yml on jeremiah-k/fetchtastic

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