TediCross is a bot which bridges a chat in Telegram with a channel in Discord.
There is no public TediCross bot. You need to host it yourself. To host a bot, you need nodejs. The bot requires NodeJS 16 or higher.
If you are cloning the repository and looking for the stable release, switch to the stable
branch.
We now have a Telegram channel where we post news about the bot! Join us at https://t.me/TediCross
The bot is able to relay text messages and media files between Discord and Telegram. @-mentions, URLs, code (both inline and block-style) works well
For a list of known bugs, or to submit a bug or feature request, see this repo's "Issues" tab
Setting up the bot requires basic knowledge of the command line, which is bash or similar on Linux/Mac, and cmd.exe in Windows
- Install nodejs. TediCross requires at least node version 16
- Download the latest release
- Open a terminal and enter the repo with the
cd
command. Something likecd Downloads/TediCross-master
. Your exact command may differ - Run the command
npm install --omit=dev
- Make a copy of the file
example.settings.yaml
and name itsettings.yaml
- Acquire a bot token for Telegram (How to create a Telegram bot) and put it in the settings file
- The Telegram bot must be able to access all messages. Talk to @BotFather to disable privacy mode for the bot
- Do NOT use another bot you already have running. That will cause all sorts of weird problems. Make a new one
- Acquire a bot token for Discord (How to create a Discord bot), enable the
Message Content Intent
underBot
>Privileged Gateway Intents
and put it in the settings file underdiscord.token
. NOTE that the token is NOT the "Client Secret". The token is under the section "Bot" further down the page
- Do NOT use another bot you already have running. That will cause all sorts of weird problems. Make a new one
- Add the Telegram bot to the Telegram chat
- If the Telegram chat is a supergroup, the bot also needs to be admin of the group, or it won't get the messages. The creator of the supergroup is able to give it admin rights
- Add the Discord bot to the Discord server (https://discord.com/oauth2/authorize?client_id=YOUR_CLIENT_ID_HERE&scope=bot&permissions=248832). This requires that you have admin rights on the server
- Start TediCross:
npm start
- Ask the bots for the remaining details. In the Telegram chat and the Discord channel, write
/chatinfo
. Put the info you get in the settings file.
- If you want to bridge a Telegram group or channel, remember that the ID is negative. Include the
-
when entering it into the settings file - It is important that the Discord channel ID is wrapped with single quotes when entered into the settings file.
'244791815503347712'
, not244791815503347712
- Restart TediCross. You stop it by pressing CTRL + C in the terminal it is running in
- To turn on threads support (EXPERIMENTAL) just add
topicBridges
section under particularBridge
. Write/threadinfo
in telegram and discord threads to get corresponding IDs. !NOTE: previously this param was namedthreadMap
. Old configs with that name still valid. - Auto mapping of threads (EXPERIMENTAL). Boolean option
topicBridgesAutoCreate
under particularBridge
. It'sfalse
by default. If it'strue
bot will create topic/thread on one side of the bridge when unmapped topic appears on another side. NOTE if you delete mapped topic on one of the sides of the bridge - bot will recreate it automatically on the other side - so you will need to delete topic on both sides.
Done! You now have a nice bridge between a Telegram chat and a Discord channel
Please refer to Docker Guide for the details.
As mentioned in the step-by-step installation guide, there is a settings file. Here is a description of what the settings do.
telegram
: Object authorizing and defining the Telegram bot's behaviortoken
: The Telegram bot's token. It is needed for the bot to authenticate to the Telegram servers and be able to send and receive messages. If set to"env"
, TediCross will read the token from the environment variableTELEGRAM_BOT_TOKEN
useFirstNameInsteadOfUsername
: If set totrue
, the messages sent to Discord will be tagged with the sender's first name + last name. If set tofalse
- sender's username will be preferred, but if username is not set - first name + last name. Note that Discord users can't @-mention Telegram users by their first name. Defaults tofalse
colonAfterSenderName
: Whether to put a colon after the name of the sender in messages from Discord to Telegram. If true, the name is displayedName:
. If false, it is displayedName
. Defaults to falseskipOldMessages
: Whether to skip through all previous messages cached from the telegram-side and start processing new messages ONLY. Defaults to true. Note that there is no guarantee the old messages will arrive at Discord in ordersendEmojiWithStickers
: Whether to send the corresponding emoji when relaying stickers to DiscordfilterCustomEmojis
: Determines what to do with custom emojis from Discord message before it reaches telegram. Has three states:default
- custom emojis will be transferred without any processing (ex: <:emojisnhead:1102667149627113602> My Text);remove
- custom emojis will be removed from the output (ex: My Text);replace
- custom emojis will be replaced with a definable string. Defined inreplaceCustomEmojisWith
(ex: 🔹 My Text). Defaults todefault
replaceCustomEmojisWith
: Determines a string that will be used as a replacement for custom emojis. Anything that can be passed as a string is supported, including emojis. Defaults to🔹
replaceAtSign
: Whether to replace@
sign to something else from Discord message before it reaches. When set totrue
will replace@
with a string you put intosettings.replaceAtSignWith
. If set tofalse
- will do nothing. Defaults tofalse
replaceAtSignWith
: Determines the string that will be used as a replacement for@
sign. Anything that can be passed as a string is supported, including emojis. Defaults to#
removeExcessiveSpacings
: USE WITH CAUTION Whether to remove excessive (2 or more)whitespaces
from Discord message. Can help to neat your message up if it wasn't particulary untidy in the source. When set totrue
will remove excessivewhitespaces
and replace them with a singlewhitespace
instead. If set tofalse
- will do nothing. Defaults tofalse
suppressFileTooBigMessages
: Suppress warning messages on errors with sending too big files (due to API limitations) from telegram to discord. Defaults tofalse
.suppressThisIsPrivateBotMessage
: If set totrue
- suppress warning messages (This is an instance of a TediCross bot...
) in telegram chats outside configured bridges. Defaults tofalse
discord
: Object authorizing and defining the Discord bot's behaviortoken
: The Discord bot's token. It is needed for the bot to authenticate to the Discord servers and be able to send and receive messages. If set to"env"
, TediCross will read the token from the environment variableDISCORD_BOT_TOKEN
skipOldMessages
: Whether to skip through all previous messages sent since the bot was last turned off and start processing new messages ONLY. Defaults to true. Note that there is no guarantee the old messages will arrive at Telegram in order. NOTE: Telegram has a limit on how quickly a bot can send messages. If there is a big backlog, this will cause problemsuseNickname
: Uses the sending user's nickname instead of username when relaying messages to TelegramreplyLength
: How many characters of the original message to display on repliesmaxReplyLines
: How many lines of the original message to display on repliessuppressThisIsPrivateBotMessage
: If set totrue
- suppress warning messages (This is an instance of a TediCross bot...
) in discord channels outside configured bridges. Defaults tofalse
enableCustomStatus
: If set totrue
- enables the custom status. Defaults tofalse
customStatusMessage
: The message to set as custom status. Defaults to "TediCross"
debug
: If set totrue
, activates debugging output from the bot. Defaults tofalse
messageTimeoutAmount
: Amount for your unit of time to expire messages in MessageMap. Defaults to24
messageTimeoutUnit
: Format of time as a string (ie: 'hours', 'days', 'weeks', etc...). Defaults to'hours'
persistentMessageMap
: Allow MessageMap to persist between reboots by saving it to a file. Defaults tofalse
bridges
: An array containing all your chats and channels. For each object in this array, you should have the following properties:name
: A internal name of the chat. Appears in the logdirection
: Direction of the bridge. "both" for bidirectional, "d2t" for discord-to-telegram, "t2d" for telegram-to-discordtelegram.chatId
: ID of the chat that is the Telegram end of this bridge. See step 11 on how to acquire ittelegram.relayJoinMessages
: Whether to relay messages to Discord about people joining the Telegram chattelegram.relayLeaveMessages
: Whether to relay messages to Discord about people leaving the Telegram chattelegram.sendUsernames
: Whether to send the sender's name with the messages to Discord
telegram.crossDeleteOnDiscord
: Whether to also delete the corresponding message on Discord when one is deleted on Telegram. NOTE: See FAQ about deleting messages.discord.channelId
: ID of the channel the Discord end of the bridge is in. See step 11 on how to acquire itdiscord.relayJoinMessages
: Whether to relay messages to Telegram about people joining the Discord chatdiscord.relayLeaveMessages
: Whether to relay messages to Telegram about people leaving the Discord chatdiscord.sendUsernames
: Whether to send the sender's name with the messages to Telegramdiscord.crossDeleteOnTelegram
: Whether to also delete the corresponding message on Telegram when one is deleted in Discorddiscord.disableWebPreviewOnTelegram
: Whether to disable links preview when relaying to Telegramdiscord.useEmbeds
: Whether to use embeds for current bridge. Can bealways
,never
,auto
. Defaults tofalse
topicBridges
: An array containing all threads mapping for each bridgetelegram
: Telegram thread ID. See step 13 on how to acquire itdiscord
: Discord thread ID. See step 13 on how to acquire it
The available settings will occasionally change. The bot takes care of this automatically
Anything capable of running NodeJS should be able to run TediCross. People have had success running it on ordinary laptops, raspberry pis, Amazon Web Services, Google Cloud Platform, and other machines. It runs on both Linux and Windows, and probably also macOS. It does NOT, however, run on Heroku
The machine must be on for TediCross to work
Not much at all. Almost all the commands are written in the installation guide exactly as they should be entered. The only thing you need to know in addition is the cd
command, in order to navigate to wherever you unpacked TediCross
This likely means you are using Ubuntu or another Debian based Linux distro. You get node version 4 when you do apt-get install nodejs
, and it is called nodejs
instead of node
.
TediCross requires node 16 or higher to run. To get node 16 on a Debian based system (including Ubuntu), run the following two commands:
curl -sL https://deb.nodesource.com/setup_16.x | sudo -E bash -
sudo apt-get install -y nodejs
Then try to run the bot again
This happens when you have not entered correct chat IDs in the settings file. See step 11 in the step by step installation guide for instructions on how to get these.
A small gotcha here is that Telegram group chats always have a negative chat ID. Remember to include the "-" in the settings file!
The Telegram team unfortunately decided that bots cannot interact with each other, fearing they would get stuck in infinite loops. This means it is impossible, under any circumstances, for TediCross to relay messages from other Telegram bots to Discord. Discord does not have this limitation, and the Discord side of the bot will happily relay messages from other Discord bots to Telegram
See https://core.telegram.org/bots/faq#why-doesn-39t-my-bot-see-messages-from-other-bots
Telegram bots are unfortunately completely unable to detect when a message is deleted. There is no way to implement T2D cross-deletion until Telegram implements this.
NOTE: A partial solution to this has been implemented. When a message on Telegram is edited to become just a single dot (.
), TediCross will delete it both on Telegram and on Discord.
Deleting messages D2T works as expected
The Discord library TediCross is using has support for audio channels and voice chat. For this, it needs some additional libraries, like node-opus, libsodium and others. TediCross does not do audio, so these warnings can safely be ignored
TediCross supports a theoretically infinite number of bridges, limited only by your hardware. Even a simple Raspberry Pi is powerful enough to run multiple bridges, so don't worry about making more
To make more bridges, just copy the one you have, paste it right below and make necessary changes:
...
bridges:
- name: Default bridge
direction: both
telegram:
...
discord:
...
- name: Another bridge
direction: both
telegram:
...
discord:
...
...
The names of the bridges are practically only log identifiers. They can be whatever string you want them to be. Note, however, that the setting discord.skipOldMessages
uses the names to know which messages was last sent from which channel, so they should be unique.
Note that the settings file is indentation sensitive. If you do for example
- name: Bridge1
direction: both
it won't work. The "d" in "direction" must be directly below the "n" in "name". See example.settings.yaml
for proper indentation
This happens when two applications use the same Telegram bot token, or someone has set a webhook on the Telegram bot token. You may simply have accidentally launched two instances of TediCross, or someone else has somehow gotten hold of your token
If you haven't accidentally launched two instances of TediCross, assume the token is compromised. First, talk to @BotFather to generate a new token for the bot. Then go to https://api.telegram.org/botTOKEN/deleteWebhook (with TOKEN
replaced with your actual token) to get rid of any webhook set for the bot. Then update the settings file, and restart the bot
Take a look in guides/autostart/ of this repo
Most updates are announced on the TediCross News channel. Only very minor ones are not
If you cloned the git repo, just do a git pull
, followed by npm install --omit=dev
.
If you downloaded TediCross as a zip, do step 2, 3 and 4 in the installation guide again. Then move settings.yaml
and the whole data/
directory from the old version to the new one and start it.
This has been tried, and it did indeed make the messages much prettier. The bot can impersonate multiple people this way. Unfortunately, messages sent through a webhook does not belong to the bot, meaning the bot cannot edit them. Cross-editing from Telegram to Discord is then lost. In addition, it requires the bot owner to have two-factor authentication activated.
No
TediCross will send a link to this documentation to every chat it is in which is not configured to bridge correctly. Please use this documentation to configure your bot for bridging and the behavior will stop.
If you need any help, join our group on Telegram or our server on Discord
Cryptocoins of the following types are accepted:
- BTC: 1Gzr9ZyvTiFCPKfy2BshuZgUeFLebAfbFU
- ETH: 0x9449D54C85C8FdB079e74379d93A9C9fe611981A
These donations go to the original creator, not the current maintainer.