2018-12-31 22:04:05 +03:00
|
|
|
//
|
2023-01-01 00:28:08 +03:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2023
|
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)
|
|
|
|
//
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \file
|
|
|
|
* C interface for interaction with TDLib via JSON-serialized objects.
|
|
|
|
* Can be used to easily integrate TDLib with any programming language which supports calling C functions
|
|
|
|
* and is able to work with JSON.
|
|
|
|
*
|
|
|
|
* The JSON serialization of TDLib API objects is straightforward: all API objects are represented as JSON objects with
|
2020-11-15 17:38:10 +03:00
|
|
|
* the same keys as the API object field names. The object type name is stored in the special field "@type" which is
|
2019-04-30 01:07:04 +03:00
|
|
|
* optional in places where type is uniquely determined by the context.
|
2020-01-31 03:47:28 +03:00
|
|
|
* Fields of Bool type are stored as Boolean, fields of int32, int53, and double types are stored as Number, fields of
|
2019-04-30 01:07:04 +03:00
|
|
|
* int64 and string types are stored as String, fields of bytes type are base64 encoded and then stored as String,
|
2020-11-15 19:57:03 +03:00
|
|
|
* fields of array type are stored as Array.
|
2018-12-31 22:04:05 +03:00
|
|
|
*
|
2020-11-18 23:42:26 +03:00
|
|
|
* The main TDLib interface is asynchronous. To match requests with a corresponding response, the field "@extra" can
|
2020-10-05 16:08:07 +03:00
|
|
|
* be added to the request object. The corresponding response will have an "@extra" field with exactly the same value.
|
2020-11-18 23:42:26 +03:00
|
|
|
* Each returned object will have an "@client_id" field, containing the identifier of the client for which
|
|
|
|
* a response or an update was received.
|
2020-10-05 16:08:07 +03:00
|
|
|
*
|
2020-11-15 01:13:11 +03:00
|
|
|
* A TDLib client instance can be created through td_create_client_id.
|
2020-11-20 01:32:58 +03:00
|
|
|
* Requests can be sent using td_send and the received client identifier.
|
2020-11-18 23:42:26 +03:00
|
|
|
* New updates and responses to requests can be received through td_receive from any thread after the first request
|
|
|
|
* has been sent to the client instance. This function must not be called simultaneously from two different threads.
|
2023-01-02 15:38:04 +03:00
|
|
|
* Also, note that all updates and responses to requests must be applied in the order they were received for consistency.
|
2020-11-18 23:42:26 +03:00
|
|
|
* Some TDLib requests can be executed synchronously from any thread using td_execute.
|
|
|
|
* TDLib client instances are destroyed automatically after they are closed.
|
2021-10-05 00:59:35 +03:00
|
|
|
* All TDLib client instances must be closed before application termination to ensure data consistency.
|
2020-10-05 16:08:07 +03:00
|
|
|
*
|
|
|
|
* General pattern of usage:
|
|
|
|
* \code
|
2020-11-15 01:13:11 +03:00
|
|
|
* int client_id = td_create_client_id();
|
2020-10-05 16:08:07 +03:00
|
|
|
* // share the client_id with other threads, which will be able to send requests via td_send
|
|
|
|
*
|
|
|
|
* const double WAIT_TIMEOUT = 10.0; // seconds
|
|
|
|
* while (true) {
|
|
|
|
* const char *result = td_receive(WAIT_TIMEOUT);
|
|
|
|
* if (result) {
|
2020-11-18 23:42:26 +03:00
|
|
|
* // parse the result as a JSON object and process it as an incoming update or the answer to a previously sent request
|
2020-10-05 16:08:07 +03:00
|
|
|
* }
|
|
|
|
* }
|
|
|
|
* \endcode
|
|
|
|
*/
|
|
|
|
|
2021-12-22 14:03:46 +03:00
|
|
|
#include "td/telegram/tdjson_export.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-10-05 16:08:07 +03:00
|
|
|
/**
|
2020-11-15 01:13:11 +03:00
|
|
|
* Returns an opaque identifier of a new TDLib instance.
|
|
|
|
* The TDLib instance will not send updates until the first request is sent to it.
|
2020-11-18 23:42:26 +03:00
|
|
|
* \return Opaque identifier of a new TDLib instance.
|
2020-10-05 16:08:07 +03:00
|
|
|
*/
|
2020-11-15 01:13:11 +03:00
|
|
|
TDJSON_EXPORT int td_create_client_id();
|
2020-10-05 16:08:07 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sends request to the TDLib client. May be called from any thread.
|
2020-11-18 23:42:26 +03:00
|
|
|
* \param[in] client_id TDLib client identifier.
|
2020-10-05 16:08:07 +03:00
|
|
|
* \param[in] request JSON-serialized null-terminated request to TDLib.
|
|
|
|
*/
|
|
|
|
TDJSON_EXPORT void td_send(int client_id, const char *request);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Receives incoming updates and request responses. Must not be called simultaneously from two different threads.
|
2020-11-18 23:42:26 +03:00
|
|
|
* The returned pointer can be used until the next call to td_receive or td_execute, after which it will be deallocated by TDLib.
|
2020-10-05 16:08:07 +03:00
|
|
|
* \param[in] timeout The maximum number of seconds allowed for this function to wait for new data.
|
|
|
|
* \return JSON-serialized null-terminated incoming update or request response. May be NULL if the timeout expires.
|
|
|
|
*/
|
|
|
|
TDJSON_EXPORT const char *td_receive(double timeout);
|
|
|
|
|
|
|
|
/**
|
2020-11-18 23:42:26 +03:00
|
|
|
* Synchronously executes a TDLib request.
|
|
|
|
* A request can be executed synchronously, only if it is documented with "Can be called synchronously".
|
|
|
|
* The returned pointer can be used until the next call to td_receive or td_execute, after which it will be deallocated by TDLib.
|
2020-10-05 16:08:07 +03:00
|
|
|
* \param[in] request JSON-serialized null-terminated request to TDLib.
|
|
|
|
* \return JSON-serialized null-terminated request response.
|
|
|
|
*/
|
|
|
|
TDJSON_EXPORT const char *td_execute(const char *request);
|
|
|
|
|
2021-05-18 04:35:36 +03:00
|
|
|
/**
|
|
|
|
* A type of callback function that will be called when a message is added to the internal TDLib log.
|
|
|
|
*
|
2022-07-08 11:21:31 +03:00
|
|
|
* \param verbosity_level Log verbosity level with which the message was added from -1 up to 1024.
|
2021-05-20 18:30:46 +03:00
|
|
|
* If 0, then TDLib will crash as soon as the callback returns.
|
|
|
|
* None of the TDLib methods can be called from the callback.
|
2022-06-04 14:57:29 +03:00
|
|
|
* \param message Null-terminated UTF-8-encoded string with the message added to the log.
|
2021-05-18 04:35:36 +03:00
|
|
|
*/
|
|
|
|
typedef void (*td_log_message_callback_ptr)(int verbosity_level, const char *message);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the callback that will be called when a message is added to the internal TDLib log.
|
|
|
|
* None of the TDLib methods can be called from the callback.
|
|
|
|
* By default the callback is not set.
|
|
|
|
*
|
2021-06-02 15:43:56 +03:00
|
|
|
* \param[in] max_verbosity_level The maximum verbosity level of messages for which the callback will be called.
|
2021-05-18 04:35:36 +03:00
|
|
|
* \param[in] callback Callback that will be called when a message is added to the internal TDLib log.
|
|
|
|
* Pass nullptr to remove the callback.
|
|
|
|
*/
|
|
|
|
TDJSON_EXPORT void td_set_log_message_callback(int max_verbosity_level, td_log_message_callback_ptr callback);
|
|
|
|
|
2021-12-22 14:03:46 +03:00
|
|
|
/**
|
|
|
|
* \file
|
2021-12-22 14:07:44 +03:00
|
|
|
* Alternatively, you can use old TDLib JSON interface, which will be removed in TDLib 2.0.0.
|
2021-12-22 14:03:46 +03:00
|
|
|
*
|
|
|
|
* Objects and functions serialization to JSON is the same for both JSON interfaces.
|
|
|
|
*
|
2021-12-23 18:40:52 +03:00
|
|
|
* The main TDLib interface is asynchronous. To match requests with a corresponding response a field "@extra" can
|
|
|
|
* be added to the request object. The corresponding response will have an "@extra" field with exactly the same value.
|
|
|
|
*
|
2021-12-22 14:03:46 +03:00
|
|
|
* A TDLib client instance can be created through td_json_client_create.
|
|
|
|
* Requests then can be sent using td_json_client_send from any thread.
|
|
|
|
* New updates and request responses can be received through td_json_client_receive from any thread. This function
|
2023-01-02 15:38:04 +03:00
|
|
|
* must not be called simultaneously from two different threads. Also, note that all updates and request responses
|
2021-12-22 14:03:46 +03:00
|
|
|
* must be applied in the order they were received to ensure consistency.
|
|
|
|
* Given this information, it's advisable to call this function from a dedicated thread.
|
|
|
|
* Some service TDLib requests can be executed synchronously from any thread by using td_json_client_execute.
|
|
|
|
* The TDLib client instance can be destroyed via td_json_client_destroy.
|
|
|
|
*
|
|
|
|
* General pattern of usage:
|
|
|
|
* \code
|
|
|
|
* void *client = td_json_client_create();
|
|
|
|
* // 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
|
|
|
|
* int is_closed = 0; // should be set to 1, when updateAuthorizationState with authorizationStateClosed is received
|
|
|
|
* while (!is_closed) {
|
|
|
|
* const char *result = td_json_client_receive(client, WAIT_TIMEOUT);
|
|
|
|
* if (result) {
|
|
|
|
* // parse the result as JSON object and process it as an incoming update or an answer to a previously sent request
|
|
|
|
* }
|
|
|
|
* }
|
|
|
|
* td_json_client_destroy(client);
|
|
|
|
* \endcode
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a new instance of TDLib.
|
|
|
|
* \return Pointer to the created instance of TDLib.
|
|
|
|
*/
|
|
|
|
TDJSON_EXPORT void *td_json_client_create();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sends request to the TDLib client. May be called from any thread.
|
|
|
|
* \param[in] client The client.
|
|
|
|
* \param[in] request JSON-serialized null-terminated request to TDLib.
|
|
|
|
*/
|
|
|
|
TDJSON_EXPORT void td_json_client_send(void *client, const char *request);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Receives incoming updates and request responses from the TDLib client. May be called from any thread, but
|
|
|
|
* must not be called simultaneously from two different threads.
|
|
|
|
* Returned pointer will be deallocated by TDLib during next call to td_json_client_receive or td_json_client_execute
|
|
|
|
* in the same thread, so it can't be used after that.
|
|
|
|
* \param[in] client The client.
|
|
|
|
* \param[in] timeout The maximum number of seconds allowed for this function to wait for new data.
|
|
|
|
* \return JSON-serialized null-terminated incoming update or request response. May be NULL if the timeout expires.
|
|
|
|
*/
|
|
|
|
TDJSON_EXPORT const char *td_json_client_receive(void *client, double timeout);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Synchronously executes TDLib request. May be called from any thread.
|
|
|
|
* Only a few requests can be executed synchronously.
|
|
|
|
* Returned pointer will be deallocated by TDLib during next call to td_json_client_receive or td_json_client_execute
|
|
|
|
* in the same thread, so it can't be used after that.
|
|
|
|
* \param[in] client The client. Currently ignored for all requests, so NULL can be passed.
|
|
|
|
* \param[in] request JSON-serialized null-terminated request to TDLib.
|
|
|
|
* \return JSON-serialized null-terminated request response.
|
|
|
|
*/
|
|
|
|
TDJSON_EXPORT const char *td_json_client_execute(void *client, const char *request);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Destroys the TDLib client instance. After this is called the client instance must not be used anymore.
|
|
|
|
* \param[in] client The client.
|
|
|
|
*/
|
|
|
|
TDJSON_EXPORT void td_json_client_destroy(void *client);
|
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
#ifdef __cplusplus
|
|
|
|
} // extern "C"
|
|
|
|
#endif
|