mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Merge pull request #1915 from profanity-im/fix-db-string-ops
Handle potential NULL pointers in database
This commit is contained in:
commit
6d17b4eeb5
@ -63,10 +63,16 @@ static int _get_db_version(void);
|
|||||||
static gboolean _migrate_to_v2(void);
|
static gboolean _migrate_to_v2(void);
|
||||||
static gboolean _check_available_space_for_db_migration(char* path_to_db);
|
static gboolean _check_available_space_for_db_migration(char* path_to_db);
|
||||||
|
|
||||||
#define auto_sqlite __attribute__((__cleanup__(auto_free_sqlite)))
|
|
||||||
|
|
||||||
static const int latest_version = 2;
|
static const int latest_version = 2;
|
||||||
|
|
||||||
|
static char*
|
||||||
|
_db_strdup(const char* str)
|
||||||
|
{
|
||||||
|
return str ? strdup(str) : NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define auto_sqlite __attribute__((__cleanup__(auto_free_sqlite)))
|
||||||
|
|
||||||
static void
|
static void
|
||||||
auto_free_sqlite(gchar** str)
|
auto_free_sqlite(gchar** str)
|
||||||
{
|
{
|
||||||
@ -240,10 +246,10 @@ _log_database_add_outgoing(char* type, const char* const id, const char* const b
|
|||||||
{
|
{
|
||||||
ProfMessage* msg = message_init();
|
ProfMessage* msg = message_init();
|
||||||
|
|
||||||
msg->id = id ? strdup(id) : NULL;
|
msg->id = _db_strdup(id);
|
||||||
msg->from_jid = jid_create(barejid);
|
msg->from_jid = jid_create(barejid);
|
||||||
msg->plain = message ? strdup(message) : NULL;
|
msg->plain = _db_strdup(message);
|
||||||
msg->replace_id = replace_id ? strdup(replace_id) : NULL;
|
msg->replace_id = _db_strdup(replace_id);
|
||||||
msg->timestamp = g_date_time_new_now_local(); // TODO: get from outside. best to have whole ProfMessage from outside
|
msg->timestamp = g_date_time_new_now_local(); // TODO: get from outside. best to have whole ProfMessage from outside
|
||||||
msg->enc = enc;
|
msg->enc = enc;
|
||||||
|
|
||||||
@ -306,7 +312,7 @@ log_database_get_limits_info(const gchar* const contact_barejid, gboolean is_las
|
|||||||
char* archive_id = (char*)sqlite3_column_text(stmt, 0);
|
char* archive_id = (char*)sqlite3_column_text(stmt, 0);
|
||||||
char* date = (char*)sqlite3_column_text(stmt, 1);
|
char* date = (char*)sqlite3_column_text(stmt, 1);
|
||||||
|
|
||||||
msg->stanzaid = strdup(archive_id);
|
msg->stanzaid = _db_strdup(archive_id);
|
||||||
msg->timestamp = g_date_time_new_from_iso8601(date, NULL);
|
msg->timestamp = g_date_time_new_from_iso8601(date, NULL);
|
||||||
}
|
}
|
||||||
sqlite3_finalize(stmt);
|
sqlite3_finalize(stmt);
|
||||||
@ -369,7 +375,7 @@ log_database_get_previous_chat(const gchar* const contact_barejid, const char* s
|
|||||||
ProfMessage* msg = message_init();
|
ProfMessage* msg = message_init();
|
||||||
msg->from_jid = jid_create(from);
|
msg->from_jid = jid_create(from);
|
||||||
msg->to_jid = jid_create(to_jid);
|
msg->to_jid = jid_create(to_jid);
|
||||||
msg->plain = strdup(message);
|
msg->plain = _db_strdup(message);
|
||||||
msg->timestamp = g_date_time_new_from_iso8601(date, NULL);
|
msg->timestamp = g_date_time_new_from_iso8601(date, NULL);
|
||||||
msg->type = _get_message_type_type(type);
|
msg->type = _get_message_type_type(type);
|
||||||
msg->enc = _get_message_enc_type(encryption);
|
msg->enc = _get_message_enc_type(encryption);
|
||||||
|
Loading…
Reference in New Issue
Block a user