Commit 2ab3feb3 authored by Vincent Castellano's avatar Vincent Castellano

Added get_history and get_history_ex to python bindings

parent 871fc440
...@@ -615,6 +615,7 @@ enum py_query_type { ...@@ -615,6 +615,7 @@ enum py_query_type {
pq_chat_info, pq_chat_info,
pq_user_info, pq_user_info,
pq_history, pq_history,
pq_history_ext,
pq_chat_add_user, pq_chat_add_user,
pq_chat_del_user, pq_chat_del_user,
pq_add_contact, pq_add_contact,
...@@ -937,7 +938,7 @@ void py_do_all (void) { ...@@ -937,7 +938,7 @@ void py_do_all (void) {
const char *str; const char *str;
int len; int len, limit, offset;
PyObject *pyObj1 = NULL; PyObject *pyObj1 = NULL;
PyObject *pyObj2 = NULL; PyObject *pyObj2 = NULL;
PyObject *cb_extra; PyObject *cb_extra;
...@@ -1006,7 +1007,7 @@ void py_do_all (void) { ...@@ -1006,7 +1007,7 @@ void py_do_all (void) {
if (!M || (M->media.type != tgl_message_media_photo && M->media.type != tgl_message_media_photo_encr && M->media.type != tgl_message_media_document && M->media.type != tgl_message_media_document_encr)) { if (!M || (M->media.type != tgl_message_media_photo && M->media.type != tgl_message_media_photo_encr && M->media.type != tgl_message_media_document && M->media.type != tgl_message_media_document_encr)) {
py_file_cb (TLS, py_ptr[p], 0, 0); py_file_cb (TLS, py_ptr[p], 0, 0);
} else { } else {
if (M->media.type == tgl_message_media_photo) { , limit, offse, limit, offsettif (M->media.type == tgl_message_media_photo) {
tgl_do_load_photo (TLS, &M->media.photo, py_file_cb, py_ptr[p]); tgl_do_load_photo (TLS, &M->media.photo, py_file_cb, py_ptr[p]);
} else if (M->media.type == tgl_message_media_document) { } else if (M->media.type == tgl_message_media_document) {
tgl_do_load_document (TLS, &M->media.document, py_file_cb, py_ptr[p]); tgl_do_load_document (TLS, &M->media.document, py_file_cb, py_ptr[p]);
...@@ -1036,10 +1037,15 @@ void py_do_all (void) { ...@@ -1036,10 +1037,15 @@ void py_do_all (void) {
case pq_user_info: case pq_user_info:
tgl_do_get_user_info (TLS, ((tgl_peer_t *)py_ptr[p + 1])->id, 0, py_user_cb, py_ptr[p]); tgl_do_get_user_info (TLS, ((tgl_peer_t *)py_ptr[p + 1])->id, 0, py_user_cb, py_ptr[p]);
break; break;
*/
case pq_history: case pq_history:
tgl_do_get_history (TLS, ((tgl_peer_t *)py_ptr[p + 1])->id, (long)py_ptr[p + 2], 0, py_msg_list_cb, py_ptr[p]); PyArg_ParseTuple(args, "iiiO", &peer.type, &peer.id, &limit, &cb_extra);
tgl_do_get_history (TLS, peer, limit, 0, py_msg_list_cb, cb_extra);
break;
case pq_history_ext:
PyArg_ParseTuple(args, "iiiiO", &peer.type, &peer.id, &offset, &limit, &cb_extra);
tgl_do_get_history_ext (TLS, peer, offset, limit, 0, py_msg_list_cb, cb_extra);
break; break;
*/
case pq_chat_add_user: case pq_chat_add_user:
PyArg_ParseTuple(args, "iiiiO", &peer.type, &peer.id, &peer1.type, &peer1.id, &cb_extra); PyArg_ParseTuple(args, "iiiiO", &peer.type, &peer.id, &peer1.type, &peer1.id, &cb_extra);
tgl_do_add_user_to_chat (TLS, peer, peer1, 100, py_msg_cb, cb_extra); tgl_do_add_user_to_chat (TLS, peer, peer1, 100, py_msg_cb, cb_extra);
...@@ -1174,6 +1180,7 @@ PyObject* py_fwd_media(PyObject *self, PyObject *args) { return push_py_func(pq_ ...@@ -1174,6 +1180,7 @@ PyObject* py_fwd_media(PyObject *self, PyObject *args) { return push_py_func(pq_
PyObject* py_chat_info(PyObject *self, PyObject *args) { return push_py_func(pq_chat_info, args); } PyObject* py_chat_info(PyObject *self, PyObject *args) { return push_py_func(pq_chat_info, args); }
PyObject* py_user_info(PyObject *self, PyObject *args) { return push_py_func(pq_chat_info, args); } PyObject* py_user_info(PyObject *self, PyObject *args) { return push_py_func(pq_chat_info, args); }
PyObject* py_history(PyObject *self, PyObject *args) { return push_py_func(pq_history, args); } PyObject* py_history(PyObject *self, PyObject *args) { return push_py_func(pq_history, args); }
PyObject* py_history_ext(PyObject *self, PyObject *args) { return push_py_func(pq_history_ext, args); }
PyObject* py_chat_add_user(PyObject *self, PyObject *args) { return push_py_func(pq_chat_add_user, args); } PyObject* py_chat_add_user(PyObject *self, PyObject *args) { return push_py_func(pq_chat_add_user, args); }
PyObject* py_chat_del_user(PyObject *self, PyObject *args) { return push_py_func(pq_chat_del_user, args); } PyObject* py_chat_del_user(PyObject *self, PyObject *args) { return push_py_func(pq_chat_del_user, args); }
PyObject* py_add_contact(PyObject *self, PyObject *args) { return push_py_func(pq_add_contact, args); } PyObject* py_add_contact(PyObject *self, PyObject *args) { return push_py_func(pq_add_contact, args); }
...@@ -1230,6 +1237,7 @@ static PyMethodDef py_tgl_methods[] = { ...@@ -1230,6 +1237,7 @@ static PyMethodDef py_tgl_methods[] = {
{"chat_info", py_chat_info, METH_VARARGS, ""}, {"chat_info", py_chat_info, METH_VARARGS, ""},
{"user_info", py_user_info, METH_VARARGS, ""}, {"user_info", py_user_info, METH_VARARGS, ""},
{"get_history", py_history, METH_VARARGS, ""}, {"get_history", py_history, METH_VARARGS, ""},
{"get_history_ext", py_history_ext, METH_VARARGS, ""},
{"chat_add_user", py_chat_add_user, METH_VARARGS, ""}, {"chat_add_user", py_chat_add_user, METH_VARARGS, ""},
{"chat_del_user", py_chat_del_user, METH_VARARGS, ""}, {"chat_del_user", py_chat_del_user, METH_VARARGS, ""},
{"add_contact", py_add_contact, METH_VARARGS, ""}, {"add_contact", py_add_contact, METH_VARARGS, ""},
...@@ -1272,13 +1280,14 @@ MOD_INIT(tgl) ...@@ -1272,13 +1280,14 @@ MOD_INIT(tgl)
return MOD_SUCCESS_VAL(m); return MOD_SUCCESS_VAL(m);
} }
/*
extern int safe_quit; extern int safe_quit;
static int safe_quit_from_py() { static int safe_quit_from_py() {
Py_Finalize(); Py_Finalize();
safe_quit = 1; safe_quit = 1;
return 1; return 1;
} }
*/
void py_init (const char *file) { void py_init (const char *file) {
if (!file) { return; } if (!file) { return; }
......
import tgl import tgl
import pprint import pprint
from functools import partial
our_id = 0 our_id = 0
pp = pprint.PrettyPrinter(indent=4) pp = pprint.PrettyPrinter(indent=4)
...@@ -20,6 +22,15 @@ def msg_cb(success, msg): ...@@ -20,6 +22,15 @@ def msg_cb(success, msg):
pp.pprint(success) pp.pprint(success)
pp.pprint(msg) pp.pprint(msg)
HISTORY_QUERY_SIZE = 100
def history_cb(msg_list, ptype, pid, success, msgs):
print(len(msgs))
msg_list.extend(msgs)
print(len(msg_list))
if len(msgs) == HISTORY_QUERY_SIZE:
tgl.get_history_ext(ptype, pid, len(msg_list), HISTORY_QUERY_SIZE, partial(history_cb, msg_list, ptype, pid));
def on_msg_receive(msg): def on_msg_receive(msg):
if msg["out"] and not binlog_done: if msg["out"] and not binlog_done:
return; return;
...@@ -39,6 +50,10 @@ def on_msg_receive(msg): ...@@ -39,6 +50,10 @@ def on_msg_receive(msg):
print("SENDING PONG") print("SENDING PONG")
tgl.send_msg(ptype, pid, "PONG!", msg_cb) tgl.send_msg(ptype, pid, "PONG!", msg_cb)
if text.startswith("!loadhistory"):
msg_list = []
tgl.get_history_ext(ptype, pid, 0, HISTORY_QUERY_SIZE, partial(history_cb, msg_list, ptype, pid));
def on_secret_chat_update(peer, types): def on_secret_chat_update(peer, types):
return "on_secret_chat_update" return "on_secret_chat_update"
...@@ -48,7 +63,6 @@ def on_user_update(): ...@@ -48,7 +63,6 @@ def on_user_update():
def on_chat_update(): def on_chat_update():
pass pass
# Set callbacks # Set callbacks
tgl.set_on_binlog_replay_end(on_binlog_replay_end) tgl.set_on_binlog_replay_end(on_binlog_replay_end)
tgl.set_on_get_difference_end(on_get_difference_end) tgl.set_on_get_difference_end(on_get_difference_end)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment