Support missed device token types, better names for 'token' fields.

GitOrigin-RevId: 2bf86a45e30387a8bf0ee0aa93c1c795f402d138
This commit is contained in:
levlam 2018-01-19 18:04:16 +03:00
parent 22ad86508a
commit 5895f817d8
10 changed files with 155 additions and 25 deletions

View File

@ -1,6 +1,6 @@
cmake_minimum_required(VERSION 3.0.2 FATAL_ERROR) cmake_minimum_required(VERSION 3.0.2 FATAL_ERROR)
project(TDLib VERSION 1.0.3 LANGUAGES CXX C) project(TDLib VERSION 1.0.4 LANGUAGES CXX C)
if (NOT DEFINED CMAKE_MODULE_PATH) if (NOT DEFINED CMAKE_MODULE_PATH)
set(CMAKE_MODULE_PATH "") set(CMAKE_MODULE_PATH "")

View File

@ -81,7 +81,7 @@ target_link_library(YourLibrary Td::TdJson)
Or you could install `TDLib` and then reference it in your CMakeLists.txt like this: Or you could install `TDLib` and then reference it in your CMakeLists.txt like this:
``` ```
find_package(Td 1.0.3) find_package(Td 1.0.4)
target_link_library(YourLibrary Td::TdJson) target_link_library(YourLibrary Td::TdJson)
``` ```
See [example/cpp/CMakeLists.txt](https://github.com/tdlib/td/tree/master/example/cpp/CMakeLists.txt). See [example/cpp/CMakeLists.txt](https://github.com/tdlib/td/tree/master/example/cpp/CMakeLists.txt).

View File

@ -2,7 +2,7 @@ cmake_minimum_required(VERSION 3.1 FATAL_ERROR)
project(TdExample VERSION 1.0 LANGUAGES CXX) project(TdExample VERSION 1.0 LANGUAGES CXX)
find_package(Td 1.0.3 REQUIRED) find_package(Td 1.0.4 REQUIRED)
add_executable(tdjson_example tdjson_example.cpp) add_executable(tdjson_example tdjson_example.cpp)
target_link_libraries(tdjson_example PRIVATE Td::TdJson) target_link_libraries(tdjson_example PRIVATE Td::TdJson)

View File

@ -1419,17 +1419,30 @@ chatEventLogFilters message_edits:Bool message_deletions:Bool message_pins:Bool
//@class DeviceToken @description Represents a token for push notifications //@class DeviceToken @description Represents a token for push notifications
//@description A token for Apple Push Notification Service @token Token, may be empty to de-register a device @is_app_sandbox True, if App Sandbox is enabled //@description A token for Google Cloud Messaging @token Device registration token, may be empty to de-register a device
deviceTokenApplePush token:string is_app_sandbox:Bool = DeviceToken;
//@description A token for Google Cloud Messaging @token Token, may be empty to de-register a device
deviceTokenGoogleCloudMessaging token:string = DeviceToken; deviceTokenGoogleCloudMessaging token:string = DeviceToken;
//@description A token for Microsoft Push Notification Service @token Token, may be empty to de-register a device //@description A token for Apple Push Notification Service @device_token Device token, may be empty to de-register a device @is_app_sandbox True, if App Sandbox is enabled
deviceTokenMicrosoftPush token:string = DeviceToken; deviceTokenApplePush device_token:string is_app_sandbox:Bool = DeviceToken;
//@description A token for Simple Push API @token Token, may be empty to de-register a device //@description A token for Apple Push Notification Service VoIP notifications @device_token Device token, may be empty to de-register a device @is_app_sandbox True, if App Sandbox is enabled
deviceTokenSimplePush token:string = DeviceToken; deviceTokenApplePushVoIP device_token:string is_app_sandbox:Bool = DeviceToken;
//@description A token for Windows Push Notification Services @access_token The access token that will be used to send notifications, may be empty to de-register a device
deviceTokenWindowsPush access_token:string = DeviceToken;
//@description A token for Microsoft Push Notification Service @channel_uri Push notification channel URI, may be empty to de-register a device
deviceTokenMicrosoftPush channel_uri:string = DeviceToken;
//@description A token for Microsoft Push Notification Service VoIP channel @channel_uri Push notification channel URI, may be empty to de-register a device
deviceTokenMicrosoftPushVoIP channel_uri:string = DeviceToken;
//@description A token for web Push API @endpoint Absolute URL exposed by the push service where the application server can send push messages, may be empty to de-register a device
//@p256dh_base64url Base64url-encoded P-256 elliptic curve Diffie-Hellman public key @auth_base64url Base64url-encoded authentication secret
deviceTokenWebPush endpoint:string p256dh_base64url:string auth_base64url:string = DeviceToken;
//@description A token for Simple Push API for Firefox OS @endpoint Absolute URL exposed by the push service where the application server can send push messages, may be empty to de-register a device
deviceTokenSimplePush endpoint:string = DeviceToken;
//@description A token for Ubuntu Push Client service @token Token, may be empty to de-register a device //@description A token for Ubuntu Push Client service @token Token, may be empty to de-register a device
deviceTokenUbuntuPush token:string = DeviceToken; deviceTokenUbuntuPush token:string = DeviceToken;
@ -1437,6 +1450,9 @@ deviceTokenUbuntuPush token:string = DeviceToken;
//@description A token for Blackberry Push Service @token Token, may be empty to de-register a device //@description A token for Blackberry Push Service @token Token, may be empty to de-register a device
deviceTokenBlackberryPush token:string = DeviceToken; deviceTokenBlackberryPush token:string = DeviceToken;
//@description A token for Tizen Push Service @reg_id Push service registration identifier, may be empty to de-register a device
deviceTokenTizenPush reg_id:string = DeviceToken;
//@description Contains information about a wallpaper @id Unique persistent wallpaper identifier @sizes Available variants of the wallpaper in different sizes. These photos can only be downloaded; they can't be sent in a message @color Main color of the wallpaper in RGB24 format; should be treated as background color if no photos are specified //@description Contains information about a wallpaper @id Unique persistent wallpaper identifier @sizes Available variants of the wallpaper in different sizes. These photos can only be downloaded; they can't be sent in a message @color Main color of the wallpaper in RGB24 format; should be treated as background color if no photos are specified
wallpaper id:int32 sizes:vector<photoSize> color:int32 = Wallpaper; wallpaper id:int32 sizes:vector<photoSize> color:int32 = Wallpaper;

Binary file not shown.

View File

@ -14,10 +14,11 @@
#include "td/telegram/td_api.hpp" #include "td/telegram/td_api.hpp"
#include "td/telegram/telegram_api.h" #include "td/telegram/telegram_api.h"
#include "td/utils/base64.h"
#include "td/utils/format.h" #include "td/utils/format.h"
#include "td/utils/JsonBuilder.h"
#include "td/utils/logging.h" #include "td/utils/logging.h"
#include "td/utils/Status.h" #include "td/utils/Status.h"
#include "td/utils/StringBuilder.h"
#include "td/utils/tl_helpers.h" #include "td/utils/tl_helpers.h"
#include <type_traits> #include <type_traits>
@ -105,7 +106,7 @@ void DeviceTokenManager::register_device(tl_object_ptr<td_api::DeviceToken> devi
switch (device_token_ptr->get_id()) { switch (device_token_ptr->get_id()) {
case td_api::deviceTokenApplePush::ID: { case td_api::deviceTokenApplePush::ID: {
auto device_token = static_cast<td_api::deviceTokenApplePush *>(device_token_ptr.get()); auto device_token = static_cast<td_api::deviceTokenApplePush *>(device_token_ptr.get());
token = std::move(device_token->token_); token = std::move(device_token->device_token_);
token_type = TokenType::APNS; token_type = TokenType::APNS;
is_app_sandbox = device_token->is_app_sandbox_; is_app_sandbox = device_token->is_app_sandbox_;
break; break;
@ -118,31 +119,110 @@ void DeviceTokenManager::register_device(tl_object_ptr<td_api::DeviceToken> devi
} }
case td_api::deviceTokenMicrosoftPush::ID: { case td_api::deviceTokenMicrosoftPush::ID: {
auto device_token = static_cast<td_api::deviceTokenMicrosoftPush *>(device_token_ptr.get()); auto device_token = static_cast<td_api::deviceTokenMicrosoftPush *>(device_token_ptr.get());
token = std::move(device_token->token_); token = std::move(device_token->channel_uri_);
token_type = TokenType::MPNS; token_type = TokenType::MPNS;
break; break;
} }
case td_api::deviceTokenSimplePush::ID: { case td_api::deviceTokenSimplePush::ID: {
auto device_token = static_cast<td_api::deviceTokenSimplePush *>(device_token_ptr.get()); auto device_token = static_cast<td_api::deviceTokenSimplePush *>(device_token_ptr.get());
token = std::move(device_token->token_); token = std::move(device_token->endpoint_);
token_type = TokenType::SimplePush; token_type = TokenType::SIMPLE_PUSH;
break; break;
} }
case td_api::deviceTokenUbuntuPush::ID: { case td_api::deviceTokenUbuntuPush::ID: {
auto device_token = static_cast<td_api::deviceTokenUbuntuPush *>(device_token_ptr.get()); auto device_token = static_cast<td_api::deviceTokenUbuntuPush *>(device_token_ptr.get());
token = std::move(device_token->token_); token = std::move(device_token->token_);
token_type = TokenType::UbuntuPhone; token_type = TokenType::UBUNTU_PHONE;
break; break;
} }
case td_api::deviceTokenBlackberryPush::ID: { case td_api::deviceTokenBlackberryPush::ID: {
auto device_token = static_cast<td_api::deviceTokenBlackberryPush *>(device_token_ptr.get()); auto device_token = static_cast<td_api::deviceTokenBlackberryPush *>(device_token_ptr.get());
token = std::move(device_token->token_); token = std::move(device_token->token_);
token_type = TokenType::Blackberry; token_type = TokenType::BLACKBERRY;
break;
}
case td_api::deviceTokenWindowsPush::ID: {
auto device_token = static_cast<td_api::deviceTokenWindowsPush *>(device_token_ptr.get());
token = std::move(device_token->access_token_);
token_type = TokenType::WNS;
break;
}
case td_api::deviceTokenApplePushVoIP::ID: {
auto device_token = static_cast<td_api::deviceTokenApplePushVoIP *>(device_token_ptr.get());
token = std::move(device_token->device_token_);
token_type = TokenType::APNS_VOIP;
is_app_sandbox = device_token->is_app_sandbox_;
break;
}
case td_api::deviceTokenWebPush::ID: {
auto device_token = static_cast<td_api::deviceTokenWebPush *>(device_token_ptr.get());
if (device_token->endpoint_.find(',') != string::npos) {
return promise.set_error(Status::Error(400, "Illegal endpoint value"));
}
if (!is_base64url(device_token->p256dh_base64url_)) {
return promise.set_error(Status::Error(400, "Public key must be base64url-encoded"));
}
if (!is_base64url(device_token->auth_base64url_)) {
return promise.set_error(Status::Error(400, "Authentication secret must be base64url-encoded"));
}
if (!clean_input_string(device_token->endpoint_)) {
return promise.set_error(Status::Error(400, "Endpoint must be encoded in UTF-8"));
}
if (!device_token->endpoint_.empty()) {
class JsonKeys : public Jsonable {
public:
JsonKeys(Slice p256dh, Slice auth) : p256dh_(p256dh), auth_(auth) {
}
void store(JsonValueScope *scope) const {
auto object = scope->enter_object();
object << ctie("p256dh", p256dh_);
object << ctie("auth", auth_);
}
private:
Slice p256dh_;
Slice auth_;
};
class JsonWebPushToken : public Jsonable {
public:
JsonWebPushToken(Slice endpoint, Slice p256dh, Slice auth)
: endpoint_(endpoint), p256dh_(p256dh), auth_(auth) {
}
void store(JsonValueScope *scope) const {
auto object = scope->enter_object();
object << ctie("endpoint", endpoint_);
object << ctie("keys", JsonKeys(p256dh_, auth_));
}
private:
Slice endpoint_;
Slice p256dh_;
Slice auth_;
};
token = json_encode<string>(
JsonWebPushToken(device_token->endpoint_, device_token->p256dh_base64url_, device_token->auth_base64url_));
}
token_type = TokenType::WEB_PUSH;
break;
}
case td_api::deviceTokenMicrosoftPushVoIP::ID: {
auto device_token = static_cast<td_api::deviceTokenMicrosoftPushVoIP *>(device_token_ptr.get());
token = std::move(device_token->channel_uri_);
token_type = TokenType::MPNS_VOIP;
break;
}
case td_api::deviceTokenTizenPush::ID: {
auto device_token = static_cast<td_api::deviceTokenTizenPush *>(device_token_ptr.get());
token = std::move(device_token->reg_id_);
token_type = TokenType::TIZEN;
break; break;
} }
default: default:
UNREACHABLE(); UNREACHABLE();
} }
if (!clean_input_string(token)) { if (!clean_input_string(token)) {
return promise.set_error(Status::Error(400, "Device token must be encoded in UTF-8")); return promise.set_error(Status::Error(400, "Device token must be encoded in UTF-8"));
} }
@ -181,7 +261,7 @@ string DeviceTokenManager::get_database_key(int32 token_type) {
} }
void DeviceTokenManager::start_up() { void DeviceTokenManager::start_up() {
for (int32 token_type = 1; token_type < TokenType::Size; token_type++) { for (int32 token_type = 1; token_type < TokenType::SIZE; token_type++) {
auto serialized = G()->td_db()->get_binlog_pmc()->get(get_database_key(token_type)); auto serialized = G()->td_db()->get_binlog_pmc()->get(get_database_key(token_type));
if (serialized.empty()) { if (serialized.empty()) {
continue; continue;
@ -231,7 +311,7 @@ void DeviceTokenManager::loop() {
if (sync_cnt_ != 0) { if (sync_cnt_ != 0) {
return; return;
} }
for (int32 token_type = 1; token_type < TokenType::Size; token_type++) { for (int32 token_type = 1; token_type < TokenType::SIZE; token_type++) {
auto &info = tokens_[token_type]; auto &info = tokens_[token_type];
if (info.state == TokenInfo::State::Sync) { if (info.state == TokenInfo::State::Sync) {
continue; continue;
@ -256,7 +336,7 @@ void DeviceTokenManager::loop() {
void DeviceTokenManager::on_result(NetQueryPtr net_query) { void DeviceTokenManager::on_result(NetQueryPtr net_query) {
auto token_type = static_cast<TokenType>(get_link_token()); auto token_type = static_cast<TokenType>(get_link_token());
CHECK(token_type >= 1 && token_type < TokenType::Size); CHECK(token_type >= 1 && token_type < TokenType::SIZE);
auto &info = tokens_[token_type]; auto &info = tokens_[token_type];
if (info.net_query_id != net_query->id()) { if (info.net_query_id != net_query->id()) {
net_query->clear(); net_query->clear();

View File

@ -14,6 +14,7 @@
#include "td/telegram/td_api.h" #include "td/telegram/td_api.h"
#include "td/utils/common.h" #include "td/utils/common.h"
#include "td/utils/StringBuilder.h"
#include <array> #include <array>
@ -30,7 +31,21 @@ class DeviceTokenManager : public NetQueryCallback {
static constexpr size_t MAX_OTHER_USER_IDS = 100; static constexpr size_t MAX_OTHER_USER_IDS = 100;
ActorShared<> parent_; ActorShared<> parent_;
enum TokenType : int32 { APNS = 1, GCM = 2, MPNS = 3, SimplePush = 4, UbuntuPhone = 5, Blackberry = 6, Size }; enum TokenType : int32 {
APNS = 1,
GCM = 2,
MPNS = 3,
SIMPLE_PUSH = 4,
UBUNTU_PHONE = 5,
BLACKBERRY = 6,
UNUSED = 7,
WNS = 8,
APNS_VOIP = 9,
WEB_PUSH = 10,
MPNS_VOIP = 11,
TIZEN = 12,
SIZE
};
struct TokenInfo { struct TokenInfo {
enum class State { Sync, Unregister, Register }; enum class State { Sync, Unregister, Register };
State state = State::Sync; State state = State::Sync;
@ -49,7 +64,7 @@ class DeviceTokenManager : public NetQueryCallback {
friend StringBuilder &operator<<(StringBuilder &string_builder, const TokenInfo &token_info); friend StringBuilder &operator<<(StringBuilder &string_builder, const TokenInfo &token_info);
std::array<TokenInfo, TokenType::Size> tokens_; std::array<TokenInfo, TokenType::SIZE> tokens_;
int32 sync_cnt_{0}; int32 sync_cnt_{0};
void start_up() override; void start_up() override;

View File

@ -965,7 +965,8 @@ td_api::object_ptr<td_api::file> copy(const td_api::file &obj) {
if (file_id.is_valid()) { if (file_id.is_valid()) {
return G()->td().get_actor_unsafe()->file_manager_.get()->get_file_object(file_id); return G()->td().get_actor_unsafe()->file_manager_.get()->get_file_object(file_id);
} else { } else {
return td_api::make_object<td_api::file>(obj.id_, obj.size_, obj.expected_size_, copy(obj.local_), copy(obj.remote_)); return td_api::make_object<td_api::file>(obj.id_, obj.size_, obj.expected_size_, copy(obj.local_),
copy(obj.remote_));
} }
} }

View File

@ -187,7 +187,7 @@ class Td final : public NetQueryCallback {
static td_api::object_ptr<td_api::Object> static_request(td_api::object_ptr<td_api::Function> function); static td_api::object_ptr<td_api::Object> static_request(td_api::object_ptr<td_api::Function> function);
private: private:
static constexpr const char *tdlib_version = "1.0.3"; static constexpr const char *tdlib_version = "1.0.4";
static constexpr int32 ONLINE_TIMEOUT = 240; static constexpr int32 ONLINE_TIMEOUT = 240;
void send_result(uint64 id, tl_object_ptr<td_api::Object> object); void send_result(uint64 id, tl_object_ptr<td_api::Object> object);

View File

@ -1027,6 +1027,13 @@ class CliClient final : public Actor {
} else if (op == "rdb") { } else if (op == "rdb") {
send_request(make_tl_object<td_api::registerDevice>(make_tl_object<td_api::deviceTokenBlackberryPush>(args), send_request(make_tl_object<td_api::registerDevice>(make_tl_object<td_api::deviceTokenBlackberryPush>(args),
as_user_ids(""))); as_user_ids("")));
} else if (op == "rdt") {
string token;
string other_user_ids_str;
std::tie(token, other_user_ids_str) = split(args);
send_request(make_tl_object<td_api::registerDevice>(make_tl_object<td_api::deviceTokenTizenPush>(token),
as_user_ids(other_user_ids_str)));
} else if (op == "rdu") { } else if (op == "rdu") {
string token; string token;
string other_user_ids_str; string other_user_ids_str;
@ -1034,6 +1041,17 @@ class CliClient final : public Actor {
std::tie(token, other_user_ids_str) = split(args); std::tie(token, other_user_ids_str) = split(args);
send_request(make_tl_object<td_api::registerDevice>(make_tl_object<td_api::deviceTokenUbuntuPush>(token), send_request(make_tl_object<td_api::registerDevice>(make_tl_object<td_api::deviceTokenUbuntuPush>(token),
as_user_ids(other_user_ids_str))); as_user_ids(other_user_ids_str)));
} else if (op == "rdw") {
string endpoint;
string key;
string secret;
string other_user_ids_str;
std::tie(endpoint, args) = split(args);
std::tie(key, args) = split(args);
std::tie(secret, other_user_ids_str) = split(args);
send_request(make_tl_object<td_api::registerDevice>(
make_tl_object<td_api::deviceTokenWebPush>(endpoint, key, secret), as_user_ids(other_user_ids_str)));
} else if (op == "gpf") { } else if (op == "gpf") {
string chat_id; string chat_id;
string message_id; string message_id;