Memogram is an easy to use integration service for syncing messages and images from a Telegram bot into your Memos.
- Memos service
- Telegram Bot
Download the binary files for your operating system from the Releases page.
Create a .env
file in the project's root directory and add the following configuration:
SERVER_ADDR=dns:localhost:5230
BOT_TOKEN=your_telegram_bot_token
INSTANCE_URL=https://memos.example.com
The SERVER_ADDR
should be a gRPC server address that the Memos is running on. It follows the gRPC Name Resolution.
-
Download and extract the released binary file;
-
Create a
.env
file in the same directory as the binary file; -
Run the executable in the terminal:
./memogram
-
Once the bot is running, you can interact with it via your Telegram bot.
Or you can start the service with Docker:
-
Build the Docker image:
docker build -t memogram .
-
Run the Docker container with the required environment variables:
docker run -d --name memogram \ -e SERVER_ADDR=dns:localhost:5230 \ -e BOT_TOKEN=your_telegram_bot_token \ memogram
-
The Memogram service should now be running inside the Docker container. You can interact with it via your Telegram bot.
Or you can start the service with Docker Compose. This can be combined with the memos
itself in the same compose file:
- Create a folder where the service will be located.
- Clone this repository in a subfolder
git clone https://github.com/usememos/telegram-integration memogram
- Create
.env
fileSERVER_ADDR=dns:yourMemosUrl.com:5230 BOT_TOKEN=your_telegram_bot_token INSTANCE_URL=https://memos.example.com
- Create Docker Compose
docker-compose.yml
file:services: memogram: env_file: .env build: memogram container_name: memogram
- Run the bot via
docker compose up -d
- The Memogram service should now be running inside the Docker container. You can interact with it via your Telegram bot.
- Create a folder for your project.
- Clone this repository in a subfolder:
git clone https://github.com/usememos/telegram-integration memogram
- Create a
.env
file in the project root with the following content:
SERVER_ADDR=dns:memos.com:5230
BOT_TOKEN=your_telegram_bot_token
INSTANCE_URL=https://memos.example.com
Note: We use memos
as the SERVER_ADDR because it's the service name in our Docker network.
4. Create a docker-compose.yml
file in the project root with the following content:
version: "3.8"
services:
memos:
image: neosmemo/memos:stable
container_name: memos
volumes:
- ~/.memos/:/var/opt/memos
ports:
- 5230:5230
networks:
- memos-network
memogram:
env_file: .env
build: memogram
container_name: memogram
networks:
- memos-network
depends_on:
- memos
networks:
memos-network:
name: memos-network
- Run both services using:
docker-compose up -d
/start <access_token>
: Start the bot with your Memos access token.- Send text messages: Save the message content as a memo.
- Send files (photos, documents): Save the files as resources in a memo.
/search <words>
: Search for the memos.