2013-10-23 18:26:17 +04:00
|
|
|
/*
|
|
|
|
This file is part of telegram-client.
|
|
|
|
|
|
|
|
Telegram-client is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
Telegram-client is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this telegram-client. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
Copyright Vitaly Valtman 2013
|
|
|
|
*/
|
2013-10-12 00:52:20 +04:00
|
|
|
#include "net.h"
|
|
|
|
#ifndef __QUERIES_H__
|
|
|
|
#define __QUERIES_H__
|
2013-11-01 03:18:34 +04:00
|
|
|
#include "structures.h"
|
2014-08-12 09:59:59 +00:00
|
|
|
#include "auto.h"
|
2014-08-13 19:55:16 +04:00
|
|
|
#include "tgl-layout.h"
|
2013-10-12 00:52:20 +04:00
|
|
|
|
|
|
|
#define QUERY_ACK_RECEIVED 1
|
|
|
|
|
|
|
|
struct query;
|
|
|
|
struct query_methods {
|
|
|
|
int (*on_answer)(struct query *q);
|
|
|
|
int (*on_error)(struct query *q, int error_code, int len, char *error);
|
|
|
|
int (*on_timeout)(struct query *q);
|
2014-08-12 09:59:59 +00:00
|
|
|
struct paramed_type *type;
|
2013-10-12 00:52:20 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
struct event_timer {
|
|
|
|
double timeout;
|
|
|
|
int (*alarm)(void *self);
|
|
|
|
void *self;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct query {
|
|
|
|
long long msg_id;
|
|
|
|
int data_len;
|
|
|
|
int flags;
|
2013-10-25 02:32:13 +04:00
|
|
|
int seq_no;
|
2013-10-12 00:52:20 +04:00
|
|
|
void *data;
|
|
|
|
struct query_methods *methods;
|
|
|
|
struct event_timer ev;
|
2013-10-21 22:24:31 +04:00
|
|
|
struct dc *DC;
|
2013-10-25 02:32:13 +04:00
|
|
|
struct session *session;
|
2013-10-18 23:30:24 +04:00
|
|
|
void *extra;
|
2013-10-12 00:52:20 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-10-18 23:30:24 +04:00
|
|
|
struct query *send_query (struct dc *DC, int len, void *data, struct query_methods *methods, void *extra);
|
2013-10-12 00:52:20 +04:00
|
|
|
void query_ack (long long id);
|
|
|
|
void query_error (long long id);
|
|
|
|
void query_result (long long id);
|
2013-10-26 01:08:52 +04:00
|
|
|
void query_restart (long long id);
|
2013-10-12 00:52:20 +04:00
|
|
|
|
|
|
|
void insert_event_timer (struct event_timer *ev);
|
|
|
|
void remove_event_timer (struct event_timer *ev);
|
|
|
|
double next_timer_in (void);
|
|
|
|
void work_timers (void);
|
|
|
|
|
|
|
|
extern struct query_methods help_get_config_methods;
|
|
|
|
|
|
|
|
double get_double_time (void);
|
|
|
|
|
2013-11-13 04:11:25 +04:00
|
|
|
|
|
|
|
// For binlog
|
|
|
|
|
2013-11-15 04:08:24 +04:00
|
|
|
int get_dh_config_on_answer (struct query *q);
|
2013-11-13 04:11:25 +04:00
|
|
|
void fetch_dc_option (void);
|
2013-10-12 00:52:20 +04:00
|
|
|
#endif
|