Commit 7f2fc476 authored by Vincent Castellano's avatar Vincent Castellano

Migrate API to completely use new python objects.

parent fe030a69
This diff is collapsed.
...@@ -24,6 +24,7 @@ ...@@ -24,6 +24,7 @@
#include <Python.h> #include <Python.h>
#include <tgl/tgl.h> #include <tgl/tgl.h>
// Python functions
void py_init (const char *file); void py_init (const char *file);
void py_new_msg (struct tgl_message *M); void py_new_msg (struct tgl_message *M);
void py_our_id (int id); void py_our_id (int id);
...@@ -34,7 +35,54 @@ void py_binlog_end (void); ...@@ -34,7 +35,54 @@ void py_binlog_end (void);
void py_diff_end (void); void py_diff_end (void);
void py_do_all (void); void py_do_all (void);
// Binding functions
PyObject* py_contact_list(PyObject *self, PyObject *args);
PyObject* py_dialog_list(PyObject *self, PyObject *args);
PyObject* py_rename_chat(PyObject *self, PyObject *args);
PyObject* py_send_msg(PyObject *self, PyObject *args);
PyObject* py_send_typing(PyObject *self, PyObject *args);
PyObject* py_send_typing_abort(PyObject *self, PyObject *args);
PyObject* py_send_photo(PyObject *self, PyObject *args);
PyObject* py_send_video(PyObject *self, PyObject *args);
PyObject* py_send_audio(PyObject *self, PyObject *args);
PyObject* py_send_document(PyObject *self, PyObject *args);
PyObject* py_send_file(PyObject *self, PyObject *args);
PyObject* py_send_text(PyObject *self, PyObject *args);
PyObject* py_chat_set_photo(PyObject *self, PyObject *args);
PyObject* py_load_photo(PyObject *self, PyObject *args);
PyObject* py_load_video(PyObject *self, PyObject *args);
PyObject* py_load_video_thumb(PyObject *self, PyObject *args);
PyObject* py_load_audio(PyObject *self, PyObject *args);
PyObject* py_load_document(PyObject *self, PyObject *args);
PyObject* py_load_document_thumb(PyObject *self, PyObject *args);
PyObject* py_fwd(PyObject *self, PyObject *args);
PyObject* py_fwd_media(PyObject *self, PyObject *args);
PyObject* py_chat_info(PyObject *self, PyObject *args);
PyObject* py_user_info(PyObject *self, PyObject *args);
PyObject* py_history(PyObject *self, PyObject *args);
PyObject* py_chat_add_user(PyObject *self, PyObject *args);
PyObject* py_chat_del_user(PyObject *self, PyObject *args);
PyObject* py_add_contact(PyObject *self, PyObject *args);
PyObject* py_del_contact(PyObject *self, PyObject *args);
PyObject* py_rename_contact(PyObject *self, PyObject *args);
PyObject* py_search(PyObject *self, PyObject *args);
PyObject* py_global_search(PyObject *self, PyObject *args);
PyObject* py_mark_read(PyObject *self, PyObject *args);
PyObject* py_set_profile_photo(PyObject *self, PyObject *args);
PyObject* py_set_profile_name(PyObject *self, PyObject *args);
PyObject* py_create_secret_chat(PyObject *self, PyObject *args);
PyObject* py_create_group_chat(PyObject *self, PyObject *args);
PyObject* py_delete_msg(PyObject *self, PyObject *args);
PyObject* py_restore_msg(PyObject *self, PyObject *args);
PyObject* py_accept_secret_chat(PyObject *self, PyObject *args);
PyObject* py_send_contact(PyObject *self, PyObject *args);
PyObject* py_status_online(PyObject *self, PyObject *args);
PyObject* py_status_offline(PyObject *self, PyObject *args);
PyObject* py_send_location(PyObject *self, PyObject *args);
PyObject* py_extf(PyObject *self, PyObject *args);
// Util Functions
void py_add_string_field (PyObject* dict, char *name, const char *value); void py_add_string_field (PyObject* dict, char *name, const char *value);
void py_add_string_field_arr (PyObject* list, int num, const char *value); void py_add_string_field_arr (PyObject* list, int num, const char *value);
void py_add_num_field (PyObject* dict, const char *name, double value); void py_add_num_field (PyObject* dict, const char *name, double value);
......
...@@ -38,11 +38,13 @@ tgl_Peer_init(tgl_Peer *self, PyObject *args, PyObject *kwds) ...@@ -38,11 +38,13 @@ tgl_Peer_init(tgl_Peer *self, PyObject *args, PyObject *kwds)
{ {
static char *kwlist[] = {"type", "id", NULL}; static char *kwlist[] = {"type", "id", NULL};
tgl_peer_id_t peer_id; tgl_peer_id_t peer_id;
if(!PyArg_ParseTupleAndKeywords(args, kwds, "|ii", kwlist, if(!PyArg_ParseTupleAndKeywords(args, kwds, "ii", kwlist,
&peer_id.type, &peer_id.type,
&peer_id.id)) &peer_id.id))
{
PyErr_Format(PyErr_NewException("tgl.PeerInvalid", NULL, NULL), "Peer must specify type and id");
return -1; return -1;
}
self->peer = tgl_peer_get(TLS, peer_id); self->peer = tgl_peer_get(TLS, peer_id);
if(self->peer == NULL) if(self->peer == NULL)
return -1; return -1;
...@@ -66,7 +68,7 @@ tgl_Peer_getname (tgl_Peer *self, void *closure) ...@@ -66,7 +68,7 @@ tgl_Peer_getname (tgl_Peer *self, void *closure)
ret = PyUnicode_FromString(self->peer->encr_chat.print_name); ret = PyUnicode_FromString(self->peer->encr_chat.print_name);
break; break;
default: default:
PyErr_SetString(PyExc_TypeError, "peer.type not supported!"); PyErr_SetString(PyExc_TypeError, "peer.type_name not supported!");
Py_RETURN_NONE; Py_RETURN_NONE;
} }
...@@ -85,7 +87,7 @@ tgl_Peer_getuser_id (tgl_Peer *self, void *closure) ...@@ -85,7 +87,7 @@ tgl_Peer_getuser_id (tgl_Peer *self, void *closure)
ret = PyLong_FromLong(self->peer->id.id); ret = PyLong_FromLong(self->peer->id.id);
break; break;
case TGL_PEER_CHAT: case TGL_PEER_CHAT:
PyErr_SetString(PyExc_TypeError, "peer.type == TGL_PEER_CHAT has no user_id"); PyErr_SetString(PyExc_TypeError, "peer.type_name == 'chat' has no user_id");
Py_RETURN_NONE; Py_RETURN_NONE;
break; break;
...@@ -93,7 +95,7 @@ tgl_Peer_getuser_id (tgl_Peer *self, void *closure) ...@@ -93,7 +95,7 @@ tgl_Peer_getuser_id (tgl_Peer *self, void *closure)
ret = PyLong_FromLong(self->peer->encr_chat.user_id); ret = PyLong_FromLong(self->peer->encr_chat.user_id);
break; break;
default: default:
PyErr_SetString(PyExc_TypeError, "peer.type not supported!"); PyErr_SetString(PyExc_TypeError, "peer.type_name not supported!");
Py_RETURN_NONE; Py_RETURN_NONE;
} }
...@@ -120,11 +122,11 @@ tgl_Peer_getuser_list (tgl_Peer *self, void *closure) ...@@ -120,11 +122,11 @@ tgl_Peer_getuser_list (tgl_Peer *self, void *closure)
break; break;
case TGL_PEER_ENCR_CHAT: case TGL_PEER_ENCR_CHAT:
case TGL_PEER_USER: case TGL_PEER_USER:
PyErr_SetString(PyExc_TypeError, "Only peer.type == TGL_PEER_CHAT has user_list"); PyErr_SetString(PyExc_TypeError, "Only peer.type_name == 'chat' has user_list");
Py_RETURN_NONE; Py_RETURN_NONE;
break; break;
default: default:
PyErr_SetString(PyExc_TypeError, "peer.type not supported!"); PyErr_SetString(PyExc_TypeError, "peer.type_name not supported!");
Py_RETURN_NONE; Py_RETURN_NONE;
} }
...@@ -147,11 +149,11 @@ tgl_Peer_getuser_status(tgl_Peer *self, void *closure) ...@@ -147,11 +149,11 @@ tgl_Peer_getuser_status(tgl_Peer *self, void *closure)
break; break;
case TGL_PEER_CHAT: case TGL_PEER_CHAT:
case TGL_PEER_ENCR_CHAT: case TGL_PEER_ENCR_CHAT:
PyErr_SetString(PyExc_TypeError, "Only peer.type == TGL_PEER_USER has user_status"); PyErr_SetString(PyExc_TypeError, "Only peer.type_name == 'user' has user_status");
Py_RETURN_NONE; Py_RETURN_NONE;
break; break;
default: default:
PyErr_SetString(PyExc_TypeError, "peer.type not supported!"); PyErr_SetString(PyExc_TypeError, "peer.type_name not supported!");
Py_RETURN_NONE; Py_RETURN_NONE;
} }
...@@ -170,11 +172,11 @@ tgl_Peer_getphone (tgl_Peer *self, void *closure) ...@@ -170,11 +172,11 @@ tgl_Peer_getphone (tgl_Peer *self, void *closure)
break; break;
case TGL_PEER_CHAT: case TGL_PEER_CHAT:
case TGL_PEER_ENCR_CHAT: case TGL_PEER_ENCR_CHAT:
PyErr_SetString(PyExc_TypeError, "Only peer.type == TGL_PEER_USER has phone"); PyErr_SetString(PyExc_TypeError, "Only peer.type_name == 'user' has phone");
Py_RETURN_NONE; Py_RETURN_NONE;
break; break;
default: default:
PyErr_SetString(PyExc_TypeError, "peer.type not supported!"); PyErr_SetString(PyExc_TypeError, "peer.type_name not supported!");
Py_RETURN_NONE; Py_RETURN_NONE;
} }
...@@ -193,11 +195,34 @@ tgl_Peer_getusername (tgl_Peer *self, void *closure) ...@@ -193,11 +195,34 @@ tgl_Peer_getusername (tgl_Peer *self, void *closure)
break; break;
case TGL_PEER_CHAT: case TGL_PEER_CHAT:
case TGL_PEER_ENCR_CHAT: case TGL_PEER_ENCR_CHAT:
PyErr_SetString(PyExc_TypeError, "Only peer.type == TGL_PEER_USER has username"); PyErr_SetString(PyExc_TypeError, "Only peer.type_name == 'user' has username");
Py_RETURN_NONE;
break;
default:
PyErr_SetString(PyExc_TypeError, "peer.type_name not supported!");
Py_RETURN_NONE;
}
Py_XINCREF(ret);
return ret;
}
static PyObject *
tgl_Peer_getfirst_name (tgl_Peer *self, void *closure)
{
PyObject *ret;
switch(self->peer->id.type) {
case TGL_PEER_USER:
ret = PyUnicode_FromString(self->peer->user.first_name);
break;
case TGL_PEER_CHAT:
case TGL_PEER_ENCR_CHAT:
PyErr_SetString(PyExc_TypeError, "Only peer.type_name == 'user' has first_name");
Py_RETURN_NONE; Py_RETURN_NONE;
break; break;
default: default:
PyErr_SetString(PyExc_TypeError, "peer.type not supported!"); PyErr_SetString(PyExc_TypeError, "peer.type_name not supported!");
Py_RETURN_NONE; Py_RETURN_NONE;
} }
...@@ -205,6 +230,28 @@ tgl_Peer_getusername (tgl_Peer *self, void *closure) ...@@ -205,6 +230,28 @@ tgl_Peer_getusername (tgl_Peer *self, void *closure)
return ret; return ret;
} }
static PyObject *
tgl_Peer_getlast_name (tgl_Peer *self, void *closure)
{
PyObject *ret;
switch(self->peer->id.type) {
case TGL_PEER_USER:
ret = PyUnicode_FromString(self->peer->user.username);
break;
case TGL_PEER_CHAT:
case TGL_PEER_ENCR_CHAT:
PyErr_SetString(PyExc_TypeError, "Only peer.type_name == 'user' has last_name");
Py_RETURN_NONE;
break;
default:
PyErr_SetString(PyExc_TypeError, "peer.type_name not supported!");
Py_RETURN_NONE;
}
Py_XINCREF(ret);
return ret;
}
static PyObject * static PyObject *
tgl_Peer_getuser (tgl_Peer *self, void *closure) tgl_Peer_getuser (tgl_Peer *self, void *closure)
...@@ -216,12 +263,14 @@ tgl_Peer_getuser (tgl_Peer *self, void *closure) ...@@ -216,12 +263,14 @@ tgl_Peer_getuser (tgl_Peer *self, void *closure)
ret = tgl_Peer_FromTglPeer(tgl_peer_get(TLS, TGL_MK_USER (self->peer->encr_chat.user_id))); ret = tgl_Peer_FromTglPeer(tgl_peer_get(TLS, TGL_MK_USER (self->peer->encr_chat.user_id)));
break; break;
case TGL_PEER_USER: case TGL_PEER_USER:
ret = (PyObject*)self;
break;
case TGL_PEER_CHAT: case TGL_PEER_CHAT:
PyErr_SetString(PyExc_TypeError, "Only peer.type == TGL_PEER_ENCR_CHAT has user"); PyErr_SetString(PyExc_TypeError, "Only peer.type_name == 'chat' does not have user");
Py_RETURN_NONE; Py_RETURN_NONE;
break; break;
default: default:
PyErr_SetString(PyExc_TypeError, "peer.type not supported!"); PyErr_SetString(PyExc_TypeError, "peer.type_name not supported!");
Py_RETURN_NONE; Py_RETURN_NONE;
} }
...@@ -229,6 +278,27 @@ tgl_Peer_getuser (tgl_Peer *self, void *closure) ...@@ -229,6 +278,27 @@ tgl_Peer_getuser (tgl_Peer *self, void *closure)
return ret; return ret;
} }
static PyObject *
tgl_Peer_gettype_name(tgl_Peer* self)
{
PyObject *name;
switch(self->peer->id.type) {
case TGL_PEER_USER:
name = PyUnicode_FromString("user");
break;
case TGL_PEER_CHAT:
name = PyUnicode_FromString("chat");
break;
case TGL_PEER_ENCR_CHAT:
name = PyUnicode_FromString("secret_chat");
break;
default:
name = PyUnicode_FromString("unknown");
}
return name;
}
static PyObject * static PyObject *
tgl_Peer_getid (tgl_Peer *self, void *closure) tgl_Peer_getid (tgl_Peer *self, void *closure)
{ {
...@@ -254,6 +324,7 @@ tgl_Peer_gettype (tgl_Peer *self, void *closure) ...@@ -254,6 +324,7 @@ tgl_Peer_gettype (tgl_Peer *self, void *closure)
static PyGetSetDef tgl_Peer_getseters[] = { static PyGetSetDef tgl_Peer_getseters[] = {
{"id", (getter)tgl_Peer_getid, NULL, "", NULL}, {"id", (getter)tgl_Peer_getid, NULL, "", NULL},
{"type", (getter)tgl_Peer_gettype, NULL, "", NULL}, {"type", (getter)tgl_Peer_gettype, NULL, "", NULL},
{"type_name", (getter)tgl_Peer_gettype_name, NULL, "", NULL},
{"name", (getter)tgl_Peer_getname, NULL, "", NULL}, {"name", (getter)tgl_Peer_getname, NULL, "", NULL},
{"user_id", (getter)tgl_Peer_getuser_id, NULL, "", NULL}, {"user_id", (getter)tgl_Peer_getuser_id, NULL, "", NULL},
{"user", (getter)tgl_Peer_getuser, NULL, "", NULL}, {"user", (getter)tgl_Peer_getuser, NULL, "", NULL},
...@@ -261,6 +332,8 @@ static PyGetSetDef tgl_Peer_getseters[] = { ...@@ -261,6 +332,8 @@ static PyGetSetDef tgl_Peer_getseters[] = {
{"user_status", (getter)tgl_Peer_getuser_status, NULL, "", NULL}, {"user_status", (getter)tgl_Peer_getuser_status, NULL, "", NULL},
{"phone", (getter)tgl_Peer_getphone, NULL, "", NULL}, {"phone", (getter)tgl_Peer_getphone, NULL, "", NULL},
{"username", (getter)tgl_Peer_getusername, NULL, "", NULL}, {"username", (getter)tgl_Peer_getusername, NULL, "", NULL},
{"first_name", (getter)tgl_Peer_getfirst_name, NULL, "", NULL},
{"last_name", (getter)tgl_Peer_getlast_name, NULL, "", NULL},
{NULL} /* Sentinel */ {NULL} /* Sentinel */
}; };
...@@ -269,30 +342,36 @@ static PyMemberDef tgl_Peer_members[] = { ...@@ -269,30 +342,36 @@ static PyMemberDef tgl_Peer_members[] = {
}; };
static PyObject * static PyObject *
tgl_Peer_type_name(tgl_Peer* self) tgl_Peer_send_msg (tgl_Peer *self, PyObject *args, PyObject *kwargs)
{ {
PyObject *name; static char *kwlist[] = {"message", "callback", NULL};
switch(self->peer->id.type) { char *message;
case TGL_PEER_USER: PyObject *callback = NULL;
name = PyUnicode_FromString("user");
break; if(PyArg_ParseTupleAndKeywords(args, kwargs, "s|O", kwlist, &message, &callback)) {
case TGL_PEER_CHAT: PyObject *api_call;
name = PyUnicode_FromString("chat");
break; if(callback)
case TGL_PEER_ENCR_CHAT: api_call = Py_BuildValue("OsO", (PyObject*) self, message, callback);
name = PyUnicode_FromString("encr_chat"); else
break; api_call = Py_BuildValue("Os", (PyObject*) self, message);
default:
name = PyUnicode_FromString("unknown"); Py_XINCREF(Py_None);
Py_XINCREF(api_call);
return py_send_msg(Py_None, api_call);
} else {
Py_XINCREF(Py_False);
return Py_False;
} }
return name;
} }
static PyMethodDef tgl_Peer_methods[] = { static PyMethodDef tgl_Peer_methods[] = {
{"type_name", (PyCFunction)tgl_Peer_type_name, METH_NOARGS, {"send_msg", (PyCFunction)tgl_Peer_send_msg, METH_VARARGS | METH_KEYWORDS,
"Return the string representation of the peer type." "Send a message to peer object"},
},
{NULL} /* Sentinel */ {NULL} /* Sentinel */
}; };
......
...@@ -31,11 +31,13 @@ def history_cb(msg_list, ptype, pid, success, msgs): ...@@ -31,11 +31,13 @@ def history_cb(msg_list, ptype, pid, success, msgs):
if len(msgs) == HISTORY_QUERY_SIZE: if len(msgs) == HISTORY_QUERY_SIZE:
tgl.get_history(ptype, pid, len(msg_list), HISTORY_QUERY_SIZE, partial(history_cb, msg_list, ptype, pid)); tgl.get_history(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;
tgl.send_msg(tgl.Peer(97704886), "Test")
print("From: {0}, To: {1}".format(msg.src.id, msg.dest.user)) print("Peers {0}".format(msg.src.id))
""" """
def on_msg_receive(msg): def on_msg_receive(msg):
......
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