Skip to main content

Bring media from shared links directly into Telegram chats.

Project description

Mouse Ran Down

Format and Lint Build and push to ghcr.io Update requirements Publish to PyPI

This is a Telegram bot.

playful image of mouse with clock

When added to a group, any shared public X/Reddit/Instagram/TikTok/Bluesky/YouTube/Vimeo/SoundCloud/Bandcamp/Mastodon posts with media will be replied to with the media uploaded directly into the chat, along with a preview image.

You can also send links as direct (or forwarded) messages to the bot.

If you have Telegram Premium or a Business account, you can add the bot to any or all of your one-on-one chats, as well. In that case, it will look to the other party as if you personally sent the media.

Normally, entire accounts, playlists, and albums won't be loaded. You can insist that the bot try to load a link by including the bot's name in the same message (e.g. @MouseRanDownBot).

Currently running at @MouseRanDownBot.

I do not guarantee any level of service or privacy, so I encourage you to run it yourself.

Credentials

Copy credentials.example.nt to credentials.nt and insert at least a Telegram bot token.

Comment out, delete, or use empty values for any unused fields.

Telegram

Use Telegram's @BotFather to create a bot and get its token.

Ensure you give it permission to read group messages by disabling privacy mode.

Cookies

The optional cookies entry helps if using the bot for reddit video links, and age-restricted content and such on other platforms. You can get the cookie content in the right format with yt-dlp's --cookies and --cookies-from-browser options, or a browser extension like cookies.txt (I can't vouch for the security of this or any extension).

Installing directly

You can use pip/pipx/uv/zpy etc. to install the package from PyPI, e.g.:

$ uv tool install mouse-ran-down
$ uv tool install 'mouse-ran-down[sentry]'  # for Sentry/GlitchTip integration

To run it effectively you'll need to install ffmpeg and mailcap, and you might benefit from installing atomicparsley.

Run mouse-ran-down --help for usage.

You may prefer to just use the container image from my registry (see below).

Build the container image

Make container image with ./mk/ctnr.sh:

$ ./mk/ctnr.sh -h
Build a container image for Mouse Ran Down
Usage: ./mk/ctnr.sh [--connect-repo URL] [<image>]
  <image> defaults to ghcr.io/andydecleyre/mouse-ran-down

Run the container

If doing any of these for a rootless container on a Systemd-using server, don't forget to run this once:

$ loginctl enable-linger

Otherwise podman will kill the container on logout.

From a local image

Run the container from a local image ghcr.io/andydecleyre/mouse-ran-down with:

$ podman run --rm -d -v ./credentials.nt:/app/credentials.nt:ro ghcr.io/andydecleyre/mouse-ran-down

From an image pushed to a registry

./start/podman.sh:

$ ./start/podman.sh -h
Usage: ./start/podman.sh [-n <name>] [-i <image>] [-t <tag>] [-c] [<credentials-file>]
  -n <name>: name of the container (default: mouse)
  -i <image>: name of the image (default: ghcr.io/andydecleyre/mouse-ran-down)
  -t <tag>: tag of the image (default: main)
  -c: remove any dangling images after starting the container
  <credentials-file>: path to credentials.nt (default: ./credentials.nt)

As an auto-updating Systemd service, pulling from a registry

Or you could write an auto-update-friendly quadlet systemd service at ~/.config/containers/systemd/mouse.container, changing the values as you like:

[Container]
AutoUpdate=registry
ContainerName=mouse
Image=ghcr.io/andydecleyre/mouse-ran-down:main
Volume=%h/mouse-ran-down/credentials.nt:/app/credentials.nt:ro

[Service]
Restart=always
TimeoutStartSec=120

[Install]
WantedBy=default.target

Ensure the service is discovered/generated, and start it:

$ systemctl --user daemon-reload
$ systemctl --user start mouse

Ensure the auto-updating timer is enabled:

$ systemctl --user enable --now podman-auto-update.timer

View container logs

$ podman logs CONTAINER_NAME  # e.g. mouse

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

mouse_ran_down-0.0.6.tar.gz (19.1 kB view details)

Uploaded Source

Built Distribution

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

mouse_ran_down-0.0.6-py3-none-any.whl (19.6 kB view details)

Uploaded Python 3

File details

Details for the file mouse_ran_down-0.0.6.tar.gz.

File metadata

  • Download URL: mouse_ran_down-0.0.6.tar.gz
  • Upload date:
  • Size: 19.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.7.6

File hashes

Hashes for mouse_ran_down-0.0.6.tar.gz
Algorithm Hash digest
SHA256 5ba68b4ef29c7ffefbce22e7f57f6f57119a9601e5e92aa069e9ea274a055bf4
MD5 633a1f0378cf3c666200ad05a4fd8081
BLAKE2b-256 0dcea79967f5689f7d7142d8e62ae38564fd576b63ad50d5f2e144e924675d08

See more details on using hashes here.

File details

Details for the file mouse_ran_down-0.0.6-py3-none-any.whl.

File metadata

File hashes

Hashes for mouse_ran_down-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 f2dfaed3dd701b67aefd00c67add764600c719b1d6e9d6d9c59344e344cc2091
MD5 79be0cf6a7402b54b26a2d1c8efb0da8
BLAKE2b-256 2b94be0557012f34ea279149398cbeba9f1d7e01b4321b20946d58b19ae86fc7

See more details on using hashes here.

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