mirror of
https://gitlab.linphone.org/BC/public/linphone-iphone.git
synced 2026-01-17 11:08:06 +00:00
379 lines
14 KiB
Objective-C
379 lines
14 KiB
Objective-C
/* ChatModel.m
|
|
*
|
|
* Copyright (C) 2012 Belledonne Comunications, Grenoble, France
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*/
|
|
|
|
#import "ChatModel.h"
|
|
#import "LinphoneManager.h"
|
|
|
|
@implementation ChatModel
|
|
|
|
@synthesize chatId;
|
|
@synthesize localContact;
|
|
@synthesize remoteContact;
|
|
@synthesize message;
|
|
@synthesize direction;
|
|
@synthesize time;
|
|
@synthesize read;
|
|
@synthesize state;
|
|
|
|
#pragma mark - Lifecycle Functions
|
|
|
|
- (id)initWithData:(sqlite3_stmt *)sqlStatement {
|
|
self = [super init];
|
|
if (self != nil) {
|
|
self->chatId = [[NSNumber alloc] initWithInt: sqlite3_column_int(sqlStatement, 0)];
|
|
self.localContact = [NSString stringWithUTF8String: (const char*) sqlite3_column_text(sqlStatement, 1)];
|
|
self.remoteContact = [NSString stringWithUTF8String: (const char*) sqlite3_column_text(sqlStatement, 2)];
|
|
self.direction = [NSNumber numberWithInt:sqlite3_column_int(sqlStatement, 3)];
|
|
self.message = [NSString stringWithUTF8String: (const char*) sqlite3_column_text(sqlStatement, 4)];
|
|
self.time = [NSDate dateWithTimeIntervalSince1970:sqlite3_column_int(sqlStatement, 5)];
|
|
self.read = [NSNumber numberWithInt:sqlite3_column_int(sqlStatement, 6)];
|
|
self.state = [NSNumber numberWithInt:sqlite3_column_int(sqlStatement, 7)];
|
|
}
|
|
return self;
|
|
}
|
|
|
|
- (void)dealloc {
|
|
[chatId release];
|
|
[localContact release];
|
|
[remoteContact release];
|
|
[message release];
|
|
[direction release];
|
|
[time release];
|
|
[read release];
|
|
[state release];
|
|
[super dealloc];
|
|
}
|
|
|
|
|
|
- (BOOL)isExternalImage {
|
|
return [message hasPrefix:@"http:"] || [message hasPrefix:@"https:"];
|
|
}
|
|
|
|
- (BOOL)isInternalImage {
|
|
return [message hasPrefix:@"assets-library:"];
|
|
}
|
|
|
|
|
|
#pragma mark - CRUD Functions
|
|
|
|
- (void)create {
|
|
sqlite3* database = [[LinphoneManager instance] database];
|
|
if(database == NULL) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Database not ready"];
|
|
return;
|
|
}
|
|
|
|
const char *sql = "INSERT INTO chat (localContact, remoteContact, direction, message, time, read, state) VALUES (@LOCALCONTACT, @REMOTECONTACT, @DIRECTION, @MESSAGE, @TIME, @READ, @STATE)";
|
|
sqlite3_stmt *sqlStatement;
|
|
if (sqlite3_prepare_v2(database, sql, -1, &sqlStatement, NULL) != SQLITE_OK) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Can't prepare the query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
return;
|
|
}
|
|
|
|
// Prepare statement
|
|
sqlite3_bind_text(sqlStatement, 1, [localContact UTF8String], -1, SQLITE_STATIC);
|
|
sqlite3_bind_text(sqlStatement, 2, [remoteContact UTF8String], -1, SQLITE_STATIC);
|
|
sqlite3_bind_int(sqlStatement, 3, [direction intValue]);
|
|
sqlite3_bind_text(sqlStatement, 4, [message UTF8String], -1, SQLITE_STATIC);
|
|
sqlite3_bind_double(sqlStatement, 5, [time timeIntervalSince1970]);
|
|
sqlite3_bind_int(sqlStatement, 6, [read intValue]);
|
|
sqlite3_bind_int(sqlStatement, 7, [state intValue]);
|
|
|
|
if (sqlite3_step(sqlStatement) != SQLITE_DONE) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Error during execution of query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
sqlite3_finalize(sqlStatement);
|
|
}
|
|
|
|
if([self chatId] != nil) {
|
|
[chatId release];
|
|
}
|
|
chatId = [[NSNumber alloc] initWithInt:sqlite3_last_insert_rowid(database)];
|
|
sqlite3_finalize(sqlStatement);
|
|
}
|
|
|
|
+ (ChatModel*)read:(NSNumber*)chatId {
|
|
sqlite3* database = [[LinphoneManager instance] database];
|
|
if(database == NULL) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Database not ready"];
|
|
return nil;
|
|
}
|
|
|
|
const char *sql = "SELECT id, localContact, remoteContact, direction, message, time, read FROM chat WHERE id=@ID";
|
|
sqlite3_stmt *sqlStatement;
|
|
if (sqlite3_prepare_v2(database, sql, -1, &sqlStatement, NULL) != SQLITE_OK) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Can't prepare the query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
return nil;
|
|
}
|
|
|
|
// Prepare statement
|
|
sqlite3_bind_int(sqlStatement, 1, [chatId intValue]);
|
|
|
|
ChatModel* line = nil;
|
|
int err = sqlite3_step(sqlStatement);
|
|
if (err == SQLITE_ROW) {
|
|
line = [[[ChatModel alloc] initWithData:sqlStatement] autorelease];
|
|
} else if (err != SQLITE_DONE) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Error during execution of query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
sqlite3_finalize(sqlStatement);
|
|
return nil;
|
|
}
|
|
|
|
sqlite3_finalize(sqlStatement);
|
|
return line;
|
|
}
|
|
|
|
- (void)update {
|
|
sqlite3* database = [[LinphoneManager instance] database];
|
|
if(database == NULL) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Database not ready"];
|
|
return;
|
|
}
|
|
|
|
const char *sql = "UPDATE chat SET localContact=@LOCALCONTACT, remoteContact=@REMOTECONTACT, direction=@DIRECTION, message=@MESSAGE, time=@TIME, read=@READ, state=@STATE WHERE id=@ID";
|
|
sqlite3_stmt *sqlStatement;
|
|
if (sqlite3_prepare_v2(database, sql, -1, &sqlStatement, NULL) != SQLITE_OK) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Can't prepare the query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
return;
|
|
}
|
|
|
|
// Prepare statement
|
|
sqlite3_bind_text(sqlStatement, 1, [localContact UTF8String], -1, SQLITE_STATIC);
|
|
sqlite3_bind_text(sqlStatement, 2, [remoteContact UTF8String], -1, SQLITE_STATIC);
|
|
sqlite3_bind_int(sqlStatement, 3, [direction intValue]);
|
|
sqlite3_bind_text(sqlStatement, 4, [message UTF8String], -1, SQLITE_STATIC);
|
|
sqlite3_bind_double(sqlStatement, 5, [time timeIntervalSince1970]);
|
|
sqlite3_bind_int(sqlStatement, 6, [read intValue]);
|
|
sqlite3_bind_int(sqlStatement, 7, [state intValue]);
|
|
sqlite3_bind_int(sqlStatement, 8, [chatId intValue]);
|
|
|
|
if (sqlite3_step(sqlStatement) != SQLITE_DONE) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Error during execution of query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
sqlite3_finalize(sqlStatement);
|
|
return;
|
|
}
|
|
|
|
sqlite3_finalize(sqlStatement);
|
|
}
|
|
|
|
- (void)delete {
|
|
sqlite3* database = [[LinphoneManager instance] database];
|
|
if(database == NULL) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Database not ready"];
|
|
return;
|
|
}
|
|
|
|
const char *sql = "DELETE FROM chat WHERE id=@ID";
|
|
sqlite3_stmt *sqlStatement;
|
|
if (sqlite3_prepare_v2(database, sql, -1, &sqlStatement, NULL) != SQLITE_OK) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Can't prepare the query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
return;
|
|
}
|
|
|
|
// Prepare statement
|
|
sqlite3_bind_int(sqlStatement, 1, [chatId intValue]);
|
|
|
|
if (sqlite3_step(sqlStatement) != SQLITE_DONE) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Error during execution of query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
sqlite3_finalize(sqlStatement);
|
|
return;
|
|
}
|
|
|
|
sqlite3_finalize(sqlStatement);
|
|
}
|
|
|
|
|
|
#pragma mark -
|
|
|
|
+ (NSMutableArray *)listConversations {
|
|
NSMutableArray *array = [NSMutableArray array];
|
|
sqlite3* database = [[LinphoneManager instance] database];
|
|
if(database == NULL) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Database not ready"];
|
|
return array;
|
|
}
|
|
|
|
const char *sql = "SELECT id, localContact, remoteContact, direction, message, time, read, state FROM chat GROUP BY remoteContact ORDER BY time DESC";
|
|
sqlite3_stmt *sqlStatement;
|
|
if (sqlite3_prepare_v2(database, sql, -1, &sqlStatement, NULL) != SQLITE_OK) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Can't execute the query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
return array;
|
|
}
|
|
|
|
int err;
|
|
while ((err = sqlite3_step(sqlStatement)) == SQLITE_ROW) {
|
|
ChatModel *line = [[ChatModel alloc] initWithData:sqlStatement];
|
|
[array addObject:line];
|
|
[line release];
|
|
}
|
|
|
|
if (err != SQLITE_DONE) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Error during execution of query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
return array;
|
|
}
|
|
|
|
sqlite3_finalize(sqlStatement);
|
|
|
|
return array;
|
|
}
|
|
|
|
+ (NSMutableArray *)listMessages:(NSString *)contact {
|
|
NSMutableArray *array = [NSMutableArray array];
|
|
sqlite3* database = [[LinphoneManager instance] database];
|
|
if(database == NULL) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Database not ready"];
|
|
return array;
|
|
}
|
|
|
|
const char *sql = "SELECT id, localContact, remoteContact, direction, message, time, read, state FROM chat WHERE remoteContact=@REMOTECONTACT ORDER BY time ASC";
|
|
sqlite3_stmt *sqlStatement;
|
|
if (sqlite3_prepare_v2(database, sql, -1, &sqlStatement, NULL) != SQLITE_OK) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Can't execute the query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
return array;
|
|
}
|
|
|
|
// Prepare statement
|
|
sqlite3_bind_text(sqlStatement, 1, [contact UTF8String], -1, SQLITE_STATIC);
|
|
|
|
int err;
|
|
while ((err = sqlite3_step(sqlStatement)) == SQLITE_ROW) {
|
|
ChatModel *line = [[ChatModel alloc] initWithData:sqlStatement];
|
|
[array addObject:line];
|
|
[line release];
|
|
}
|
|
|
|
if (err != SQLITE_DONE) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Error during execution of query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
return array;
|
|
}
|
|
|
|
sqlite3_finalize(sqlStatement);
|
|
|
|
return array;
|
|
}
|
|
|
|
+ (void)removeConversation:(NSString *)contact {
|
|
sqlite3* database = [[LinphoneManager instance] database];
|
|
if(database == NULL) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Database not ready"];
|
|
return;
|
|
}
|
|
|
|
const char *sql = "DELETE FROM chat WHERE remoteContact=@REMOTECONTACT";
|
|
sqlite3_stmt *sqlStatement;
|
|
if (sqlite3_prepare_v2(database, sql, -1, &sqlStatement, NULL) != SQLITE_OK) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Can't prepare the query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
return;
|
|
}
|
|
|
|
// Prepare statement
|
|
sqlite3_bind_text(sqlStatement, 1, [contact UTF8String], -1, SQLITE_STATIC);
|
|
|
|
if (sqlite3_step(sqlStatement) != SQLITE_DONE) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Error during execution of query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
sqlite3_finalize(sqlStatement);
|
|
return;
|
|
}
|
|
|
|
sqlite3_finalize(sqlStatement);
|
|
}
|
|
|
|
+ (int)unreadMessages {
|
|
int count = -1;
|
|
sqlite3* database = [[LinphoneManager instance] database];
|
|
if(database == NULL) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Database not ready"];
|
|
return count;
|
|
}
|
|
|
|
const char *sql = "SELECT count(*) FROM chat WHERE read=0";
|
|
sqlite3_stmt *sqlStatement;
|
|
if (sqlite3_prepare_v2(database, sql, -1, &sqlStatement, NULL) != SQLITE_OK) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Can't prepare the query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
return count;
|
|
}
|
|
|
|
if (sqlite3_step(sqlStatement) != SQLITE_ROW) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Error during execution of query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
sqlite3_finalize(sqlStatement);
|
|
return count;
|
|
}
|
|
|
|
count = sqlite3_column_int(sqlStatement, 0);
|
|
|
|
sqlite3_finalize(sqlStatement);
|
|
return count;
|
|
}
|
|
|
|
+ (int)unreadMessages:(NSString *)contact {
|
|
int count = -1;
|
|
sqlite3* database = [[LinphoneManager instance] database];
|
|
if(database == NULL) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Database not ready"];
|
|
return count;
|
|
}
|
|
|
|
const char *sql = "SELECT count(*) FROM chat WHERE read=0 AND remoteContact=@REMOTECONTACT";
|
|
sqlite3_stmt *sqlStatement;
|
|
if (sqlite3_prepare_v2(database, sql, -1, &sqlStatement, NULL) != SQLITE_OK) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Can't prepare the query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
return count;
|
|
}
|
|
|
|
// Prepare statement
|
|
sqlite3_bind_text(sqlStatement, 1, [contact UTF8String], -1, SQLITE_STATIC);
|
|
|
|
if (sqlite3_step(sqlStatement) != SQLITE_ROW) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Error during execution of query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
sqlite3_finalize(sqlStatement);
|
|
return count;
|
|
}
|
|
|
|
count = sqlite3_column_int(sqlStatement, 0);
|
|
|
|
sqlite3_finalize(sqlStatement);
|
|
return count;
|
|
}
|
|
|
|
+ (void)readConversation:(NSString *)contact {
|
|
sqlite3* database = [[LinphoneManager instance] database];
|
|
if(database == NULL) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Database not ready"];
|
|
return;
|
|
}
|
|
|
|
const char *sql = "UPDATE chat SET read=1 WHERE remoteContact=@REMOTECONTACT";
|
|
sqlite3_stmt *sqlStatement;
|
|
if (sqlite3_prepare_v2(database, sql, -1, &sqlStatement, NULL) != SQLITE_OK) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Can't prepare the query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
return;
|
|
}
|
|
|
|
// Prepare statement
|
|
sqlite3_bind_text(sqlStatement, 1, [contact UTF8String], -1, SQLITE_STATIC);
|
|
|
|
if (sqlite3_step(sqlStatement) != SQLITE_DONE) {
|
|
[LinphoneLogger logc:LinphoneLoggerError format:"Error during execution of query: %s (%s)", sql, sqlite3_errmsg(database)];
|
|
sqlite3_finalize(sqlStatement);
|
|
return;
|
|
}
|
|
|
|
sqlite3_finalize(sqlStatement);
|
|
}
|
|
|
|
@end
|