2018-12-31 22:04:05 +03:00
|
|
|
//
|
2019-01-01 01:02:34 +03:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2019
|
2018-12-31 22:04:05 +03: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 03:13:30 +03: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-07 01:28:35 +03:00
|
|
|
// disable TDLib logging
|
|
|
|
td_json_client_execute(nullptr, "{\"@type\":\"setLogVerbosityLevel\", \"new_verbosity_level\":0}");
|
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
void *client = td_json_client_create();
|
2018-03-02 03:13:30 +03:00
|
|
|
// somehow share the client with other threads, which will be able to send requests via td_json_client_send
|
|
|
|
|
|
|
|
const double WAIT_TIMEOUT = 10.0; // seconds
|
2018-12-31 22:04:05 +03:00
|
|
|
while (true) {
|
2018-03-02 03:13:30 +03:00
|
|
|
const char *result = td_json_client_receive(client, WAIT_TIMEOUT);
|
|
|
|
if (result != nullptr) {
|
|
|
|
// parse the result as JSON object and process it as an incoming update or an answer to a previously sent request
|
|
|
|
|
|
|
|
// if (result is UpdateAuthorizationState with authorizationStateClosed) {
|
|
|
|
// break;
|
|
|
|
// }
|
|
|
|
|
|
|
|
std::cout << result << std::endl;
|
2018-12-31 22:04:05 +03:00
|
|
|
}
|
|
|
|
}
|
2018-03-02 03:13:30 +03:00
|
|
|
|
|
|
|
td_json_client_destroy(client);
|
2018-12-31 22:04:05 +03:00
|
|
|
}
|