summaryrefslogtreecommitdiff
path: root/protocols/Telegram/tgl/tgl.c
diff options
context:
space:
mode:
authorKirill Volinsky <mataes2007@gmail.com>2016-03-07 22:07:50 +0000
committerKirill Volinsky <mataes2007@gmail.com>2016-03-07 22:07:50 +0000
commit90cc15799fe189134d9580c1dc121d0b78df17ba (patch)
tree32ea2068c77c2e224d743479408818315931f64b /protocols/Telegram/tgl/tgl.c
parent33f7eca09be79fb9f1d1933f198b5ec60e465cd7 (diff)
tgl.lib first compile version. Only release x86
git-svn-id: http://svn.miranda-ng.org/main/trunk@16445 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'protocols/Telegram/tgl/tgl.c')
-rw-r--r--protocols/Telegram/tgl/tgl.c149
1 files changed, 149 insertions, 0 deletions
diff --git a/protocols/Telegram/tgl/tgl.c b/protocols/Telegram/tgl/tgl.c
new file mode 100644
index 0000000000..dd4f2713c9
--- /dev/null
+++ b/protocols/Telegram/tgl/tgl.c
@@ -0,0 +1,149 @@
+/*
+ This file is part of tgl-library
+
+ This library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ This library 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
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with this library; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+
+ Copyright Vitaly Valtman 2014-2015
+*/
+
+#ifdef HAVE_CONFIG_H
+#include "config.h"
+#endif
+
+#include "tgl.h"
+#include "tools.h"
+#include "mtproto-client.h"
+#include "tgl-structures.h"
+//#include "net.h"
+
+#include <assert.h>
+
+struct tgl_state tgl_state;
+
+
+void tgl_set_binlog_mode (struct tgl_state *TLS, int mode) {
+ TLS->binlog_enabled = mode;
+}
+
+void tgl_set_binlog_path (struct tgl_state *TLS, const char *path) {
+ TLS->binlog_name = tstrdup (path);
+}
+
+void tgl_set_auth_file_path (struct tgl_state *TLS, const char *path) {
+ TLS->auth_file = tstrdup (path);
+}
+
+void tgl_set_download_directory (struct tgl_state *TLS, const char *path) {
+ TLS->downloads_directory = tstrdup (path);
+}
+
+void tgl_set_callback (struct tgl_state *TLS, struct tgl_update_callback *cb) {
+ TLS->callback = *cb;
+}
+
+void tgl_set_rsa_key (struct tgl_state *TLS, const char *key) {
+ assert (TLS->rsa_key_num < TGL_MAX_RSA_KEYS_NUM);
+ TLS->rsa_key_list[TLS->rsa_key_num ++] = tstrdup (key);
+}
+
+void tgl_init (struct tgl_state *TLS) {
+ assert (TLS->timer_methods);
+ assert (TLS->net_methods);
+ if (!TLS->callback.create_print_name) {
+ TLS->callback.create_print_name = tgls_default_create_print_name;
+ }
+ if (!TLS->temp_key_expire_time) {
+ TLS->temp_key_expire_time = 100000;
+ }
+
+ TLS->message_list.next_use = &TLS->message_list;
+ TLS->message_list.prev_use = &TLS->message_list;
+
+ tglmp_on_start (TLS);
+
+ if (!TLS->app_id) {
+ TLS->app_id = TG_APP_ID;
+ TLS->app_hash = tstrdup (TG_APP_HASH);
+ }
+}
+
+int tgl_authorized_dc (struct tgl_state *TLS, struct tgl_dc *DC) {
+ assert (DC);
+ return (DC->flags & 4) != 0;//DC->auth_key_id;
+}
+
+int tgl_signed_dc (struct tgl_state *TLS, struct tgl_dc *DC) {
+ assert (DC);
+ return (DC->flags & TGLDCF_LOGGED_IN) != 0;
+}
+
+void tgl_register_app_id (struct tgl_state *TLS, int app_id, const char *app_hash) {
+ TLS->app_id = app_id;
+ TLS->app_hash = tstrdup (app_hash);
+}
+
+struct tgl_state *tgl_state_alloc (void) {
+ struct tgl_state *TLS = (struct tgl_state *)malloc (sizeof (*TLS));
+ if (!TLS) { return NULL; }
+ memset (TLS, 0, sizeof (*TLS));
+ return TLS;
+}
+
+void tgl_incr_verbosity (struct tgl_state *TLS) {
+ TLS->verbosity ++;
+}
+
+void tgl_set_verbosity (struct tgl_state *TLS, int val) {
+ TLS->verbosity = val;
+}
+
+void tgl_enable_pfs (struct tgl_state *TLS) {
+ TLS->enable_pfs = 1;
+}
+
+void tgl_set_test_mode (struct tgl_state *TLS) {
+ TLS->test_mode ++;
+}
+
+void tgl_set_net_methods (struct tgl_state *TLS, struct tgl_net_methods *methods) {
+ TLS->net_methods = methods;
+}
+
+void tgl_set_timer_methods (struct tgl_state *TLS, struct tgl_timer_methods *methods) {
+ TLS->timer_methods = methods;
+}
+
+void tgl_set_ev_base (struct tgl_state *TLS, void *ev_base) {
+ TLS->ev_base = ev_base;
+}
+
+void tgl_set_app_version (struct tgl_state *TLS, const char *app_version) {
+ if (TLS->app_version) {
+ tfree_str (TLS->app_version);
+ }
+ TLS->app_version = tstrdup (app_version);
+}
+
+void tgl_enable_ipv6 (struct tgl_state *TLS) {
+ TLS->ipv6_enabled = 1;
+}
+
+void tgl_disable_link_preview (struct tgl_state *TLS) {
+ TLS->disable_link_preview = 1;
+}
+
+void tgl_enable_bot (struct tgl_state *TLS) {
+ TLS->is_bot = 1;
+}