From 022bd092ceab814b1aa06838d25c613ec758033c Mon Sep 17 00:00:00 2001 From: levlam Date: Tue, 3 Apr 2018 19:28:37 +0300 Subject: [PATCH] Add selfie support. GitOrigin-RevId: 3a778f7000dc074a568e1e44de0a7ca3d208f77b --- td/generate/scheme/td_api.tl | 12 ++++++------ td/generate/scheme/td_api.tlo | Bin 116704 -> 116800 bytes td/telegram/SecureValue.cpp | 9 ++++++++- td/telegram/SecureValue.h | 1 + 4 files changed, 15 insertions(+), 7 deletions(-) diff --git a/td/generate/scheme/td_api.tl b/td/generate/scheme/td_api.tl index 7ada26605..c5ca7bd6f 100644 --- a/td/generate/scheme/td_api.tl +++ b/td/generate/scheme/td_api.tl @@ -830,11 +830,11 @@ passportDataTypePhoneNumber = PassportDataType; passportDataTypeEmailAddress = PassportDataType; -//@description Contains information about a Telegram Passport data @type Telegram Passport data type @data TODO data should be typed @files List of attached files -passportData type:PassportDataType data:string files:vector = PassportData; +//@description Contains information about a Telegram Passport data @type Telegram Passport data type @data TODO data should be typed @files List of attached files with a document @selfie Selfie with the document +passportData type:PassportDataType data:string files:vector selfie:file = PassportData; -//@description Contains information about a Telegram Passport data to save @type Telegram Passport data type @data TODO data should be typed @files List of attached files -inputPassportData type:PassportDataType data:string files:vector = InputPassportData; +//@description Contains information about a Telegram Passport data to save @type Telegram Passport data type @data TODO data should be typed @files List of attached files with a document @selfie Selfie with the document +inputPassportData type:PassportDataType data:string files:vector selfie:file = InputPassportData; //@class PassportAuthorizationForm Contains information about requested Telegram Passport authorization form @data Available data @@ -845,8 +845,8 @@ passportAuthorizationForm id:int32 data:vector = PassportAuthoriza encryptedCredentials data:bytes hash:bytes secret:bytes = EncryptedCredentials; -//@description Contains information about an encrypted Telegram Passport data @type Telegram Passport data type @data Encrypted data about the user @files List of attached files @value Unencrypted data, phone number or email address -encryptedPassportData type:PassportDataType data:bytes files:vector value:string = EncryptedPassportData; +//@description Contains information about an encrypted Telegram Passport data @type Telegram Passport data type @data Encrypted data about the user @files List of attached files @value Unencrypted data, phone number or email address @selfie Selfie with the document +encryptedPassportData type:PassportDataType data:bytes files:vector value:string selfie:file = EncryptedPassportData; //@class MessageContent @description Contains the content of a message diff --git a/td/generate/scheme/td_api.tlo b/td/generate/scheme/td_api.tlo index 67145cb7cfaf3061e7c791ce3e1700097d36a22e..d415a298384d942e0f94a449399591db307a688f 100644 GIT binary patch delta 318 zcmaFR&wgM6`-UYPY~iO5tq^sc92Y0H`2dFvGYgykfr*=Vcvx9%YA!Ks77+CCWdSLf z91|zO31ZwlCgj69`Qmi*$uUMelMlp&OmC=QWMwZ-%}L8lWtgmRTL!FtvqJm?3q_D& zf|+>*r6mE0#l;2rMI|nYC5a3SAaRgEEI@kU3u5vVpcu#i5`&qTJ$b=J9!yig9@=qn%_>fqVkV&V>eEkbWz+!scKd-E c#v2w$vLEBb!QnA|&sIhgh>|Z`8Q%y30LGYoGynhq delta 276 zcmX>wf&D>0`-UYPY!3U9V?|vj$Hj?lKEPqa%yNtGjo>C89#)pvSzVT!1q3~OSwKoA z$HYlM7zGz?CdU}@Og<17GWmfj2Uu{kL;M5_MUYm(%)Elql7PhG;)4955|_l1LhFZveYiwiG084IHsAarifh-#*4z_=~%r-_7h?0

get_encrypted_passport_data_ob bool is_plain = value.data.hash.empty(); return td_api::make_object( get_passport_data_type_object(value.type), is_plain ? string() : value.data.data, - get_encrypted_files_object(file_manager, value.files), is_plain ? value.data.data : string()); + get_encrypted_files_object(file_manager, value.files), is_plain ? value.data.data : string(), get_encrypted_file_object(file_manager, value.selfie)); } telegram_api::object_ptr get_input_secure_value_object( @@ -351,6 +351,7 @@ Result get_secure_value(td_api::object_ptrtype_)); res.data = std::move(input_passport_data->data_); // res.files = TODO + // res.selfie = TODO return res; } @@ -393,6 +394,8 @@ Result decrypt_encrypted_secure_value(FileManager *file_manager, co // TODO //TRY_RESULT(files, decrypt_secure_files(file_manager, secret, encrypted_secure_value.files)); //res.files = std::move(files); + //TRY_RESULT(selfie, decrypt_secure_file(file_manager, secret, encrypted_secure_value.selfie)); + //res.selfie = std::move(selfie); break; } } @@ -404,11 +407,13 @@ SecureFile encrypt_secure_file(FileManager *file_manager, const secure_storage:: //TODO: return SecureFile{}; } + vector encrypt_secure_files(FileManager *file_manager, const secure_storage::Secret &master_secret, vector files, string &to_hash) { return transform(files, [&](auto file_id) { return encrypt_secure_file(file_manager, master_secret, file_id, to_hash); }); } + SecureData encrypt_secure_data(const secure_storage::Secret &master_secret, Slice data, string &to_hash) { namespace ss = secure_storage; auto secret = ss::Secret::create_new(); @@ -422,6 +427,7 @@ SecureData encrypt_secure_data(const secure_storage::Secret &master_secret, Slic to_hash.append(secret.as_slice().str()); return res; } + EncryptedSecureValue encrypt_secure_value(FileManager *file_manager, const secure_storage::Secret &master_secret, const SecureValue &secure_value) { namespace ss = secure_storage; @@ -438,6 +444,7 @@ EncryptedSecureValue encrypt_secure_value(FileManager *file_manager, const secur res.data = encrypt_secure_data(master_secret, secure_value.data, to_hash); // TODO //res.files = encrypt_secure_files(file_manager, master_secret, secure_value.files, to_hash); + //res.selfie = encrypt_secure_file(file_manager, master_secret, secure_value.selfie, to_hash); res.hash = ss::calc_value_hash(to_hash).as_slice().str(); break; } diff --git a/td/telegram/SecureValue.h b/td/telegram/SecureValue.h index bec87cadc..f2299d665 100644 --- a/td/telegram/SecureValue.h +++ b/td/telegram/SecureValue.h @@ -126,6 +126,7 @@ class SecureValue { SecureValueType type; string data; vector files; + FileId selfie; }; Result get_secure_value(td_api::object_ptr &&input_passport_data);