2013-10-23 10: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-11 16:52:20 -04:00
|
|
|
#include "net.h"
|
|
|
|
#ifndef __QUERIES_H__
|
|
|
|
#define __QUERIES_H__
|
2013-10-31 19:18:34 -04:00
|
|
|
#include "structures.h"
|
2014-08-12 05:59:59 -04:00
|
|
|
#include "auto.h"
|
2014-08-13 11:55:16 -04:00
|
|
|
#include "tgl-layout.h"
|
2013-10-11 16: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 05:59:59 -04:00
|
|
|
struct paramed_type *type;
|
2013-10-11 16: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-24 18:32:13 -04:00
|
|
|
int seq_no;
|
2013-10-11 16:52:20 -04:00
|
|
|
void *data;
|
|
|
|
struct query_methods *methods;
|
|
|
|
struct event_timer ev;
|
2013-10-21 14:24:31 -04:00
|
|
|
struct dc *DC;
|
2013-10-24 18:32:13 -04:00
|
|
|
struct session *session;
|
2013-10-18 15:30:24 -04:00
|
|
|
void *extra;
|
2014-08-13 21:31:24 -04:00
|
|
|
void *callback;
|
|
|
|
void *callback_extra;
|
2013-10-11 16:52:20 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2014-08-13 21:31:24 -04:00
|
|
|
struct query *send_query (struct dc *DC, int len, void *data, struct query_methods *methods, void *extra, void *callback, void *callback_extra);
|
2013-10-11 16:52:20 -04:00
|
|
|
void query_ack (long long id);
|
|
|
|
void query_error (long long id);
|
|
|
|
void query_result (long long id);
|
2013-10-25 17:08:52 -04:00
|
|
|
void query_restart (long long id);
|
2013-10-11 16: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);
|
|
|
|
|
2014-08-13 21:31:24 -04:00
|
|
|
//extern struct query_methods help_get_config_methods;
|
2013-10-11 16:52:20 -04:00
|
|
|
|
|
|
|
double get_double_time (void);
|
|
|
|
|
2013-11-12 19:11:25 -05:00
|
|
|
|
|
|
|
// For binlog
|
|
|
|
|
2014-08-13 21:31:24 -04:00
|
|
|
//int get_dh_config_on_answer (struct query *q);
|
|
|
|
//void fetch_dc_option (void);
|
2013-10-11 16:52:20 -04:00
|
|
|
#endif
|