removing the id field at conversations, use thread_id
This commit is contained in:
parent
1c6d19c986
commit
d1616d4997
|
@ -203,12 +203,12 @@ class MainActivity : SimpleActivity() {
|
||||||
|
|
||||||
cachedConversations.forEach { cachedConversation ->
|
cachedConversations.forEach { cachedConversation ->
|
||||||
if (!conversations.map { it.threadId }.contains(cachedConversation.threadId)) {
|
if (!conversations.map { it.threadId }.contains(cachedConversation.threadId)) {
|
||||||
conversationsDB.delete(cachedConversation.id!!)
|
conversationsDB.deleteThreadId(cachedConversation.threadId)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cachedConversations.forEach { cachedConversation ->
|
cachedConversations.forEach { cachedConversation ->
|
||||||
val conv = conversations.firstOrNull { it.threadId == cachedConversation.threadId && it.getStringToCompare() != cachedConversation.getStringToCompare() }
|
val conv = conversations.firstOrNull { it.threadId == cachedConversation.threadId && it.toString() != cachedConversation.toString() }
|
||||||
if (conv != null) {
|
if (conv != null) {
|
||||||
conversationsDB.insertOrUpdate(conv)
|
conversationsDB.insertOrUpdate(conv)
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,7 @@ import com.simplemobiletools.smsmessenger.models.Conversation
|
||||||
import com.simplemobiletools.smsmessenger.models.Message
|
import com.simplemobiletools.smsmessenger.models.Message
|
||||||
import com.simplemobiletools.smsmessenger.models.MessageAttachment
|
import com.simplemobiletools.smsmessenger.models.MessageAttachment
|
||||||
|
|
||||||
@Database(entities = [Conversation::class, Attachment::class, MessageAttachment::class, Message::class], version = 2)
|
@Database(entities = [Conversation::class, Attachment::class, MessageAttachment::class, Message::class], version = 3)
|
||||||
@TypeConverters(Converters::class)
|
@TypeConverters(Converters::class)
|
||||||
abstract class MessagesDatabase : RoomDatabase() {
|
abstract class MessagesDatabase : RoomDatabase() {
|
||||||
|
|
||||||
|
@ -39,6 +39,7 @@ abstract class MessagesDatabase : RoomDatabase() {
|
||||||
db = Room.databaseBuilder(context.applicationContext, MessagesDatabase::class.java, "conversations.db")
|
db = Room.databaseBuilder(context.applicationContext, MessagesDatabase::class.java, "conversations.db")
|
||||||
.fallbackToDestructiveMigration()
|
.fallbackToDestructiveMigration()
|
||||||
.addMigrations(MIGRATION_1_2)
|
.addMigrations(MIGRATION_1_2)
|
||||||
|
.addMigrations(MIGRATION_2_3)
|
||||||
.build()
|
.build()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -48,12 +49,31 @@ abstract class MessagesDatabase : RoomDatabase() {
|
||||||
|
|
||||||
private val MIGRATION_1_2 = object : Migration(1, 2) {
|
private val MIGRATION_1_2 = object : Migration(1, 2) {
|
||||||
override fun migrate(database: SupportSQLiteDatabase) {
|
override fun migrate(database: SupportSQLiteDatabase) {
|
||||||
database.execSQL("CREATE TABLE IF NOT EXISTS `messages` (`id` INTEGER PRIMARY KEY NOT NULL, `body` TEXT NOT NULL, `type` INTEGER NOT NULL, `participants` TEXT NOT NULL, `date` INTEGER NOT NULL, `read` INTEGER NOT NULL, `thread_id` INTEGER NOT NULL, `is_mms` INTEGER NOT NULL, `attachment` TEXT, `sender_name` TEXT NOT NULL, `sender_photo_uri` TEXT NOT NULL, `subscription_id` INTEGER NOT NULL)")
|
database.apply {
|
||||||
|
execSQL("CREATE TABLE IF NOT EXISTS `messages` (`id` INTEGER PRIMARY KEY NOT NULL, `body` TEXT NOT NULL, `type` INTEGER NOT NULL, `participants` TEXT NOT NULL, `date` INTEGER NOT NULL, `read` INTEGER NOT NULL, `thread_id` INTEGER NOT NULL, `is_mms` INTEGER NOT NULL, `attachment` TEXT, `sender_name` TEXT NOT NULL, `sender_photo_uri` TEXT NOT NULL, `subscription_id` INTEGER NOT NULL)")
|
||||||
|
|
||||||
database.execSQL("CREATE TABLE IF NOT EXISTS `message_attachments` (`id` INTEGER PRIMARY KEY NOT NULL, `text` TEXT NOT NULL, `attachments` TEXT NOT NULL)")
|
execSQL("CREATE TABLE IF NOT EXISTS `message_attachments` (`id` INTEGER PRIMARY KEY NOT NULL, `text` TEXT NOT NULL, `attachments` TEXT NOT NULL)")
|
||||||
|
|
||||||
database.execSQL("CREATE TABLE IF NOT EXISTS `attachments` (`id` INTEGER PRIMARY KEY AUTOINCREMENT, `message_id` INTEGER NOT NULL, `uri_string` TEXT NOT NULL, `mimetype` TEXT NOT NULL, `width` INTEGER NOT NULL, `height` INTEGER NOT NULL, `filename` TEXT NOT NULL)")
|
execSQL("CREATE TABLE IF NOT EXISTS `attachments` (`id` INTEGER PRIMARY KEY AUTOINCREMENT, `message_id` INTEGER NOT NULL, `uri_string` TEXT NOT NULL, `mimetype` TEXT NOT NULL, `width` INTEGER NOT NULL, `height` INTEGER NOT NULL, `filename` TEXT NOT NULL)")
|
||||||
database.execSQL("CREATE UNIQUE INDEX `index_attachments_message_id` ON `attachments` (`message_id`)")
|
execSQL("CREATE UNIQUE INDEX `index_attachments_message_id` ON `attachments` (`message_id`)")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private val MIGRATION_2_3 = object : Migration(2, 3) {
|
||||||
|
override fun migrate(database: SupportSQLiteDatabase) {
|
||||||
|
database.apply {
|
||||||
|
execSQL("CREATE TABLE conversations_new (`thread_id` INTEGER NOT NULL PRIMARY KEY, `snippet` TEXT NOT NULL, `date` INTEGER NOT NULL, `read` INTEGER NOT NULL, `title` TEXT NOT NULL, `photo_uri` TEXT NOT NULL, `is_group_conversation` INTEGER NOT NULL, `phone_number` TEXT NOT NULL)")
|
||||||
|
|
||||||
|
execSQL("INSERT OR IGNORE INTO conversations_new (thread_id, snippet, date, read, title, photo_uri, is_group_conversation, phone_number) " +
|
||||||
|
"SELECT thread_id, snippet, date, read, title, photo_uri, is_group_conversation, phone_number FROM conversations")
|
||||||
|
|
||||||
|
execSQL("DROP TABLE conversations")
|
||||||
|
|
||||||
|
execSQL("ALTER TABLE conversations_new RENAME TO conversations")
|
||||||
|
|
||||||
|
execSQL("CREATE UNIQUE INDEX IF NOT EXISTS `index_conversations_id` ON `conversations` (`thread_id`)")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,8 +2,5 @@ package com.simplemobiletools.smsmessenger.extensions
|
||||||
|
|
||||||
import android.text.TextUtils
|
import android.text.TextUtils
|
||||||
import com.simplemobiletools.commons.models.SimpleContact
|
import com.simplemobiletools.commons.models.SimpleContact
|
||||||
import com.simplemobiletools.smsmessenger.models.Conversation
|
|
||||||
|
|
||||||
fun ArrayList<SimpleContact>.getThreadTitle() = TextUtils.join(", ", map { it.name }.toTypedArray())
|
fun ArrayList<SimpleContact>.getThreadTitle() = TextUtils.join(", ", map { it.name }.toTypedArray())
|
||||||
|
|
||||||
fun ArrayList<Conversation>.getHashToCompare() = map { it.getStringToCompare() }.hashCode()
|
|
||||||
|
|
|
@ -238,7 +238,7 @@ fun Context.getConversations(threadId: Long? = null, privateContacts: ArrayList<
|
||||||
val photoUri = if (phoneNumbers.size == 1) simpleContactHelper.getPhotoUriFromPhoneNumber(phoneNumbers.first()) else ""
|
val photoUri = if (phoneNumbers.size == 1) simpleContactHelper.getPhotoUriFromPhoneNumber(phoneNumbers.first()) else ""
|
||||||
val isGroupConversation = phoneNumbers.size > 1
|
val isGroupConversation = phoneNumbers.size > 1
|
||||||
val read = cursor.getIntValue(Threads.READ) == 1
|
val read = cursor.getIntValue(Threads.READ) == 1
|
||||||
val conversation = Conversation(null, id, snippet, date.toInt(), read, title, photoUri, isGroupConversation, phoneNumbers.first())
|
val conversation = Conversation(id, snippet, date.toInt(), read, title, photoUri, isGroupConversation, phoneNumbers.first())
|
||||||
conversations.add(conversation)
|
conversations.add(conversation)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,9 +23,6 @@ interface ConversationsDao {
|
||||||
@Query("UPDATE conversations SET read = 0 WHERE thread_id = :threadId")
|
@Query("UPDATE conversations SET read = 0 WHERE thread_id = :threadId")
|
||||||
fun markUnread(threadId: Long)
|
fun markUnread(threadId: Long)
|
||||||
|
|
||||||
@Query("DELETE FROM conversations WHERE id = :id")
|
|
||||||
fun delete(id: Long)
|
|
||||||
|
|
||||||
@Query("DELETE FROM conversations WHERE thread_id = :threadId")
|
@Query("DELETE FROM conversations WHERE thread_id = :threadId")
|
||||||
fun deleteThreadId(threadId: Long)
|
fun deleteThreadId(threadId: Long)
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,8 +7,7 @@ import androidx.room.PrimaryKey
|
||||||
|
|
||||||
@Entity(tableName = "conversations", indices = [(Index(value = ["thread_id"], unique = true))])
|
@Entity(tableName = "conversations", indices = [(Index(value = ["thread_id"], unique = true))])
|
||||||
data class Conversation(
|
data class Conversation(
|
||||||
@PrimaryKey(autoGenerate = true) var id: Long?,
|
@PrimaryKey @ColumnInfo(name = "thread_id") var threadId: Long,
|
||||||
@ColumnInfo(name = "thread_id") var threadId: Long,
|
|
||||||
@ColumnInfo(name = "snippet") var snippet: String,
|
@ColumnInfo(name = "snippet") var snippet: String,
|
||||||
@ColumnInfo(name = "date") var date: Int,
|
@ColumnInfo(name = "date") var date: Int,
|
||||||
@ColumnInfo(name = "read") var read: Boolean,
|
@ColumnInfo(name = "read") var read: Boolean,
|
||||||
|
@ -16,8 +15,4 @@ data class Conversation(
|
||||||
@ColumnInfo(name = "photo_uri") var photoUri: String,
|
@ColumnInfo(name = "photo_uri") var photoUri: String,
|
||||||
@ColumnInfo(name = "is_group_conversation") var isGroupConversation: Boolean,
|
@ColumnInfo(name = "is_group_conversation") var isGroupConversation: Boolean,
|
||||||
@ColumnInfo(name = "phone_number") var phoneNumber: String
|
@ColumnInfo(name = "phone_number") var phoneNumber: String
|
||||||
) {
|
)
|
||||||
fun getStringToCompare(): String {
|
|
||||||
return copy(id = 0).toString()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in New Issue