2018-12-31 20:04:05 +01:00
|
|
|
//
|
2022-12-31 22:28:08 +01:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2023
|
2018-12-31 20:04:05 +01:00
|
|
|
//
|
|
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
#include <iostream>
|
|
|
|
#include <td/telegram/td_json_client.h>
|
|
|
|
|
2018-03-02 01:13:30 +01:00
|
|
|
// Basic example of TDLib JSON interface usage.
|
|
|
|
// Native interface should be preferred instead in C++, so here is only an example of
|
|
|
|
// the main event cycle, which should be essentially the same for all languages.
|
|
|
|
|
|
|
|
int main() {
|
2019-03-06 23:28:35 +01:00
|
|
|
// disable TDLib logging
|
2020-10-12 12:58:01 +02:00
|
|
|
td_execute("{\"@type\":\"setLogVerbosityLevel\", \"new_verbosity_level\":0}");
|
2019-03-06 23:28:35 +01:00
|
|
|
|
2020-11-14 23:13:11 +01:00
|
|
|
int client_id = td_create_client_id();
|
2020-10-12 12:58:01 +02:00
|
|
|
// somehow share the client_id with other threads, which will be able to send requests via td_send
|
2018-03-02 01:13:30 +01:00
|
|
|
|
2020-11-13 17:16:11 +01:00
|
|
|
// start the client by sending request to it
|
|
|
|
td_send(client_id, "{\"@type\":\"getOption\", \"name\":\"version\"}");
|
|
|
|
|
2019-12-06 00:36:33 +01:00
|
|
|
const bool test_incorrect_queries = false;
|
2019-08-06 02:29:16 +02:00
|
|
|
if (test_incorrect_queries) {
|
2020-10-12 12:58:01 +02:00
|
|
|
td_execute("{\"@type\":\"setLogVerbosityLevel\", \"new_verbosity_level\":1}");
|
|
|
|
td_execute("");
|
|
|
|
td_execute("test");
|
|
|
|
td_execute("\"test\"");
|
|
|
|
td_execute("{\"@type\":\"test\", \"@extra\":1}");
|
|
|
|
|
|
|
|
td_send(client_id, "{\"@type\":\"getFileMimeType\"}");
|
|
|
|
td_send(client_id, "{\"@type\":\"getFileMimeType\", \"@extra\":1}");
|
|
|
|
td_send(client_id, "{\"@type\":\"getFileMimeType\", \"@extra\":null}");
|
|
|
|
td_send(client_id, "{\"@type\":\"test\"}");
|
|
|
|
td_send(client_id, "[]");
|
|
|
|
td_send(client_id, "{\"@type\":\"test\", \"@extra\":1}");
|
|
|
|
td_send(client_id, "{\"@type\":\"sendMessage\", \"chat_id\":true, \"@extra\":1}");
|
|
|
|
td_send(client_id, "test");
|
2019-08-06 02:29:16 +02:00
|
|
|
}
|
|
|
|
|
2018-03-02 01:13:30 +01:00
|
|
|
const double WAIT_TIMEOUT = 10.0; // seconds
|
2018-12-31 20:04:05 +01:00
|
|
|
while (true) {
|
2020-10-12 12:58:01 +02:00
|
|
|
const char *result = td_receive(WAIT_TIMEOUT);
|
2018-03-02 01:13:30 +01:00
|
|
|
if (result != nullptr) {
|
2019-08-06 02:29:16 +02:00
|
|
|
// parse the result as a JSON object and process it as an incoming update or an answer to a previously sent request
|
2018-03-02 01:13:30 +01:00
|
|
|
|
|
|
|
// if (result is UpdateAuthorizationState with authorizationStateClosed) {
|
|
|
|
// break;
|
|
|
|
// }
|
|
|
|
|
|
|
|
std::cout << result << std::endl;
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|