Protect against Py_DECREFing nulls. Add datetime support
This commit is contained in:
parent
66aa288b3d
commit
faaea75eec
@ -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"):
|
||||||
|
31
python-tg.c
31
python-tg.c
@ -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 @@
|
|||||||
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;
|
|||||||
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) {
|
|||||||
|
|
||||||
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) {
|
|||||||
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) {
|
|||||||
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) {
|
|||||||
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) {
|
|||||||
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) {
|
|||||||
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) {
|
|||||||
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) {
|
|||||||
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) {
|
|||||||
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,8 +1316,9 @@ 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
|
||||||
my_python_register(pDict, "on_binlog_replay_end", _py_binlog_end);
|
my_python_register(pDict, "on_binlog_replay_end", _py_binlog_end);
|
||||||
my_python_register(pDict, "on_get_difference_end", _py_diff_end);
|
my_python_register(pDict, "on_get_difference_end", _py_diff_end);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user