mirror of
https://github.com/oxen-io/session-android.git
synced 2023-12-14 02:53:01 +01:00
bee287bb7e
* feat: Add Session Id blinding
Including modified version of lazysodium-android to expose missing libsodium functions, we could build from a fork which we still need to setup.
* Add v4 onion request handling
* Update SOGS signature construction
* Fix SOGS signature construction
* Update onion request
* Update signature data
* Keep path prefixes for v4 endpoints
* Update SOGS signature message
* Rename to remove api version suffix
* Update onion response parsing
* Refactor file download paths
* Implement request batching
* Refactor batch response handling
* Handle batch endpoint responses
* Update batch endpoint responses
* Update attachment download handling
* Handle file downloads
* Handle inbox messages
* Fix issue with file downloads
* Preserve image bytearray encoding
* Refactor
* Open group message requests
* Check id blinding in user detail bottom sheet rather
* Message validation refactor
* Cache last inbox/outbox server ids
* Update message encryption/decryption
* Refactor
* Refactor
* Bypass user details bottom sheet in open groups for blinded session ids
* Fix capabilities call auth
* Refactor
* Revert default server details
* Update sodium dependency to forked repo
* Fix attachment upload
* Revert "Update sodium dependency to forked repo"
This reverts commit c7db9529f9
.
* Add signed sodium lib
* Update contact id truncation and mention logic
* Open group inbox messaging fix
* Refactor
* Update blinded id check
* Fix open group message sends
* Fix crash on open group direct message send
* Direct message refactor
* Direct message encrypt/decrypt fixes
* Use updated curve25519 version
* Updated lazysodium dependency
* Update encryption/decryption calls
* Handle direct message parse errors
* Minor refactor
* Existing chat refactor
* Update encryption & decryption parameters
* Fix authenticated ciphertext size
* Set direct message sync target
* Update direct message thread lookup
* Add blinded id mapping table
* Add blinded id mapping table
* Update threads after sends
* Update open group message timestamp handling
* Filter unblinded contacts
* Format blinded id mentions
* Add message deleted field
* Hide open group inbox id
* Update message request response handling
* Update message request response sender handling
* Fix mentions of blinded ids
* Handle open group poll failure
* fix: add log for failed open group onion request, add decoding body for blinding required error at destination
* fix: change the error check
* Persist group members
* Reschedule polling after capabilities update
* Retry on other exceptions
* Minor refactor
* Open group profile fix
* Group member db schema update
* Fix ban request key
* Update ban response type
* Ban endpoint updates
* Ban endpoint updates
* Delete messages
Co-authored-by: charles <charles@oxen.io>
Co-authored-by: jubb <hjubb@users.noreply.github.com>
88 lines
3.1 KiB
Kotlin
88 lines
3.1 KiB
Kotlin
package org.thoughtcrime.securesms.database
|
|
|
|
import android.content.ContentValues
|
|
import android.content.Context
|
|
import android.database.Cursor
|
|
import androidx.core.database.getStringOrNull
|
|
import org.session.libsession.messaging.BlindedIdMapping
|
|
import org.thoughtcrime.securesms.database.helpers.SQLCipherOpenHelper
|
|
|
|
class BlindedIdMappingDatabase(context: Context, helper: SQLCipherOpenHelper) : Database(context, helper) {
|
|
|
|
companion object {
|
|
const val TABLE_NAME = "blinded_id_mapping"
|
|
const val ROW_ID = "_id"
|
|
const val BLINDED_PK = "blinded_pk"
|
|
const val SESSION_PK = "session_pk"
|
|
const val SERVER_URL = "server_url"
|
|
const val SERVER_PK = "server_pk"
|
|
|
|
@JvmField
|
|
val CREATE_BLINDED_ID_MAPPING_TABLE_COMMAND = """
|
|
CREATE TABLE $TABLE_NAME (
|
|
$ROW_ID INTEGER PRIMARY KEY,
|
|
$BLINDED_PK TEXT NOT NULL,
|
|
$SESSION_PK TEXT DEFAULT NULL,
|
|
$SERVER_URL TEXT NOT NULL,
|
|
$SERVER_PK TEXT NOT NULL
|
|
)
|
|
""".trimIndent()
|
|
|
|
private fun readBlindedIdMapping(cursor: Cursor): BlindedIdMapping {
|
|
return BlindedIdMapping(
|
|
blindedId = cursor.getString(cursor.getColumnIndexOrThrow(BLINDED_PK)),
|
|
sessionId = cursor.getStringOrNull(cursor.getColumnIndexOrThrow(SESSION_PK)),
|
|
serverUrl = cursor.getString(cursor.getColumnIndexOrThrow(SERVER_URL)),
|
|
serverId = cursor.getString(cursor.getColumnIndexOrThrow(SERVER_PK)),
|
|
)
|
|
}
|
|
}
|
|
|
|
fun getBlindedIdMapping(blindedId: String): List<BlindedIdMapping> {
|
|
val query = "$BLINDED_PK = ?"
|
|
val args = arrayOf(blindedId)
|
|
|
|
val mappings: MutableList<BlindedIdMapping> = mutableListOf()
|
|
|
|
readableDatabase.query(TABLE_NAME, null, query, args, null, null, null).use { cursor ->
|
|
while (cursor.moveToNext()) {
|
|
mappings += readBlindedIdMapping(cursor)
|
|
}
|
|
}
|
|
|
|
return mappings
|
|
}
|
|
|
|
fun addBlindedIdMapping(blindedIdMapping: BlindedIdMapping) {
|
|
writableDatabase.beginTransaction()
|
|
try {
|
|
val values = ContentValues().apply {
|
|
put(BLINDED_PK, blindedIdMapping.blindedId)
|
|
put(SERVER_PK, blindedIdMapping.sessionId)
|
|
put(SERVER_URL, blindedIdMapping.serverUrl)
|
|
put(SERVER_PK, blindedIdMapping.serverId)
|
|
}
|
|
|
|
writableDatabase.insert(TABLE_NAME, null, values)
|
|
writableDatabase.setTransactionSuccessful()
|
|
} finally {
|
|
writableDatabase.endTransaction()
|
|
}
|
|
}
|
|
|
|
fun getBlindedIdMappingsExceptFor(server: String): List<BlindedIdMapping> {
|
|
val query = "$SESSION_PK IS NOT NULL AND $SERVER_URL <> ?"
|
|
val args = arrayOf(server)
|
|
|
|
val mappings: MutableList<BlindedIdMapping> = mutableListOf()
|
|
|
|
readableDatabase.query(TABLE_NAME, null, query, args, null, null, null).use { cursor ->
|
|
while (cursor.moveToNext()) {
|
|
mappings += readBlindedIdMapping(cursor)
|
|
}
|
|
}
|
|
|
|
return mappings
|
|
}
|
|
|
|
} |