mirror of
https://github.com/HappyTanuki/BumbleCee.git
synced 2025-10-26 01:45:15 +00:00
데이터베이스 연결 추가됨
This commit is contained in:
49
Temp/CurMusic
Normal file
49
Temp/CurMusic
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
W8UNLOOogU4
|
||||||
|
749DIRUHhNY
|
||||||
|
o75PUTiHEXU
|
||||||
|
pS5d77DQHOI
|
||||||
|
65xX7zyr-fA
|
||||||
|
2eNEQ0cQtkI
|
||||||
|
UgS7vgquBvo
|
||||||
|
IFCDLIKSArs
|
||||||
|
yPdqcADl5U4
|
||||||
|
6aEglYFwjrA
|
||||||
|
n8F-E5f-cos
|
||||||
|
1zwaZkOXXqw
|
||||||
|
vjSrFwbwu6w
|
||||||
|
vwZAqxL8rgs
|
||||||
|
zOkIe3RcTCs
|
||||||
|
mzVbYUBo8_Y
|
||||||
|
rgNdeflYdYw
|
||||||
|
CjaM8qWzssk
|
||||||
|
kNDbaYEp0tU
|
||||||
|
smObR_8q5UQ
|
||||||
|
27NtZwyog7g
|
||||||
|
vHfAjfKVMew
|
||||||
|
b_bjtIeqIR4
|
||||||
|
YTaX7BWlk9g
|
||||||
|
BBj3SCImk_A
|
||||||
|
Yb_IhN4TGp8
|
||||||
|
-m-crWZHLi0
|
||||||
|
4ciZKNHSoUs
|
||||||
|
4tlUwgtgdZA
|
||||||
|
oPGtAA2HaS8
|
||||||
|
dLlD-dZNACM
|
||||||
|
9LW9DpmhrPE
|
||||||
|
pMTRBNMX2mw
|
||||||
|
Kt451YtL-Vs
|
||||||
|
tc0FL9JROGQ
|
||||||
|
NinLIDs9qmU
|
||||||
|
KMdTrqzEI0I
|
||||||
|
HbXaUmWaU5Q
|
||||||
|
xtFAmapbTbY
|
||||||
|
B7luArOaIl0
|
||||||
|
HMqhXxH5-RQ
|
||||||
|
mQFokUq9LYs
|
||||||
|
HyL8Z94W6es
|
||||||
|
prAnOH-q_Bo
|
||||||
|
LRPGqNeav_M
|
||||||
|
M4-XU0a2hf0
|
||||||
|
BryspbM6s3E
|
||||||
|
JVTS3fyoAEQ
|
||||||
|
KAaUyVJoNAE
|
||||||
@@ -49,6 +49,12 @@ BumbleCeepp::BumbleCeepp(std::string token, std::string DBURL, std::string DBID,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
<<<<<<< HEAD
|
||||||
|
if (!memberCount)
|
||||||
|
{
|
||||||
|
auto joinedShard = marker.from;
|
||||||
|
marker.voice_client->log(dpp::loglevel::ll_info, "voicechat is empty.");
|
||||||
|
=======
|
||||||
marker.voice_client->log(dpp::loglevel::ll_debug, "Playing " + marker.track_meta + "on channel id " + marker.voice_client->channel_id.str() + ".");
|
marker.voice_client->log(dpp::loglevel::ll_debug, "Playing " + marker.track_meta + "on channel id " + marker.voice_client->channel_id.str() + ".");
|
||||||
|
|
||||||
int remainingSongsCount = marker.voice_client->get_tracks_remaining();
|
int remainingSongsCount = marker.voice_client->get_tracks_remaining();
|
||||||
@@ -66,15 +72,33 @@ BumbleCeepp::BumbleCeepp(std::string token, std::string DBURL, std::string DBID,
|
|||||||
enqueueMusic({nowPlayingMusic, *embed}, marker.voice_client);
|
enqueueMusic({nowPlayingMusic, *embed}, marker.voice_client);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
>>>>>>> 68b6105ac3ddf1c27f40e0e552780171352e734d
|
||||||
marker.voice_client->stop_audio();
|
marker.voice_client->stop_audio();
|
||||||
joinedShard->disconnect_voice(marker.voice_client->server_id);
|
joinedShard->disconnect_voice(marker.voice_client->server_id);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
<<<<<<< HEAD
|
||||||
|
|
||||||
|
marker.voice_client->log(dpp::loglevel::ll_debug, "Playing " + marker.track_meta + "on channel id " + marker.voice_client->channel_id.str() + ".");
|
||||||
|
|
||||||
|
int remainingSongsCount = marker.voice_client->get_tracks_remaining();
|
||||||
|
marker.voice_client->log(dpp::loglevel::ll_info, "Marker count : " + remainingSongsCount);
|
||||||
|
|
||||||
|
if (remainingSongsCount <= 1 && !marker.voice_client->is_playing())
|
||||||
|
{
|
||||||
|
auto joinedShard = marker.from;
|
||||||
|
marker.voice_client->log(dpp::loglevel::ll_info, "Queue ended");
|
||||||
|
if (!joinedShard)
|
||||||
|
return;
|
||||||
|
marker.voice_client->stop_audio();
|
||||||
|
joinedShard->disconnect_voice(marker.voice_client->server_id);
|
||||||
|
=======
|
||||||
if (repeat) {
|
if (repeat) {
|
||||||
if (!embed) {
|
if (!embed) {
|
||||||
botCluster->log(dpp::loglevel::ll_error, std::string("알 수 없는 오류 발생!"));
|
botCluster->log(dpp::loglevel::ll_error, std::string("알 수 없는 오류 발생!"));
|
||||||
|
>>>>>>> 68b6105ac3ddf1c27f40e0e552780171352e734d
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ void commands::Delete::operator()(const dpp::slashcommand_t& event)
|
|||||||
int remainingSongsCount = vc->get_tracks_remaining() - 1;
|
int remainingSongsCount = vc->get_tracks_remaining() - 1;
|
||||||
std::vector<std::string> queuedSongs = vc->get_marker_metadata();
|
std::vector<std::string> queuedSongs = vc->get_marker_metadata();
|
||||||
|
|
||||||
vc->log(dpp::loglevel::ll_trace, "Queue size : " + remainingSongsCount);
|
vc->log(dpp::loglevel::ll_info, "Queue size : " + remainingSongsCount);
|
||||||
|
|
||||||
if (index < 0 || remainingSongsCount+1 < index || (!vc->is_playing() && index == 0)) {
|
if (index < 0 || remainingSongsCount+1 < index || (!vc->is_playing() && index == 0)) {
|
||||||
std::cout << "invalid index : " << index << ", " + Pos + "\n";
|
std::cout << "invalid index : " << index << ", " + Pos + "\n";
|
||||||
|
|||||||
@@ -4,6 +4,7 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
#include <filesystem>
|
#include <filesystem>
|
||||||
#include <ctime>
|
#include <ctime>
|
||||||
|
#include <thread>
|
||||||
|
|
||||||
using json = nlohmann::json;
|
using json = nlohmann::json;
|
||||||
|
|
||||||
@@ -34,6 +35,14 @@ commands::Play::Play(dpp::snowflake botID, BumbleCeepp* Bot)
|
|||||||
commandObjectVector.push_back(command);
|
commandObjectVector.push_back(command);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
<<<<<<< HEAD
|
||||||
|
static void _Internal_Enqueue_Func(const dpp::slashcommand_t& event, BumbleCeepp* Bot){
|
||||||
|
std::string Query = std::get<std::string>(event.get_parameter("query"));
|
||||||
|
|
||||||
|
event.from->log(dpp::loglevel::ll_info, "음악 다운로드 시작");
|
||||||
|
std::system(("python3 yt-download.py \"" + Query + "\" & wait").c_str());
|
||||||
|
event.from->log(dpp::loglevel::ll_info, "음악 다운로드 완료");
|
||||||
|
=======
|
||||||
void commands::Play::operator()(const dpp::slashcommand_t& event)
|
void commands::Play::operator()(const dpp::slashcommand_t& event)
|
||||||
{
|
{
|
||||||
if (std::holds_alternative<std::monostate>(event.get_parameter("query")))
|
if (std::holds_alternative<std::monostate>(event.get_parameter("query")))
|
||||||
@@ -59,14 +68,35 @@ void commands::Play::operator()(const dpp::slashcommand_t& event)
|
|||||||
event.thinking();
|
event.thinking();
|
||||||
|
|
||||||
event.from->log(dpp::loglevel::ll_debug, "음악 ID 쿼리: " + Query);
|
event.from->log(dpp::loglevel::ll_debug, "음악 ID 쿼리: " + Query);
|
||||||
|
>>>>>>> 68b6105ac3ddf1c27f40e0e552780171352e734d
|
||||||
|
|
||||||
std::string musicIDs = getResultFromCommand(("python3 youtube-search.py \"" + Query + "\" & wait").c_str());
|
std::string musicIDs = getResultFromCommand(("python3 youtube-search.py \"" + Query + "\" & wait").c_str());
|
||||||
|
|
||||||
if (!musicIDs.length())
|
if (!musicIDs.length())
|
||||||
{
|
{
|
||||||
|
<<<<<<< HEAD
|
||||||
|
event.from->log(dpp::loglevel::ll_info, "Red ID : " + ID);
|
||||||
|
infofile.open("Music/" + ID + ".info.json");
|
||||||
|
infofile >> document;
|
||||||
|
infofile.close();
|
||||||
|
|
||||||
|
FQueueElement Data = {
|
||||||
|
ID,
|
||||||
|
Bot->makeEmbed(
|
||||||
|
document["webpage_url"],
|
||||||
|
document["title"],
|
||||||
|
document["uploader"],
|
||||||
|
document["id"],
|
||||||
|
document["thumbnail"],
|
||||||
|
int(document["duration"]))
|
||||||
|
};
|
||||||
|
|
||||||
|
RequestedMusic.push(Data);
|
||||||
|
=======
|
||||||
event.from->log(dpp::loglevel::ll_debug, "유튜브 검색 결과 없음");
|
event.from->log(dpp::loglevel::ll_debug, "유튜브 검색 결과 없음");
|
||||||
event.edit_response("검색 결과가 없습니다.");
|
event.edit_response("검색 결과가 없습니다.");
|
||||||
return;
|
return;
|
||||||
|
>>>>>>> 68b6105ac3ddf1c27f40e0e552780171352e734d
|
||||||
}
|
}
|
||||||
|
|
||||||
std::stringstream sstream(musicIDs);
|
std::stringstream sstream(musicIDs);
|
||||||
@@ -81,6 +111,15 @@ void commands::Play::operator()(const dpp::slashcommand_t& event)
|
|||||||
event.from->log(dpp::loglevel::ll_debug, "다운로드 시작");
|
event.from->log(dpp::loglevel::ll_debug, "다운로드 시작");
|
||||||
std::system(("python3 yt-download.py \"" + musicID + "\" & wait").c_str());
|
std::system(("python3 yt-download.py \"" + musicID + "\" & wait").c_str());
|
||||||
|
|
||||||
|
<<<<<<< HEAD
|
||||||
|
if (v && v->voiceclient && v->voiceclient->is_ready())
|
||||||
|
{
|
||||||
|
auto _copiedQueue = RequestedMusic;
|
||||||
|
while (!_copiedQueue.empty())
|
||||||
|
{
|
||||||
|
Bot->enqueueMusic(_copiedQueue.front(), v->voiceclient);
|
||||||
|
_copiedQueue.pop();
|
||||||
|
=======
|
||||||
event.from->log(dpp::loglevel::ll_debug, "musicID: " + musicID);
|
event.from->log(dpp::loglevel::ll_debug, "musicID: " + musicID);
|
||||||
std::ifstream infofile;
|
std::ifstream infofile;
|
||||||
infofile.open((std::string("Music/") + musicID + ".info.json").c_str());
|
infofile.open((std::string("Music/") + musicID + ".info.json").c_str());
|
||||||
@@ -102,6 +141,7 @@ void commands::Play::operator()(const dpp::slashcommand_t& event)
|
|||||||
else {
|
else {
|
||||||
event.from->log(dpp::loglevel::ll_debug, "DB쿼리 완료");
|
event.from->log(dpp::loglevel::ll_debug, "DB쿼리 완료");
|
||||||
on_DLCompleted(musicID, *embed, event);
|
on_DLCompleted(musicID, *embed, event);
|
||||||
|
>>>>>>> 68b6105ac3ddf1c27f40e0e552780171352e734d
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
@@ -135,6 +175,29 @@ void commands::Play::on_DLCompleted(std::string musicID, dpp::embed embed, const
|
|||||||
|
|
||||||
event.from->creator->message_create(followMsg);
|
event.from->creator->message_create(followMsg);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void commands::Play::operator()(const dpp::slashcommand_t& event)
|
||||||
|
{
|
||||||
|
if (std::holds_alternative<std::monostate>(event.get_parameter("query")))
|
||||||
|
{
|
||||||
|
event.reply("노래를 재생하려면 검색어 또는 링크를 입력해 주십시오.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Attempt to connect to a voice channel, returns false if we fail to connect. */
|
||||||
|
if (!event.from->get_voice(event.command.guild_id))
|
||||||
|
{
|
||||||
|
if (!dpp::find_guild(event.command.guild_id)->connect_member_voice(event.command.get_issuing_user().id))
|
||||||
|
{
|
||||||
|
return event.reply("노래를 재생할 음성 채팅방에 먼저 참가하고 신청해야 합니다!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
event.thinking();
|
||||||
|
|
||||||
|
std::thread t1(_Internal_Enqueue_Func, event, Bot);
|
||||||
|
t1.detach();
|
||||||
|
|
||||||
auto voiceconn = event.from->get_voice(event.command.guild_id);
|
auto voiceconn = event.from->get_voice(event.command.guild_id);
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user