Skip to content

HolgerHuo/telegram-netease-bot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Telegram Netease Bot - Telegram 网易云音乐 Bot

Note: As the initial version of this bot is of low quality and is hard to extent horizontally, future development on this version may be dropped. A rewrite of this program is expected to be born some time around Jan. 2023.

The rewrite is pending.


GitHub last commitGitHub release (latest by date)GitHubGitHub all releasesGitHub code size in bytes

A python telegram bot enabling you to send Netease Cloud Music and YouTube music (extracted from videos) in chats

✨ Features

  • Ease-of-use: No need to type "/" for command
  • Extensible: Built on Python3 with pyTelegramBotAPI
  • Elastic Netease Backend: Powered by NodeJS NeteaseCloudMusicApi
  • Embed music tags automatically
  • Enhanced caching system
  • Web UI allow admins to easily update expired netease cloud music tokens

👷‍♂️ QuickStart

Add example Radio 669 by going to @radio_669_bot.

Press Start

Choose your music by sending "点歌 <song_name>"

Add r669 bot to your favorite groups, ...

Enjoy it!

💻 Deployment

Prerequisites

telegram-netease-bot requires Python3.7+, which means you'll have to compile Python3.7 yourself if you are on CentOS 7

  • A working NodeJS NeteaseCloudMusicAPI (Can be deployed on Vercel)
  • Python 3.7+ and pip3
  • Bot token obtained from BotFather
  • Obtain your NCM UserID
  • If you want to use the webui for updating tokens on the fly, a reverse proxy can be set up

How-to: Obtain NCM UserID

  1. Login to your NodeJS NCMApi using the methods in the documentation (It is recommended to login using SMS code)
  2. Use your browser to inspect cookies and find the value of MUSIC_U
  3. That's it!

or a much easier way:

  1. open the web ui (by default: http://localhost:5000)
  2. scan the qr code with NCM app

Install

git clone https://github.com/HolgerHuo/telegram-netease-bot.git r669
cd r669
pip3 install -r requirements.txt
python3 run.py

A sample systemd service is shipped at r669.service. Add it to your system if you like.

Don't forget to change your bot's name, avatar, and about info and enjoy it!

To use the webui, you also need to start the uwsgi server as shown in systemd file.

To securely access the web ui, you need to setup firewall rules and reverse proxy.

💖 Credits

📜 License

GNU General Public License v3.0

©️ Holger Huo

@[email protected]