mirror of
https://github.com/Syping/dtranslatebot.git
synced 2026-04-01 05:20:22 +02:00
add direct message support
This commit is contained in:
parent
7588ca865b
commit
77621a8991
15 changed files with 115 additions and 40 deletions
7
.github/workflows/container.yml
vendored
7
.github/workflows/container.yml
vendored
|
|
@ -19,6 +19,13 @@ jobs:
|
||||||
uses: docker/metadata-action@v6
|
uses: docker/metadata-action@v6
|
||||||
with:
|
with:
|
||||||
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
|
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
|
||||||
|
tags: |
|
||||||
|
type=ref,event=branch
|
||||||
|
type=ref,event=tag
|
||||||
|
type=semver,pattern={{version}}
|
||||||
|
type=semver,pattern={{major}}.{{minor}}
|
||||||
|
type=semver,pattern={{major}}
|
||||||
|
type=raw,value=latest,enable=${{ github.ref_name == 'master' }}
|
||||||
- name: Build and push Container
|
- name: Build and push Container
|
||||||
id: push
|
id: push
|
||||||
uses: docker/build-push-action@v7
|
uses: docker/build-push-action@v7
|
||||||
|
|
|
||||||
|
|
@ -17,6 +17,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
#include "http_request.h"
|
#include "http_request.h"
|
||||||
|
using namespace std::string_literals;
|
||||||
|
|
||||||
http_request::http_request() {
|
http_request::http_request() {
|
||||||
instance = curl_easy_init();
|
instance = curl_easy_init();
|
||||||
|
|
@ -55,7 +56,7 @@ const http_response http_request::post(const std::string &url, const std::string
|
||||||
curl_easy_setopt(instance, CURLOPT_URL, url.c_str());
|
curl_easy_setopt(instance, CURLOPT_URL, url.c_str());
|
||||||
curl_slist *header_slist = nullptr;
|
curl_slist *header_slist = nullptr;
|
||||||
if (!content_type.empty()) {
|
if (!content_type.empty()) {
|
||||||
curl_slist *new_header_slist = curl_slist_append(header_slist, std::string("Content-Type: " + content_type).c_str());
|
curl_slist *new_header_slist = curl_slist_append(header_slist, std::string("Content-Type: "s + content_type).c_str());
|
||||||
if (!new_header_slist) {
|
if (!new_header_slist) {
|
||||||
curl_slist_free_all(header_slist);
|
curl_slist_free_all(header_slist);
|
||||||
throw std::bad_alloc();
|
throw std::bad_alloc();
|
||||||
|
|
@ -87,7 +88,7 @@ const http_response http_request::post(const std::string &url, const std::string
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string http_request::legacy_url(const std::string &hostname, uint16_t port, const std::string &url, bool tls) {
|
std::string http_request::legacy_url(const std::string &hostname, uint16_t port, const std::string &url, bool tls) {
|
||||||
return (tls ? "https://" : "http://") + hostname + ":" + std::to_string(port) + (url.empty() ? "/" : (url.front() != '/' ? "/" + url : url));
|
return (tls ? "https://"s : "http://"s) + hostname + ":"s + std::to_string(port) + (url.empty() ? "/"s : (url.front() != '/' ? "/"s + url : url));
|
||||||
}
|
}
|
||||||
|
|
||||||
http_request::~http_request() {
|
http_request::~http_request() {
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
* dtranslatebot Discord Translate Bot
|
* dtranslatebot Discord Translate Bot
|
||||||
* Copyright (C) 2023-2024 Syping
|
* Copyright (C) 2023-2026 Syping
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without modification,
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
* are permitted provided that the following conditions are met:
|
* are permitted provided that the following conditions are met:
|
||||||
|
|
@ -77,7 +77,8 @@ int main(int argc, char* argv[]) {
|
||||||
bot::message_queue message_queue;
|
bot::message_queue message_queue;
|
||||||
std::thread message_queue_loop(&bot::message_queue::run, &message_queue, &settings, &submit_queue);
|
std::thread message_queue_loop(&bot::message_queue::run, &message_queue, &settings, &submit_queue);
|
||||||
|
|
||||||
bot.on_message_create(std::bind(&bot::message_queue::process_message_event, &message_queue, &bot, &settings, std::placeholders::_1));
|
bot.on_message_context_menu(std::bind(&bot::slashcommands::process_message_menu_event, &message_queue, &bot, &settings, std::placeholders::_1));
|
||||||
|
bot.on_message_create(std::bind(&bot::message_queue::process_guild_message_event, &message_queue, &bot, &settings, std::placeholders::_1));
|
||||||
bot.on_slashcommand(std::bind(&bot::slashcommands::process_command_event, &bot, &settings, std::placeholders::_1));
|
bot.on_slashcommand(std::bind(&bot::slashcommands::process_command_event, &bot, &settings, std::placeholders::_1));
|
||||||
bot.on_ready([&bot, &settings]([[maybe_unused]] const dpp::ready_t &event) {
|
bot.on_ready([&bot, &settings]([[maybe_unused]] const dpp::ready_t &event) {
|
||||||
if (dpp::run_once<struct register_bot_commands>()) {
|
if (dpp::run_once<struct register_bot_commands>()) {
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
* dtranslatebot Discord Translate Bot
|
* dtranslatebot Discord Translate Bot
|
||||||
* Copyright (C) 2023-2024 Syping
|
* Copyright (C) 2023-2026 Syping
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without modification,
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
* are permitted provided that the following conditions are met:
|
* are permitted provided that the following conditions are met:
|
||||||
|
|
@ -21,6 +21,7 @@
|
||||||
#include "settings.h"
|
#include "settings.h"
|
||||||
using bot::message_queue;
|
using bot::message_queue;
|
||||||
using namespace std::chrono_literals;
|
using namespace std::chrono_literals;
|
||||||
|
using namespace std::string_literals;
|
||||||
|
|
||||||
void message_queue::add(const message &message)
|
void message_queue::add(const message &message)
|
||||||
{
|
{
|
||||||
|
|
@ -34,7 +35,30 @@ void message_queue::add(message &&message)
|
||||||
m_queue.push(message);
|
m_queue.push(message);
|
||||||
}
|
}
|
||||||
|
|
||||||
void message_queue::process_message_event(dpp::cluster *bot, bot::settings::settings *settings, const dpp::message_create_t &event)
|
void message_queue::process_direct_message_event(dpp::cluster *bot, bot::settings::settings *settings, const dpp::message_context_menu_t &event)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
// We check for conditions we want to skip translation for
|
||||||
|
if (event.ctx_message.author.id == bot->me.id || event.ctx_message.content.empty()) {
|
||||||
|
event.reply(dpp::message("Invalid message").set_flags(dpp::m_ephemeral));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
event.thinking(false);
|
||||||
|
|
||||||
|
bot::direct_message direct_message;
|
||||||
|
direct_message.event = event;
|
||||||
|
direct_message.message = event.ctx_message.content;
|
||||||
|
|
||||||
|
add(std::move(direct_message));
|
||||||
|
}
|
||||||
|
catch (const std::exception &exception) {
|
||||||
|
std::cerr << "[Exception] " << exception.what() << std::endl;
|
||||||
|
event.reply(dpp::message("Exception while processing command:\n"s + exception.what()).set_flags(dpp::m_ephemeral));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void message_queue::process_guild_message_event(dpp::cluster *bot, bot::settings::settings *settings, const dpp::message_create_t &event)
|
||||||
{
|
{
|
||||||
// We check for conditions we want to skip translation for
|
// We check for conditions we want to skip translation for
|
||||||
if (event.msg.author.id == bot->me.id || event.msg.content.empty() || event.msg.has_thread())
|
if (event.msg.author.id == bot->me.id || event.msg.content.empty() || event.msg.has_thread())
|
||||||
|
|
@ -50,7 +74,7 @@ void message_queue::process_message_event(dpp::cluster *bot, bot::settings::sett
|
||||||
|
|
||||||
const std::lock_guard<bot::settings::settings> guard(*settings);
|
const std::lock_guard<bot::settings::settings> guard(*settings);
|
||||||
if (const bot::settings::channel *channel = settings->get_channel(event.msg.guild_id, event.msg.channel_id)) {
|
if (const bot::settings::channel *channel = settings->get_channel(event.msg.guild_id, event.msg.channel_id)) {
|
||||||
bot::message message;
|
bot::guild_message message;
|
||||||
message.id = event.msg.id;
|
message.id = event.msg.id;
|
||||||
|
|
||||||
message.author = event.msg.member.get_nickname();
|
message.author = event.msg.member.get_nickname();
|
||||||
|
|
@ -81,13 +105,21 @@ void message_queue::run(bot::settings::settings *settings, submit_queue *submit_
|
||||||
|
|
||||||
auto translator = settings->get_translator();
|
auto translator = settings->get_translator();
|
||||||
|
|
||||||
for (auto target = message.targets.begin(); target != message.targets.end(); target++) {
|
if (const auto *direct_message = std::get_if<bot::direct_message>(&message)) {
|
||||||
translated_message tr_message;
|
translated_direct_message translated_message;
|
||||||
tr_message.author = message.author;
|
translated_message.event = direct_message->event;
|
||||||
tr_message.avatar = message.avatar;
|
translated_message.message = translator->translate(direct_message->message, {}, "en");
|
||||||
tr_message.message = translator->translate(message.message, message.source, target->target);
|
submit_queue->add(std::move(translated_message));
|
||||||
tr_message.webhook = target->webhook;
|
}
|
||||||
submit_queue->add(std::move(tr_message));
|
else if (const auto *guild_message = std::get_if<bot::guild_message>(&message)) {
|
||||||
|
for (auto target = guild_message->targets.begin(); target != guild_message->targets.end(); target++) {
|
||||||
|
translated_guild_message translated_message;
|
||||||
|
translated_message.author = guild_message->author;
|
||||||
|
translated_message.avatar = guild_message->avatar;
|
||||||
|
translated_message.message = translator->translate(guild_message->message, guild_message->source, target->target);
|
||||||
|
translated_message.webhook = target->webhook;
|
||||||
|
submit_queue->add(std::move(translated_message));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::this_thread::yield();
|
std::this_thread::yield();
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
* dtranslatebot Discord Translate Bot
|
* dtranslatebot Discord Translate Bot
|
||||||
* Copyright (C) 2023-2024 Syping
|
* Copyright (C) 2023-2026 Syping
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without modification,
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
* are permitted provided that the following conditions are met:
|
* are permitted provided that the following conditions are met:
|
||||||
|
|
@ -22,12 +22,18 @@
|
||||||
#include <mutex>
|
#include <mutex>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <queue>
|
#include <queue>
|
||||||
|
#include <variant>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include "settings.h"
|
#include "settings.h"
|
||||||
#include "submit_queue.h"
|
#include "submit_queue.h"
|
||||||
|
|
||||||
namespace bot {
|
namespace bot {
|
||||||
struct message {
|
struct direct_message {
|
||||||
|
dpp::message_context_menu_t event;
|
||||||
|
std::string message;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct guild_message {
|
||||||
uint64_t id;
|
uint64_t id;
|
||||||
std::string author;
|
std::string author;
|
||||||
std::string avatar;
|
std::string avatar;
|
||||||
|
|
@ -36,11 +42,14 @@ namespace bot {
|
||||||
std::vector<bot::settings::target> targets;
|
std::vector<bot::settings::target> targets;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
typedef std::variant<direct_message, guild_message> message;
|
||||||
|
|
||||||
class message_queue {
|
class message_queue {
|
||||||
public:
|
public:
|
||||||
void add(const message &message);
|
void add(const message &message);
|
||||||
void add(message &&message);
|
void add(message &&message);
|
||||||
void process_message_event(dpp::cluster *bot, bot::settings::settings *settings, const dpp::message_create_t &event);
|
void process_direct_message_event(dpp::cluster *bot, bot::settings::settings *settings, const dpp::message_context_menu_t &event);
|
||||||
|
void process_guild_message_event(dpp::cluster *bot, bot::settings::settings *settings, const dpp::message_create_t &event);
|
||||||
void run(bot::settings::settings *settings, submit_queue *submit_queue);
|
void run(bot::settings::settings *settings, submit_queue *submit_queue);
|
||||||
void terminate();
|
void terminate();
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
* dtranslatebot Discord Translate Bot
|
* dtranslatebot Discord Translate Bot
|
||||||
* Copyright (C) 2024 Syping
|
* Copyright (C) 2024-2026 Syping
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without modification,
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
* are permitted provided that the following conditions are met:
|
* are permitted provided that the following conditions are met:
|
||||||
|
|
@ -27,10 +27,16 @@ void slashcommands::process_command_event(dpp::cluster *bot, bot::settings::sett
|
||||||
slashcommands::process_edit_command(bot, settings, event);
|
slashcommands::process_edit_command(bot, settings, event);
|
||||||
else if (event.command.get_command_name() == "list")
|
else if (event.command.get_command_name() == "list")
|
||||||
slashcommands::process_list_command(bot, settings, event);
|
slashcommands::process_list_command(bot, settings, event);
|
||||||
else if (event.command.get_command_name() == "translate" || event.command.get_command_name() == "translate_pref")
|
else if (event.command.get_command_name() == "translate" || event.command.get_command_name() == "translate pref")
|
||||||
slashcommands::process_translate_command(bot, settings, event);
|
slashcommands::process_translate_command(bot, settings, event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void slashcommands::process_message_menu_event(bot::message_queue *message_queue, dpp::cluster *bot, bot::settings::settings *settings, const dpp::message_context_menu_t &event)
|
||||||
|
{
|
||||||
|
if (event.command.get_command_name() == "translate message")
|
||||||
|
message_queue->process_direct_message_event(bot, settings, event);
|
||||||
|
}
|
||||||
|
|
||||||
void slashcommands::process_edit_command(dpp::cluster *bot, bot::settings::settings *settings, const dpp::slashcommand_t &event)
|
void slashcommands::process_edit_command(dpp::cluster *bot, bot::settings::settings *settings, const dpp::slashcommand_t &event)
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
|
|
@ -475,7 +481,7 @@ void slashcommands::register_commands(dpp::cluster *bot, bot::settings::settings
|
||||||
commands.push_back(command_translate);
|
commands.push_back(command_translate);
|
||||||
|
|
||||||
if (preferred_languages.size() > 1) {
|
if (preferred_languages.size() > 1) {
|
||||||
dpp::slashcommand command_translate_pref("translate_pref", "Translate current channel (Preferred languages)", bot->me.id);
|
dpp::slashcommand command_translate_pref("translate pref", "Translate current channel (Preferred languages)", bot->me.id);
|
||||||
command_translate_pref.set_default_permissions(dpp::p_manage_webhooks);
|
command_translate_pref.set_default_permissions(dpp::p_manage_webhooks);
|
||||||
dpp::command_option channel_pref_subcommand(dpp::co_sub_command, "channel", "Translate current channel to a channel (Preferred languages)");
|
dpp::command_option channel_pref_subcommand(dpp::co_sub_command, "channel", "Translate current channel to a channel (Preferred languages)");
|
||||||
dpp::command_option webhook_pref_subcommand(dpp::co_sub_command, "webhook", "Translate current channel to a webhook (Preferred languages)");
|
dpp::command_option webhook_pref_subcommand(dpp::co_sub_command, "webhook", "Translate current channel to a webhook (Preferred languages)");
|
||||||
|
|
@ -498,5 +504,9 @@ void slashcommands::register_commands(dpp::cluster *bot, bot::settings::settings
|
||||||
commands.push_back(command_translate_pref);
|
commands.push_back(command_translate_pref);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dpp::slashcommand command_translate_message("translate message", dpp::ctxm_message, bot->me.id);
|
||||||
|
command_translate_message.set_dm_permission(true);
|
||||||
|
commands.push_back(command_translate_message);
|
||||||
|
|
||||||
bot->global_bulk_command_create(commands);
|
bot->global_bulk_command_create(commands);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
* dtranslatebot Discord Translate Bot
|
* dtranslatebot Discord Translate Bot
|
||||||
* Copyright (C) 2024 Syping
|
* Copyright (C) 2024-2026 Syping
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without modification,
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
* are permitted provided that the following conditions are met:
|
* are permitted provided that the following conditions are met:
|
||||||
|
|
@ -20,6 +20,7 @@
|
||||||
#define SLASHCOMMANDS_H
|
#define SLASHCOMMANDS_H
|
||||||
|
|
||||||
#include <dpp/cluster.h>
|
#include <dpp/cluster.h>
|
||||||
|
#include "message_queue.h"
|
||||||
#include "settings.h"
|
#include "settings.h"
|
||||||
|
|
||||||
namespace bot {
|
namespace bot {
|
||||||
|
|
@ -27,6 +28,7 @@ namespace bot {
|
||||||
public:
|
public:
|
||||||
slashcommands() = delete;
|
slashcommands() = delete;
|
||||||
static void process_command_event(dpp::cluster *bot, bot::settings::settings *settings, const dpp::slashcommand_t &event);
|
static void process_command_event(dpp::cluster *bot, bot::settings::settings *settings, const dpp::slashcommand_t &event);
|
||||||
|
static void process_message_menu_event(bot::message_queue *message_queue, dpp::cluster *bot, bot::settings::settings *settings, const dpp::message_context_menu_t &event);
|
||||||
static void register_commands(dpp::cluster *bot, bot::settings::settings *settings);
|
static void register_commands(dpp::cluster *bot, bot::settings::settings *settings);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
* dtranslatebot Discord Translate Bot
|
* dtranslatebot Discord Translate Bot
|
||||||
* Copyright (C) 2024 Syping
|
* Copyright (C) 2024-2026 Syping
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without modification,
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
* are permitted provided that the following conditions are met:
|
* are permitted provided that the following conditions are met:
|
||||||
|
|
@ -44,7 +44,12 @@ void submit_queue::run(dpp::cluster *bot)
|
||||||
m_queue.pop();
|
m_queue.pop();
|
||||||
m_mutex.unlock();
|
m_mutex.unlock();
|
||||||
|
|
||||||
webhook_push::run(message, bot);
|
if (const auto *direct_message = std::get_if<bot::translated_direct_message>(&message)) {
|
||||||
|
direct_message->event.edit_original_response(dpp::message(direct_message->message));
|
||||||
|
}
|
||||||
|
else if (const auto *guild_message = std::get_if<bot::translated_guild_message>(&message)) {
|
||||||
|
webhook_push::run(*guild_message, bot);
|
||||||
|
}
|
||||||
|
|
||||||
std::this_thread::yield();
|
std::this_thread::yield();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
* dtranslatebot Discord Translate Bot
|
* dtranslatebot Discord Translate Bot
|
||||||
* Copyright (C) 2024 Syping
|
* Copyright (C) 2024-2026 Syping
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without modification,
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
* are permitted provided that the following conditions are met:
|
* are permitted provided that the following conditions are met:
|
||||||
|
|
@ -25,13 +25,20 @@
|
||||||
#include <queue>
|
#include <queue>
|
||||||
|
|
||||||
namespace bot {
|
namespace bot {
|
||||||
struct translated_message {
|
struct translated_direct_message {
|
||||||
|
dpp::message_context_menu_t event;
|
||||||
|
std::string message;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct translated_guild_message {
|
||||||
std::string author;
|
std::string author;
|
||||||
std::string avatar;
|
std::string avatar;
|
||||||
std::string message;
|
std::string message;
|
||||||
dpp::webhook webhook;
|
dpp::webhook webhook;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
typedef std::variant<translated_direct_message, translated_guild_message> translated_message;
|
||||||
|
|
||||||
class submit_queue {
|
class submit_queue {
|
||||||
public:
|
public:
|
||||||
void add(const translated_message &message);
|
void add(const translated_message &message);
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
* dtranslatebot Discord Translate Bot
|
* dtranslatebot Discord Translate Bot
|
||||||
* Copyright (C) 2024 Syping
|
* Copyright (C) 2024-2026 Syping
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without modification,
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
* are permitted provided that the following conditions are met:
|
* are permitted provided that the following conditions are met:
|
||||||
|
|
@ -22,7 +22,7 @@
|
||||||
using namespace std::string_literals;
|
using namespace std::string_literals;
|
||||||
using namespace std::string_view_literals;
|
using namespace std::string_view_literals;
|
||||||
|
|
||||||
void bot::webhook_push::run(const bot::translated_message &message, dpp::cluster *bot)
|
void bot::webhook_push::run(const bot::translated_guild_message &message, dpp::cluster *bot)
|
||||||
{
|
{
|
||||||
dpp::json json_body = {
|
dpp::json json_body = {
|
||||||
{"username"s, message.author}
|
{"username"s, message.author}
|
||||||
|
|
|
||||||
|
|
@ -27,7 +27,7 @@ namespace bot {
|
||||||
class webhook_push {
|
class webhook_push {
|
||||||
public:
|
public:
|
||||||
webhook_push() = delete;
|
webhook_push() = delete;
|
||||||
static void run(const bot::translated_message &message, dpp::cluster *bot);
|
static void run(const bot::translated_guild_message &message, dpp::cluster *bot);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static void push_request(dpp::snowflake webhook_id, const std::string &webhook_token, const std::string &json, dpp::cluster *bot);
|
static void push_request(dpp::snowflake webhook_id, const std::string &webhook_token, const std::string &json, dpp::cluster *bot);
|
||||||
|
|
|
||||||
|
|
@ -44,7 +44,7 @@ const std::vector<language> deepl::get_languages()
|
||||||
|
|
||||||
try {
|
try {
|
||||||
http_request request;
|
http_request request;
|
||||||
http_response response = request.get(http_request::legacy_url(m_hostname, 443, "/v2/languages?type=target", true), { {"Authorization"s, "DeepL-Auth-Key " + m_apiKey} });
|
http_response response = request.get(http_request::legacy_url(m_hostname, 443, "/v2/languages?type=target"s, true), { {"Authorization"s, "DeepL-Auth-Key "s + m_apiKey} });
|
||||||
if (response.status == 200) {
|
if (response.status == 200) {
|
||||||
const dpp::json json_response = dpp::json::parse(response.content);
|
const dpp::json json_response = dpp::json::parse(response.content);
|
||||||
if (json_response.is_array()) {
|
if (json_response.is_array()) {
|
||||||
|
|
@ -90,9 +90,10 @@ const std::string deepl::translate(const std::string &text, const std::string &s
|
||||||
|
|
||||||
dpp::json json_body = {
|
dpp::json json_body = {
|
||||||
{"text"s, { text } },
|
{"text"s, { text } },
|
||||||
{"source_lang"s, source},
|
{"target_lang"s, target}
|
||||||
{"target_lang"s, target},
|
|
||||||
};
|
};
|
||||||
|
if (!source.empty())
|
||||||
|
json_body["source_lang"] = source;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
http_request request;
|
http_request request;
|
||||||
|
|
|
||||||
|
|
@ -44,7 +44,7 @@ const std::vector<language> libretranslate::get_languages()
|
||||||
|
|
||||||
try {
|
try {
|
||||||
http_request request;
|
http_request request;
|
||||||
http_response response = request.get(http_request::legacy_url(m_hostname, m_port, m_url + "languages", m_tls));
|
http_response response = request.get(http_request::legacy_url(m_hostname, m_port, m_url + "languages"s, m_tls));
|
||||||
if (response.status == 200) {
|
if (response.status == 200) {
|
||||||
const dpp::json json_response = dpp::json::parse(response.content);
|
const dpp::json json_response = dpp::json::parse(response.content);
|
||||||
if (json_response.is_array()) {
|
if (json_response.is_array()) {
|
||||||
|
|
@ -84,7 +84,7 @@ const std::string libretranslate::translate(const std::string &text, const std::
|
||||||
|
|
||||||
dpp::json json_body = {
|
dpp::json json_body = {
|
||||||
{"q"s, text},
|
{"q"s, text},
|
||||||
{"source"s, source},
|
{"source"s, source.empty() ? "auto"s : source},
|
||||||
{"target"s, target},
|
{"target"s, target},
|
||||||
{"format"s, "text"s}
|
{"format"s, "text"s}
|
||||||
};
|
};
|
||||||
|
|
@ -94,7 +94,7 @@ const std::string libretranslate::translate(const std::string &text, const std::
|
||||||
|
|
||||||
try {
|
try {
|
||||||
http_request request;
|
http_request request;
|
||||||
http_response response = request.post(http_request::legacy_url(m_hostname, m_port, m_url + "translate", m_tls), json_body.dump(), "application/json");
|
http_response response = request.post(http_request::legacy_url(m_hostname, m_port, m_url + "translate"s, m_tls), json_body.dump(), "application/json");
|
||||||
if (response.status == 200) {
|
if (response.status == 200) {
|
||||||
const dpp::json json_response = dpp::json::parse(response.content);
|
const dpp::json json_response = dpp::json::parse(response.content);
|
||||||
if (json_response.is_object()) {
|
if (json_response.is_object()) {
|
||||||
|
|
|
||||||
|
|
@ -45,7 +45,7 @@ const std::vector<language> lingvatranslate::get_languages()
|
||||||
|
|
||||||
try {
|
try {
|
||||||
http_request request;
|
http_request request;
|
||||||
http_response response = request.get(http_request::legacy_url(m_hostname, m_port, m_url + "api/v1/languages/target", m_tls));
|
http_response response = request.get(http_request::legacy_url(m_hostname, m_port, m_url + "api/v1/languages/target"s, m_tls));
|
||||||
if (response.status == 200) {
|
if (response.status == 200) {
|
||||||
const dpp::json json_response = dpp::json::parse(response.content);
|
const dpp::json json_response = dpp::json::parse(response.content);
|
||||||
if (json_response.is_object()) {
|
if (json_response.is_object()) {
|
||||||
|
|
@ -84,7 +84,7 @@ const std::string lingvatranslate::translate(const std::string &text, const std:
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
http_request request;
|
http_request request;
|
||||||
http_response response = request.get(http_request::legacy_url(m_hostname, m_port, m_url + "api/v1/" + source + "/" + target + "/" + dpp::utility::url_encode(text), m_tls));
|
http_response response = request.get(http_request::legacy_url(m_hostname, m_port, m_url + "api/v1/"s + (source.empty() ? "auto"s : source) + "/"s + target + "/"s + dpp::utility::url_encode(text), m_tls));
|
||||||
if (response.status == 200) {
|
if (response.status == 200) {
|
||||||
const dpp::json json_response = dpp::json::parse(response.content);
|
const dpp::json json_response = dpp::json::parse(response.content);
|
||||||
if (json_response.is_object()) {
|
if (json_response.is_object()) {
|
||||||
|
|
|
||||||
|
|
@ -48,7 +48,7 @@ const std::vector<language> mozhi::get_languages()
|
||||||
{"engine"s, m_engine}
|
{"engine"s, m_engine}
|
||||||
});
|
});
|
||||||
http_request request;
|
http_request request;
|
||||||
http_response response = request.get(http_request::legacy_url(m_hostname, m_port, m_url + "api/target_languages", m_tls));
|
http_response response = request.get(http_request::legacy_url(m_hostname, m_port, m_url + "api/target_languages"s, m_tls));
|
||||||
if (response.status == 200) {
|
if (response.status == 200) {
|
||||||
const dpp::json json_response = dpp::json::parse(response.content);
|
const dpp::json json_response = dpp::json::parse(response.content);
|
||||||
if (json_response.is_array()) {
|
if (json_response.is_array()) {
|
||||||
|
|
@ -85,12 +85,12 @@ const std::string mozhi::translate(const std::string &text, const std::string &s
|
||||||
try {
|
try {
|
||||||
const std::string parameters = dpp::utility::make_url_parameters({
|
const std::string parameters = dpp::utility::make_url_parameters({
|
||||||
{"engine"s, m_engine},
|
{"engine"s, m_engine},
|
||||||
{"from"s, source},
|
{"from"s, source.empty() ? "auto"s : source},
|
||||||
{"to"s, target},
|
{"to"s, target},
|
||||||
{"text"s, text},
|
{"text"s, text}
|
||||||
});
|
});
|
||||||
http_request request;
|
http_request request;
|
||||||
http_response response = request.get(http_request::legacy_url(m_hostname, m_port, m_url + "api/translate" + parameters, m_tls));
|
http_response response = request.get(http_request::legacy_url(m_hostname, m_port, m_url + "api/translate"s + parameters, m_tls));
|
||||||
if (response.status == 200) {
|
if (response.status == 200) {
|
||||||
const dpp::json json_response = dpp::json::parse(response.content);
|
const dpp::json json_response = dpp::json::parse(response.content);
|
||||||
if (json_response.is_object()) {
|
if (json_response.is_object()) {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue