/MuseHeart-MusicBot

bot de música programado em python com player interativo, suporte a multi-bot, comandos barra/slash, integração com last.fm e muito mais.

Primary LanguagePythonGNU General Public License v2.0GPL-2.0

MuseHeart-MusicBot

bot de música programado em python com player interativo, comandos de barra + slash, integração com o last.fm e muito mais.

Página com invites e algumas infos/screenshots da Muse Heart e funcionamento dessa source: clique aqui.

Algumas Previews:

Mais previews:
  • Comandos de barra / Slash commands

  • Integração com o last.fm para scrobbles (outras funcionalidades em breve).

  • Player controller: modo fixo/estendido com canal e conversa de song requests (skin: default), configurável com o comando: /setup

  • Player controller: modo fixo/estendido com canal de song-request em forum com suporte a status automático no canal de voz e palco

  • Há diversas outras skins, veja todas usando o comando /change_skin (você também pode criar outras, use os modelos padrões que estão na pasta skins como referência, crie uma cópia com outro nome e modifique a seu gosto).

Teste agora mesmo criando/reusando um bot próprio com essa source fazendo deploy em um dos serviços abaixo:


Repl.it

Link do guia com imagens: https://gist.github.com/zRitsu/70737984cbe163f890dae05a80a3ddbe


Render.com

Deploy to Render

  • [ 1 ] - No campo TOKEN_BOT_1 coloque o token do bot ( tutorial de como obter ). Nota: Caso queira, no campo TOKEN você pode incluir token de mais bots para ter bots extras pra ativar o suporte a multi-voice incluindo mais tokens no value (separando com espaços).

  • [ 2 ] - No campo DEFAULT_PREFIX coloque um prefixo para o bot.

  • [ 3 ] - Nos campos SPOTIFY_CLIENT_ID e SPOTIFY_CLIENT_SECRET coloque as suas keys do spotify ( tutorial de como obter ).

  • [ 4 ] - No campo MONGO coloque o link da sua database do MongoDB ( tutorial de como obter ).

  • [ 5 ] - Clique em Apply e aguarde o processo de build até o bot iniciar (isso pode demorar bastante, no mínimo uns 13 minutos ou mais para o deploy ser finalizado + bot iniciar + servidor lavalink iniciar).


Gitpod

Open in Gitpod

  • [ 1 ] - Abra o arquivo .env e coloque o token do bot no campo apropriado (caso não tenha, veja como obter com este tutorial tutorial de como obter). Também altamente recomendo usar mongodb, procure onde tem MONGO= no arquivo .env e nele coloque o link da sua db do mongodb (caso não tenha, veja como obter por este tutorial).

  • [ 2 ] - Clique com botão direito em cima do arquivo main.py e depois clique em: Run Python File in Terminal.

  • Nota 1: Requer verificação da conta por número de celular/mobile.

  • Nota 2: Não esqueça de ir na lista de workspaces e clicar nos 3 pontinhos do projeto e depois clicar em pin. (isso evitará o worskpace ser deletado após 14 dias inativo)

  • Nota 3: Não use o gitpod para hospedar / manter o bot online, pois a mesma tem bastante limitações no plano gratuito (mais informações nesse link).


Hospedando no seu próprio PC/VPS (windows/linux)

Requisitos:

Nota: esta source requer no mínimo 512mb de RAM E 1Ghz de CPU para rodar normalmente (caso rode o Lavalink na mesma instância do bot considerando que o bot seja privado).

Iniciar bot (guia rápido):

  • Baixe esta source como zip e extraia em seguida (Ou use o comando abaixo no terminal/cmd e abra a pasta em seguida):
git clone https://github.com/zRitsu/MuseHeart-MusicBot.git
  • dê clique-duplo no arquivo source_setup.sh (ou apenas setup caso o seu windows não esteja exibindo extensões de arquivo) e aguarde.
    Caso esteja usando linux use o comando no terminal:
bash source_setup.sh
  • Vai aparecer um arquivo com nome .env, edite ele e coloque o token do bot no campo apropriado (você também pode editar outras coisas deste mesmo arquivo caso queira fazer ajustes específicos no bot).
    Nota: Caso não tenha criado uma conta de bot, veja este tutorial para criar seu bot e obter o token necessário.
    Também altamente recomendo usar mongodb, procure onde tem MONGO= no arquivo .env e nele coloque o link da sua db do mongodb (caso não tenha, veja como obter por este tutorial).
  • Agora basta apenas abrir o arquivo source_start_win.bat para iniciar o bot se o seu sistema for windows, caso seja linux dê clique duplo no start.sh (ou se preferir execute o bot usando o comando abaixo):
bash source_start.sh

Notas:

  • Para atualizar seu bot dê um clique duplo no update.sh (windows), p/ Linux use o comando no shell/terminal:
bash source_update.sh

Ao atualizar, há chance de qualquer alteração manual feita ser perdida (caso não seja um fork desta source)...

Obs: Caso esteja rodando a source diretamente de uma máquina com windows (e que tenha git instalado) apenas dê um duplo-click no arquivo source_update.sh


Nota: há mais alguns guias na wiki.

Observações importantes:

  • Você pode usar essa source como alternativa de self-hosting do meu bot principal (Muse Heart) pra hospedar/rodar seu próprio bot de música para uso privado ou em servidores públicos no qual você gerencia (que você tenha permissão de adicionar seu próprio bot no servidor). Entretanto não recomendo distribuir o bot usando essa source publicamente por não estar otimizado o suficiente pra lidar com alta demanda de servidores, mas se mesmo assim decidir fazer isso o bot terá que estar sob a licença da source original e dependendo de onde o bot estiver sendo divulgado (ex: botlists) há possibilidade de seu bot ser apontado pelo uso dessa source.

  • Recomendo usar a source atual sem alterações no code. Caso queira fazer modificações (e principalmente adicionar novas funcionalidades) é altamente recomendável que tenha conhecimento em python, disnake, lavalink e etc. E caso queira manter sua source modificada com updates em dias usando a source base também recomendo ter conhecimento em git (pelo menos o necessário pra fazer um merge sem erros).

  • Não será fornecido suporte caso modifique a source atual (exceto para custom skins), pois atualizo ela com frequência e versões modificadas tendem a ficarem desatualizadas dificultando dar suporte por esse motivo (além de que dependendo da modificação ou implementação poder gerar erros desconhecidos que dificulta ao tentar resolver o problema e de eu exigir usar métodos pra atualizar o code que geralmente desfaz essas alterações).

  • Caso queira postar algum vídeo/tutorial usando essa source, você está totalmente livre para usá-la pra essa finalidade desde que esteja de acordo com os termos citados nos parágrafos acima.


Caso tenha algum problema, poste uma issue detalhando o problema.

Agradecimentos especiais e créditos:

  • DisnakeDev (disnake) e ao Rapptz pelo discord.py original
  • Pythonista Guild (wavelink)
  • Lavalink-Devs (lavalink e lavaplayer)
  • DarrenOfficial Lavalink serverlist (Usuários que publicaram seus servidores lavalink estão listados no comando about junto com website/link).
  • E a todos os membros que me me ajudaram bastante com reports de erros (sendo nas issues e no servidor do discord)
  • Demais atribuições podem ser conferidas no dependency graph