mirror of
https://github.com/tdlight-team/tdlight-telegram-bot-api.git
synced 2025-01-16 22:37:31 +01:00
Add Query::get_peer_ip_address.
This commit is contained in:
parent
26854a6a3d
commit
e9d32ad23d
@ -41,7 +41,7 @@ using td_api::move_object_as;
|
|||||||
|
|
||||||
int Client::get_retry_after_time(td::Slice error_message) {
|
int Client::get_retry_after_time(td::Slice error_message) {
|
||||||
td::Slice prefix = "Too Many Requests: retry after ";
|
td::Slice prefix = "Too Many Requests: retry after ";
|
||||||
if (begins_with(error_message, prefix)) {
|
if (td::begins_with(error_message, prefix)) {
|
||||||
auto r_retry_after = td::to_integer_safe<int>(error_message.substr(prefix.size()));
|
auto r_retry_after = td::to_integer_safe<int>(error_message.substr(prefix.size()));
|
||||||
if (r_retry_after.is_ok() && r_retry_after.ok() > 0) {
|
if (r_retry_after.is_ok() && r_retry_after.ok() > 0) {
|
||||||
return r_retry_after.ok();
|
return r_retry_after.ok();
|
||||||
@ -154,7 +154,7 @@ void Client::fail_query_with_error(PromisedQueryPtr query, int32 error_code, td:
|
|||||||
return fail_query(400, PSLICE() << "Bad Request: " << error_message, std::move(query));
|
return fail_query(400, PSLICE() << "Bad Request: " << error_message, std::move(query));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (begins_with(error_message, prefix)) {
|
if (td::begins_with(error_message, prefix)) {
|
||||||
return fail_query(error_code, error_message, std::move(query));
|
return fail_query(error_code, error_message, std::move(query));
|
||||||
} else {
|
} else {
|
||||||
td::string error_str = prefix.str();
|
td::string error_str = prefix.str();
|
||||||
@ -10168,7 +10168,8 @@ void Client::do_get_updates(int32 offset, int32 limit, int32 timeout, PromisedQu
|
|||||||
if (need_warning && previous_get_updates_finish_time_ > 0) {
|
if (need_warning && previous_get_updates_finish_time_ > 0) {
|
||||||
LOG(WARNING) << "Found " << updates.size() << " updates out of " << (total_size + updates.size())
|
LOG(WARNING) << "Found " << updates.size() << " updates out of " << (total_size + updates.size())
|
||||||
<< " after last getUpdates call " << (query->start_timestamp() - previous_get_updates_finish_time_)
|
<< " after last getUpdates call " << (query->start_timestamp() - previous_get_updates_finish_time_)
|
||||||
<< " seconds ago in " << (td::Time::now() - query->start_timestamp()) << " seconds";
|
<< " seconds ago in " << (td::Time::now() - query->start_timestamp()) << " seconds from "
|
||||||
|
<< query->get_peer_ip_address();
|
||||||
} else {
|
} else {
|
||||||
LOG(DEBUG) << "Found " << updates.size() << " updates out of " << total_size << " from " << from;
|
LOG(DEBUG) << "Found " << updates.size() << " updates out of " << total_size << " from " << from;
|
||||||
}
|
}
|
||||||
|
@ -90,13 +90,7 @@ void ClientManager::send(PromisedQueryPtr query) {
|
|||||||
|
|
||||||
auto id_it = token_to_id_.find(token);
|
auto id_it = token_to_id_.find(token);
|
||||||
if (id_it == token_to_id_.end()) {
|
if (id_it == token_to_id_.end()) {
|
||||||
td::string ip_address;
|
td::string ip_address = query->get_peer_ip_address();
|
||||||
if (query->peer_address().is_valid() && !query->peer_address().is_reserved()) { // external connection
|
|
||||||
ip_address = query->peer_address().get_ip_str().str();
|
|
||||||
} else {
|
|
||||||
// invalid peer address or connection from the local network
|
|
||||||
ip_address = query->get_header("x-real-ip").str();
|
|
||||||
}
|
|
||||||
if (!ip_address.empty()) {
|
if (!ip_address.empty()) {
|
||||||
td::IPAddress tmp;
|
td::IPAddress tmp;
|
||||||
tmp.init_host_port(ip_address, 0).ignore();
|
tmp.init_host_port(ip_address, 0).ignore();
|
||||||
@ -105,7 +99,7 @@ void ClientManager::send(PromisedQueryPtr query) {
|
|||||||
ip_address = tmp.get_ip_str().str();
|
ip_address = tmp.get_ip_str().str();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
LOG(DEBUG) << "Receive incoming query for new bot " << token << " from " << query->peer_address();
|
LOG(DEBUG) << "Receive incoming query for new bot " << token << " from " << ip_address;
|
||||||
if (!ip_address.empty()) {
|
if (!ip_address.empty()) {
|
||||||
LOG(DEBUG) << "Check Client creation flood control for IP address " << ip_address;
|
LOG(DEBUG) << "Check Client creation flood control for IP address " << ip_address;
|
||||||
auto res = flood_controls_.emplace(std::move(ip_address), td::FloodControlFast());
|
auto res = flood_controls_.emplace(std::move(ip_address), td::FloodControlFast());
|
||||||
|
@ -26,10 +26,10 @@ td::FlatHashMap<td::string, td::unique_ptr<td::VirtuallyJsonable>> empty_paramet
|
|||||||
Query::Query(td::vector<td::BufferSlice> &&container, td::Slice token, bool is_test_dc, td::MutableSlice method,
|
Query::Query(td::vector<td::BufferSlice> &&container, td::Slice token, bool is_test_dc, td::MutableSlice method,
|
||||||
td::vector<std::pair<td::MutableSlice, td::MutableSlice>> &&args,
|
td::vector<std::pair<td::MutableSlice, td::MutableSlice>> &&args,
|
||||||
td::vector<std::pair<td::MutableSlice, td::MutableSlice>> &&headers, td::vector<td::HttpFile> &&files,
|
td::vector<std::pair<td::MutableSlice, td::MutableSlice>> &&headers, td::vector<td::HttpFile> &&files,
|
||||||
std::shared_ptr<SharedData> shared_data, const td::IPAddress &peer_address, bool is_internal)
|
std::shared_ptr<SharedData> shared_data, const td::IPAddress &peer_ip_address, bool is_internal)
|
||||||
: state_(State::Query)
|
: state_(State::Query)
|
||||||
, shared_data_(shared_data)
|
, shared_data_(shared_data)
|
||||||
, peer_address_(peer_address)
|
, peer_ip_address_(peer_ip_address)
|
||||||
, container_(std::move(container))
|
, container_(std::move(container))
|
||||||
, token_(token)
|
, token_(token)
|
||||||
, is_test_dc_(is_test_dc)
|
, is_test_dc_(is_test_dc)
|
||||||
@ -53,6 +53,15 @@ Query::Query(td::vector<td::BufferSlice> &&container, td::Slice token, bool is_t
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
td::string Query::get_peer_ip_address() const {
|
||||||
|
if (peer_ip_address_.is_valid() && !peer_ip_address_.is_reserved()) { // external connection
|
||||||
|
return peer_ip_address_.get_ip_str().str();
|
||||||
|
} else {
|
||||||
|
// invalid peer IP address or connection from the local network
|
||||||
|
return get_header("x-real-ip").str();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
td::int64 Query::query_size() const {
|
td::int64 Query::query_size() const {
|
||||||
return std::accumulate(
|
return std::accumulate(
|
||||||
container_.begin(), container_.end(), td::int64{0},
|
container_.begin(), container_.end(), td::int64{0},
|
||||||
|
@ -70,9 +70,7 @@ class Query final : public td::ListNode {
|
|||||||
return files_;
|
return files_;
|
||||||
}
|
}
|
||||||
|
|
||||||
const td::IPAddress &peer_address() const {
|
td::string get_peer_ip_address() const;
|
||||||
return peer_address_;
|
|
||||||
}
|
|
||||||
|
|
||||||
td::BufferSlice &answer() {
|
td::BufferSlice &answer() {
|
||||||
return answer_;
|
return answer_;
|
||||||
@ -103,7 +101,7 @@ class Query final : public td::ListNode {
|
|||||||
Query(td::vector<td::BufferSlice> &&container, td::Slice token, bool is_test_dc, td::MutableSlice method,
|
Query(td::vector<td::BufferSlice> &&container, td::Slice token, bool is_test_dc, td::MutableSlice method,
|
||||||
td::vector<std::pair<td::MutableSlice, td::MutableSlice>> &&args,
|
td::vector<std::pair<td::MutableSlice, td::MutableSlice>> &&args,
|
||||||
td::vector<std::pair<td::MutableSlice, td::MutableSlice>> &&headers, td::vector<td::HttpFile> &&files,
|
td::vector<std::pair<td::MutableSlice, td::MutableSlice>> &&headers, td::vector<td::HttpFile> &&files,
|
||||||
std::shared_ptr<SharedData> shared_data, const td::IPAddress &peer_address, bool is_internal);
|
std::shared_ptr<SharedData> shared_data, const td::IPAddress &peer_ip_address, bool is_internal);
|
||||||
Query(const Query &) = delete;
|
Query(const Query &) = delete;
|
||||||
Query &operator=(const Query &) = delete;
|
Query &operator=(const Query &) = delete;
|
||||||
Query(Query &&) = delete;
|
Query(Query &&) = delete;
|
||||||
@ -129,7 +127,7 @@ class Query final : public td::ListNode {
|
|||||||
State state_;
|
State state_;
|
||||||
std::shared_ptr<SharedData> shared_data_;
|
std::shared_ptr<SharedData> shared_data_;
|
||||||
double start_timestamp_;
|
double start_timestamp_;
|
||||||
td::IPAddress peer_address_;
|
td::IPAddress peer_ip_address_;
|
||||||
td::ActorId<BotStatActor> stat_actor_;
|
td::ActorId<BotStatActor> stat_actor_;
|
||||||
|
|
||||||
// request
|
// request
|
||||||
|
Loading…
x
Reference in New Issue
Block a user