mirror of
https://github.com/Balshgit/gpt_chat_bot.git
synced 2025-09-11 22:30:41 +03:00
add provider GeminiProChat & increase chat workers num (#75)
This commit is contained in:
parent
bf7a5520dc
commit
fd9d38b5f0
@ -69,6 +69,7 @@ class ChatGptModelsEnum(StrEnum):
|
|||||||
gpt_3_5_turbo_stream_gptforlove = "gpt-3.5-turbo-stream-gptforlove"
|
gpt_3_5_turbo_stream_gptforlove = "gpt-3.5-turbo-stream-gptforlove"
|
||||||
gpt_3_5_turbo_stream_fakeGpt = "gpt-3.5-turbo-stream-fakeGpt"
|
gpt_3_5_turbo_stream_fakeGpt = "gpt-3.5-turbo-stream-fakeGpt"
|
||||||
gpt_3_5_turbo_stream_aura = "gpt-3.5-turbo-stream-aura"
|
gpt_3_5_turbo_stream_aura = "gpt-3.5-turbo-stream-aura"
|
||||||
|
gpt_3_5_turbo_stream_geminiProChat = "gpt-3.5-turbo-stream-geminiProChat"
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def values(cls) -> set[str]:
|
def values(cls) -> set[str]:
|
||||||
|
@ -35,6 +35,7 @@ public:
|
|||||||
boost::asio::awaitable<void> aura(std::shared_ptr<Channel>, nlohmann::json);
|
boost::asio::awaitable<void> aura(std::shared_ptr<Channel>, nlohmann::json);
|
||||||
boost::asio::awaitable<void> gpt6(std::shared_ptr<Channel>, nlohmann::json);
|
boost::asio::awaitable<void> gpt6(std::shared_ptr<Channel>, nlohmann::json);
|
||||||
boost::asio::awaitable<void> chatxyz(std::shared_ptr<Channel>, nlohmann::json);
|
boost::asio::awaitable<void> chatxyz(std::shared_ptr<Channel>, nlohmann::json);
|
||||||
|
boost::asio::awaitable<void> geminiProChat(std::shared_ptr<Channel>, nlohmann::json);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
boost::asio::awaitable<std::expected<boost::beast::ssl_stream<boost::beast::tcp_stream>, std::string>>
|
boost::asio::awaitable<std::expected<boost::beast::ssl_stream<boost::beast::tcp_stream>, std::string>>
|
||||||
|
@ -2272,3 +2272,82 @@ boost::asio::awaitable<void> FreeGpt::chatxyz(std::shared_ptr<Channel> ch, nlohm
|
|||||||
}
|
}
|
||||||
co_return;
|
co_return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
boost::asio::awaitable<void> FreeGpt::geminiProChat(std::shared_ptr<Channel> ch, nlohmann::json json) {
|
||||||
|
co_await boost::asio::post(boost::asio::bind_executor(*m_thread_pool_ptr, boost::asio::use_awaitable));
|
||||||
|
ScopeExit _exit{[=] { boost::asio::post(ch->get_executor(), [=] { ch->close(); }); }};
|
||||||
|
|
||||||
|
auto prompt = json.at("meta").at("content").at("parts").at(0).at("content").get<std::string>();
|
||||||
|
uint64_t timestamp = getTimestamp();
|
||||||
|
|
||||||
|
auto generate_signature = [](uint64_t timestamp, const std::string& message) {
|
||||||
|
std::string s = std::to_string(timestamp) + ":" + message + ":9C4680FB-A4E1-6BC7-052A-7F68F9F5AD1F";
|
||||||
|
unsigned char hash[SHA256_DIGEST_LENGTH];
|
||||||
|
SHA256_CTX sha256;
|
||||||
|
if (!SHA256_Init(&sha256))
|
||||||
|
throw std::runtime_error("SHA-256 initialization failed");
|
||||||
|
if (!SHA256_Update(&sha256, s.c_str(), s.length()))
|
||||||
|
throw std::runtime_error("SHA-256 update failed");
|
||||||
|
if (!SHA256_Final(hash, &sha256))
|
||||||
|
throw std::runtime_error("SHA-256 finalization failed");
|
||||||
|
std::stringstream ss;
|
||||||
|
for (int i = 0; i < SHA256_DIGEST_LENGTH; i++)
|
||||||
|
ss << std::hex << std::setw(2) << std::setfill('0') << static_cast<int>(hash[i]);
|
||||||
|
return ss.str();
|
||||||
|
};
|
||||||
|
std::string signature = generate_signature(timestamp, prompt);
|
||||||
|
|
||||||
|
boost::system::error_code err{};
|
||||||
|
std::unordered_multimap<std::string, std::string> headers{
|
||||||
|
{"Accept", "t*/*"},
|
||||||
|
{"content-type", "application/json"},
|
||||||
|
{"Referer", "https://geminiprochat.com/"},
|
||||||
|
{"Origin", "https://geminiprochat.com"},
|
||||||
|
{"Sec-Fetch-Dest", "empty"},
|
||||||
|
{"Sec-Fetch-Mode", "cors"},
|
||||||
|
{"Sec-Fetch-Site", "same-origin"},
|
||||||
|
{"TE", "trailers"},
|
||||||
|
};
|
||||||
|
std::string recv;
|
||||||
|
auto ret = Curl()
|
||||||
|
.setUrl("https://geminiprochat.com/api/generate")
|
||||||
|
.setProxy(m_cfg.http_proxy)
|
||||||
|
.setRecvHeadersCallback([](std::string) { return; })
|
||||||
|
.setRecvBodyCallback([&](std::string chunk_str) mutable {
|
||||||
|
boost::asio::post(ch->get_executor(), [=] { ch->try_send(err, chunk_str); });
|
||||||
|
return;
|
||||||
|
})
|
||||||
|
.setBody([&] {
|
||||||
|
constexpr std::string_view ask_json_str = R"({
|
||||||
|
"messages":[
|
||||||
|
{
|
||||||
|
"role":"user",
|
||||||
|
"parts":[
|
||||||
|
{
|
||||||
|
"text":"Hello"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"time":1704256758261,
|
||||||
|
"pass":null,
|
||||||
|
"sign":"e5cbb75324af44b4d9e138238335a7f2120bdae2109625883c3dc44884917086"
|
||||||
|
})";
|
||||||
|
nlohmann::json ask_request = nlohmann::json::parse(ask_json_str, nullptr, false);
|
||||||
|
ask_request["messages"][0]["parts"][0]["text"] = prompt;
|
||||||
|
ask_request["sign"] = signature;
|
||||||
|
ask_request["time"] = timestamp;
|
||||||
|
std::string ask_request_str = ask_request.dump();
|
||||||
|
SPDLOG_INFO("request: [{}]", ask_request_str);
|
||||||
|
return ask_request_str;
|
||||||
|
}())
|
||||||
|
.clearHeaders()
|
||||||
|
.setHttpHeaders(headers)
|
||||||
|
.perform();
|
||||||
|
if (ret.has_value()) {
|
||||||
|
SPDLOG_ERROR("{}", ret.value());
|
||||||
|
co_await boost::asio::post(boost::asio::bind_executor(ch->get_executor(), boost::asio::use_awaitable));
|
||||||
|
ch->try_send(err, ret.value());
|
||||||
|
}
|
||||||
|
co_return;
|
||||||
|
}
|
||||||
|
@ -324,6 +324,7 @@ int main(int, char** argv) {
|
|||||||
ADD_METHOD("gpt-3.5-turbo-stream-aura", FreeGpt::aura);
|
ADD_METHOD("gpt-3.5-turbo-stream-aura", FreeGpt::aura);
|
||||||
ADD_METHOD("gpt6", FreeGpt::gpt6);
|
ADD_METHOD("gpt6", FreeGpt::gpt6);
|
||||||
ADD_METHOD("gpt-3.5-turbo-stream-chatxyz", FreeGpt::chatxyz);
|
ADD_METHOD("gpt-3.5-turbo-stream-chatxyz", FreeGpt::chatxyz);
|
||||||
|
ADD_METHOD("gpt-3.5-turbo-stream-geminiProChat", FreeGpt::geminiProChat);
|
||||||
|
|
||||||
SPDLOG_INFO("active provider:");
|
SPDLOG_INFO("active provider:");
|
||||||
for (auto& [provider, _] : gpt_function)
|
for (auto& [provider, _] : gpt_function)
|
||||||
|
@ -46,6 +46,7 @@ services:
|
|||||||
environment:
|
environment:
|
||||||
CHAT_PATH: "/gpt/chat"
|
CHAT_PATH: "/gpt/chat"
|
||||||
API_KEY: "a40f22f2-c1a2-4b1d-a47f-55ae1a7ddbed"
|
API_KEY: "a40f22f2-c1a2-4b1d-a47f-55ae1a7ddbed"
|
||||||
|
WORK_THREAD_NUM: 4
|
||||||
networks:
|
networks:
|
||||||
chatgpt-network:
|
chatgpt-network:
|
||||||
ipv4_address: 200.20.0.11
|
ipv4_address: 200.20.0.11
|
||||||
|
Loading…
x
Reference in New Issue
Block a user