Commit faaea75e authored by Vincent Castellano's avatar Vincent Castellano

Protect against Py_DECREFing nulls. Add datetime support

parent 66aa288b
...@@ -30,6 +30,8 @@ def on_msg_receive(msg): ...@@ -30,6 +30,8 @@ def on_msg_receive(msg):
ptype = msg["to"]["type"] ptype = msg["to"]["type"]
pid = msg["to"]["id"] pid = msg["to"]["id"]
pp.pprint(msg)
text = msg["text"] text = msg["text"]
if text.startswith("!ping"): if text.startswith("!ping"):
......
...@@ -38,6 +38,9 @@ ...@@ -38,6 +38,9 @@
#include "event-old.h" #include "event-old.h"
#endif #endif
// Python Imports
#include "datetime.h"
//#include "interface.h" //#include "interface.h"
//#include "auto/constants.h" //#include "auto/constants.h"
#include <tgl/tgl.h> #include <tgl/tgl.h>
...@@ -47,6 +50,7 @@ ...@@ -47,6 +50,7 @@
extern int verbosity; extern int verbosity;
extern struct tgl_state *TLS; extern struct tgl_state *TLS;
static int python_loaded; static int python_loaded;
// Python update function callables // Python update function callables
...@@ -61,6 +65,12 @@ PyObject *_py_chat_update; ...@@ -61,6 +65,12 @@ PyObject *_py_chat_update;
PyObject* get_user (tgl_peer_t *P); PyObject* get_user (tgl_peer_t *P);
PyObject* get_peer (tgl_peer_id_t id, tgl_peer_t *P); PyObject* get_peer (tgl_peer_id_t id, tgl_peer_t *P);
// Utility functions
PyObject* get_datetime(long datetime)
{
return PyDateTime_FromTimestamp(Py_BuildValue("(O)", PyLong_FromLong(datetime)));
}
void py_add_string_field (PyObject* dict, char *name, const char *value) { void py_add_string_field (PyObject* dict, char *name, const char *value) {
assert (PyDict_Check(dict)); assert (PyDict_Check(dict));
assert (name && strlen (name)); assert (name && strlen (name));
...@@ -340,7 +350,7 @@ PyObject* get_message (struct tgl_message *M) { ...@@ -340,7 +350,7 @@ PyObject* get_message (struct tgl_message *M) {
if (tgl_get_peer_type (M->fwd_from_id)) { if (tgl_get_peer_type (M->fwd_from_id)) {
PyDict_SetItemString(msg, "fwd_from", get_peer(M->fwd_from_id, tgl_peer_get (TLS, M->fwd_from_id))); PyDict_SetItemString(msg, "fwd_from", get_peer(M->fwd_from_id, tgl_peer_get (TLS, M->fwd_from_id)));
py_add_num_field (msg, "fwd_date", M->fwd_date); PyDict_SetItemString (msg, "fwd_date", get_datetime(M->fwd_date));
} }
PyDict_SetItemString(msg, "from", get_peer(M->from_id, tgl_peer_get (TLS, M->from_id))); PyDict_SetItemString(msg, "from", get_peer(M->from_id, tgl_peer_get (TLS, M->from_id)));
...@@ -348,7 +358,7 @@ PyObject* get_message (struct tgl_message *M) { ...@@ -348,7 +358,7 @@ PyObject* get_message (struct tgl_message *M) {
PyDict_SetItemString(msg, "out", (M->out ? Py_True : Py_False)); PyDict_SetItemString(msg, "out", (M->out ? Py_True : Py_False));
PyDict_SetItemString(msg, "unread", (M->unread ? Py_True : Py_False)); PyDict_SetItemString(msg, "unread", (M->unread ? Py_True : Py_False));
PyDict_SetItemString(msg, "service", (M->service ? Py_True : Py_False)); PyDict_SetItemString(msg, "service", (M->service ? Py_True : Py_False));
PyDict_SetItemString(msg, "date", PyLong_FromLong(M->date)); // TODO put this into PyDate object PyDict_SetItemString(msg, "date", get_datetime(M->date));
if (!M->service) { if (!M->service) {
if (M->message_len && M->message) { if (M->message_len && M->message) {
...@@ -374,7 +384,7 @@ void py_binlog_end (void) { ...@@ -374,7 +384,7 @@ void py_binlog_end (void) {
else if(PyString_Check(result)) else if(PyString_Check(result))
logprintf ("python: %s\n", PyString_AsString(result)); logprintf ("python: %s\n", PyString_AsString(result));
Py_DECREF(result); Py_XDECREF(result);
} }
void py_diff_end (void) { void py_diff_end (void) {
...@@ -389,7 +399,7 @@ void py_diff_end (void) { ...@@ -389,7 +399,7 @@ void py_diff_end (void) {
else if(PyString_Check(result)) else if(PyString_Check(result))
logprintf ("python: %s\n", PyString_AsString(result)); logprintf ("python: %s\n", PyString_AsString(result));
Py_DECREF(result); Py_XDECREF(result);
} }
void py_our_id (int id) { void py_our_id (int id) {
...@@ -404,7 +414,7 @@ void py_our_id (int id) { ...@@ -404,7 +414,7 @@ void py_our_id (int id) {
else if(PyString_Check(result)) else if(PyString_Check(result))
logprintf ("python: %s\n", PyString_AsString(result)); logprintf ("python: %s\n", PyString_AsString(result));
Py_DECREF(result); Py_XDECREF(result);
} }
void py_new_msg (struct tgl_message *M) { void py_new_msg (struct tgl_message *M) {
...@@ -423,7 +433,7 @@ void py_new_msg (struct tgl_message *M) { ...@@ -423,7 +433,7 @@ void py_new_msg (struct tgl_message *M) {
else if(PyString_Check(result)) else if(PyString_Check(result))
logprintf ("python: %s\n", PyString_AsString(result)); logprintf ("python: %s\n", PyString_AsString(result));
Py_DECREF(result); Py_XDECREF(result);
} }
void py_secret_chat_update (struct tgl_secret_chat *C, unsigned flags) { void py_secret_chat_update (struct tgl_secret_chat *C, unsigned flags) {
...@@ -443,7 +453,7 @@ void py_secret_chat_update (struct tgl_secret_chat *C, unsigned flags) { ...@@ -443,7 +453,7 @@ void py_secret_chat_update (struct tgl_secret_chat *C, unsigned flags) {
else if(PyString_Check(result)) else if(PyString_Check(result))
logprintf ("python: %s\n", PyString_AsString(result)); logprintf ("python: %s\n", PyString_AsString(result));
Py_DECREF(result); Py_XDECREF(result);
} }
...@@ -464,7 +474,7 @@ void py_user_update (struct tgl_user *U, unsigned flags) { ...@@ -464,7 +474,7 @@ void py_user_update (struct tgl_user *U, unsigned flags) {
else if(PyString_Check(result)) else if(PyString_Check(result))
logprintf ("python: %s\n", PyString_AsString(result)); logprintf ("python: %s\n", PyString_AsString(result));
Py_DECREF(result); Py_XDECREF(result);
} }
void py_chat_update (struct tgl_chat *C, unsigned flags) { void py_chat_update (struct tgl_chat *C, unsigned flags) {
...@@ -485,7 +495,7 @@ void py_chat_update (struct tgl_chat *C, unsigned flags) { ...@@ -485,7 +495,7 @@ void py_chat_update (struct tgl_chat *C, unsigned flags) {
else if(PyString_Check(result)) else if(PyString_Check(result))
logprintf ("python: %s\n", PyString_AsString(result)); logprintf ("python: %s\n", PyString_AsString(result));
Py_DECREF(result); Py_XDECREF(result);
} }
////extern tgl_peer_t *Peers[]; ////extern tgl_peer_t *Peers[];
...@@ -1306,6 +1316,7 @@ void py_init (const char *file) { ...@@ -1306,6 +1316,7 @@ void py_init (const char *file) {
exit(1); exit(1);
} else { } else {
python_loaded = 1; python_loaded = 1;
PyDateTime_IMPORT;
pDict = PyModule_GetDict(pModule); pDict = PyModule_GetDict(pModule);
// Store callables for python functions // Store callables for python functions
......
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