This commit is contained in:
Ryan ZHAO
2021-01-29 16:35:47 +11:00
parent 48c0df0621
commit 543019f93c
61 changed files with 116 additions and 1127 deletions

View File

@@ -0,0 +1,61 @@
package org.session.libsession.utilities;
import android.app.Activity;
import android.app.AlarmManager;
import android.app.NotificationManager;
import android.content.Context;
import android.media.AudioManager;
import android.net.ConnectivityManager;
import android.os.Build;
import android.os.PowerManager;
import android.os.Vibrator;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.annotation.RequiresApi;
import android.telephony.SubscriptionManager;
import android.telephony.TelephonyManager;
import android.view.WindowManager;
import android.view.inputmethod.InputMethodManager;
public class ServiceUtil {
public static InputMethodManager getInputMethodManager(Context context) {
return (InputMethodManager)context.getSystemService(Context.INPUT_METHOD_SERVICE);
}
public static WindowManager getWindowManager(Context context) {
return (WindowManager) context.getSystemService(Activity.WINDOW_SERVICE);
}
public static ConnectivityManager getConnectivityManager(Context context) {
return (ConnectivityManager) context.getSystemService(Activity.CONNECTIVITY_SERVICE);
}
public static NotificationManager getNotificationManager(Context context) {
return (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
}
public static TelephonyManager getTelephonyManager(Context context) {
return (TelephonyManager)context.getSystemService(Context.TELEPHONY_SERVICE);
}
public static AudioManager getAudioManager(Context context) {
return (AudioManager)context.getSystemService(Context.AUDIO_SERVICE);
}
public static PowerManager getPowerManager(Context context) {
return (PowerManager)context.getSystemService(Context.POWER_SERVICE);
}
public static AlarmManager getAlarmManager(Context context) {
return (AlarmManager)context.getSystemService(Context.ALARM_SERVICE);
}
public static Vibrator getVibrator(Context context) {
return (Vibrator)context.getSystemService(Context.VIBRATOR_SERVICE);
}
@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP_MR1)
public static @Nullable SubscriptionManager getSubscriptionManager(@NonNull Context context) {
return (SubscriptionManager) context.getSystemService(Context.TELEPHONY_SUBSCRIPTION_SERVICE);
}
}

View File

@@ -10,17 +10,13 @@ import androidx.core.app.NotificationCompat
import org.session.libsession.R
import org.session.libsession.utilities.preferences.NotificationPrivacyPreference
import org.session.libsignal.libsignal.logging.Log
import org.session.libsignal.libsignal.util.Medium
import org.session.libsignal.service.internal.util.Base64
import java.io.IOException
import java.security.SecureRandom
import java.util.*
object TextSecurePreferences {
private val TAG = TextSecurePreferences::class.simpleName
const val IDENTITY_PREF = "pref_choose_identity"
const val CHANGE_PASSPHRASE_PREF = "pref_change_passphrase"
const val DISABLE_PASSPHRASE_PREF = "pref_disable_passphrase"
const val THEME_PREF = "pref_theme"
const val LANGUAGE_PREF = "pref_language"
@@ -40,20 +36,16 @@ object TextSecurePreferences {
private const val LAST_VERSION_CODE_PREF = "last_version_code"
private const val LAST_EXPERIENCE_VERSION_PREF = "last_experience_version_code"
private const val EXPERIENCE_DISMISSED_PREF = "experience_dismissed"
const val RINGTONE_PREF = "pref_key_ringtone"
const val VIBRATE_PREF = "pref_key_vibrate"
private const val NOTIFICATION_PREF = "pref_key_enable_notifications"
const val LED_COLOR_PREF = "pref_led_color"
const val LED_BLINK_PREF = "pref_led_blink"
private const val LED_BLINK_PREF_CUSTOM = "pref_led_blink_custom"
const val ALL_MMS_PREF = "pref_all_mms"
const val ALL_SMS_PREF = "pref_all_sms"
const val PASSPHRASE_TIMEOUT_INTERVAL_PREF = "pref_timeout_interval"
const val PASSPHRASE_TIMEOUT_PREF = "pref_timeout_passphrase"
const val SCREEN_SECURITY_PREF = "pref_screen_security"
private const val ENTER_SENDS_PREF = "pref_enter_sends"
private const val ENTER_PRESENT_PREF = "pref_enter_key"
private const val SMS_DELIVERY_REPORT_PREF = "pref_delivery_report_sms"
const val MMS_USER_AGENT = "pref_mms_user_agent"
private const val MMS_CUSTOM_USER_AGENT = "pref_custom_mms_user_agent"
@@ -63,39 +55,23 @@ object TextSecurePreferences {
const val REGISTERED_GCM_PREF = "pref_gcm_registered"
private const val GCM_PASSWORD_PREF = "pref_gcm_password"
private const val SEEN_WELCOME_SCREEN_PREF = "pref_seen_welcome_screen"
private const val PROMPTED_PUSH_REGISTRATION_PREF = "pref_prompted_push_registration"
private const val PROMPTED_DEFAULT_SMS_PREF = "pref_prompted_default_sms"
private const val PROMPTED_OPTIMIZE_DOZE_PREF = "pref_prompted_optimize_doze"
private const val PROMPTED_SHARE_PREF = "pref_prompted_share"
private const val SIGNALING_KEY_PREF = "pref_signaling_key"
private const val DIRECTORY_FRESH_TIME_PREF = "pref_directory_refresh_time"
private const val UPDATE_APK_REFRESH_TIME_PREF = "pref_update_apk_refresh_time"
private const val UPDATE_APK_DOWNLOAD_ID = "pref_update_apk_download_id"
private const val UPDATE_APK_DIGEST = "pref_update_apk_digest"
private const val SIGNED_PREKEY_ROTATION_TIME_PREF = "pref_signed_pre_key_rotation_time"
private const val IN_THREAD_NOTIFICATION_PREF = "pref_key_inthread_notifications"
private const val SHOW_INVITE_REMINDER_PREF = "pref_show_invite_reminder"
const val MESSAGE_BODY_TEXT_SIZE_PREF = "pref_message_body_text_size"
const val LOCAL_REGISTRATION_ID_PREF = "pref_local_registration_id"
private const val SIGNED_PREKEY_REGISTERED_PREF = "pref_signed_prekey_registered"
private const val WIFI_SMS_PREF = "pref_wifi_sms"
private const val GCM_DISABLED_PREF = "pref_gcm_disabled"
private const val GCM_REGISTRATION_ID_PREF = "pref_gcm_registration_id"
private const val GCM_REGISTRATION_ID_VERSION_PREF = "pref_gcm_registration_id_version"
private const val GCM_REGISTRATION_ID_TIME_PREF = "pref_gcm_registration_id_last_set_time"
private const val WEBSOCKET_REGISTERED_PREF = "pref_websocket_registered"
private const val RATING_LATER_PREF = "pref_rating_later"
private const val RATING_ENABLED_PREF = "pref_rating_enabled"
private const val SIGNED_PREKEY_FAILURE_COUNT_PREF = "pref_signed_prekey_failure_count"
const val REPEAT_ALERTS_PREF = "pref_repeat_alerts"
const val NOTIFICATION_PRIVACY_PREF = "pref_notification_privacy"
const val NOTIFICATION_PRIORITY_PREF = "pref_notification_priority"
const val NEW_CONTACTS_NOTIFICATIONS = "pref_enable_new_contacts_notifications"
const val WEBRTC_CALLING_PREF = "pref_webrtc_calling"
const val MEDIA_DOWNLOAD_MOBILE_PREF = "pref_media_download_mobile"
const val MEDIA_DOWNLOAD_WIFI_PREF = "pref_media_download_wifi"
@@ -104,7 +80,6 @@ object TextSecurePreferences {
const val SYSTEM_EMOJI_PREF = "pref_system_emoji"
private const val MULTI_DEVICE_PROVISIONED_PREF = "pref_multi_device"
const val DIRECT_CAPTURE_CAMERA_ID = "pref_direct_capture_camera_id"
private const val ALWAYS_RELAY_CALLS_PREF = "pref_turn_only"
const val PROFILE_KEY_PREF = "pref_profile_key"
const val PROFILE_NAME_PREF = "pref_profile_name"
const val PROFILE_AVATAR_ID_PREF = "pref_profile_avatar_id"
@@ -112,7 +87,6 @@ object TextSecurePreferences {
const val READ_RECEIPTS_PREF = "pref_read_receipts"
const val INCOGNITO_KEYBORAD_PREF = "pref_incognito_keyboard"
private const val UNAUTHORIZED_RECEIVED = "pref_unauthorized_received"
private const val SUCCESSFUL_DIRECTORY_PREF = "pref_successful_directory"
private const val DATABASE_ENCRYPTED_SECRET = "pref_database_encrypted_secret"
private const val DATABASE_UNENCRYPTED_SECRET = "pref_database_unencrypted_secret"
@@ -120,10 +94,6 @@ object TextSecurePreferences {
private const val ATTACHMENT_UNENCRYPTED_SECRET = "pref_attachment_unencrypted_secret"
private const val NEEDS_SQLCIPHER_MIGRATION = "pref_needs_sql_cipher_migration"
private const val NEXT_PRE_KEY_ID = "pref_next_pre_key_id"
private const val ACTIVE_SIGNED_PRE_KEY_ID = "pref_active_signed_pre_key_id"
private const val NEXT_SIGNED_PRE_KEY_ID = "pref_next_signed_pre_key_id"
const val BACKUP_ENABLED = "pref_backup_enabled_v3"
private const val BACKUP_PASSPHRASE = "pref_backup_passphrase"
private const val ENCRYPTED_BACKUP_PASSPHRASE = "pref_encrypted_backup_passphrase"
@@ -134,9 +104,6 @@ object TextSecurePreferences {
const val SCREEN_LOCK = "pref_android_screen_lock"
const val SCREEN_LOCK_TIMEOUT = "pref_android_screen_lock_timeout"
private const val LAST_FULL_CONTACT_SYNC_TIME = "pref_last_full_contact_sync_time"
private const val NEEDS_FULL_CONTACT_SYNC = "pref_needs_full_contact_sync"
private const val LOG_ENCRYPTED_SECRET = "pref_log_encrypted_secret"
private const val LOG_UNENCRYPTED_SECRET = "pref_log_unencrypted_secret"
@@ -145,11 +112,7 @@ object TextSecurePreferences {
private const val NEEDS_MESSAGE_PULL = "pref_needs_message_pull"
private const val UNIDENTIFIED_ACCESS_CERTIFICATE_ROTATION_TIME_PREF = "pref_unidentified_access_certificate_rotation_time"
private const val UNIDENTIFIED_ACCESS_CERTIFICATE = "pref_unidentified_access_certificate"
const val UNIVERSAL_UNIDENTIFIED_ACCESS = "pref_universal_unidentified_access"
const val SHOW_UNIDENTIFIED_DELIVERY_INDICATORS = "pref_show_unidentifed_delivery_indicators"
private const val UNIDENTIFIED_DELIVERY_ENABLED = "pref_unidentified_delivery_enabled"
const val TYPING_INDICATORS = "pref_typing_indicators"
@@ -165,7 +128,6 @@ object TextSecurePreferences {
const val IS_USING_FCM = "pref_is_using_fcm"
private const val FCM_TOKEN = "pref_fcm_token"
private const val LAST_FCM_TOKEN_UPLOAD_TIME = "pref_last_fcm_token_upload_time_2"
private const val HAS_SEEN_PN_MODE_SHEET = "pref_has_seen_pn_mode_sheet"
@JvmStatic
@@ -264,36 +226,6 @@ object TextSecurePreferences {
return getStringPreference(context, BACKUP_SAVE_DIR, null)
}
fun getNextPreKeyId(context: Context): Int {
return getIntegerPreference(context, NEXT_PRE_KEY_ID, SecureRandom().nextInt(Medium.MAX_VALUE))
}
fun setNextPreKeyId(context: Context, value: Int) {
setIntegerPrefrence(context, NEXT_PRE_KEY_ID, value)
}
fun getNextSignedPreKeyId(context: Context): Int {
return getIntegerPreference(context, NEXT_SIGNED_PRE_KEY_ID, SecureRandom().nextInt(Medium.MAX_VALUE))
}
fun setNextSignedPreKeyId(context: Context, value: Int) {
setIntegerPrefrence(context, NEXT_SIGNED_PRE_KEY_ID, value)
}
fun getActiveSignedPreKeyId(context: Context): Int {
return getIntegerPreference(context, ACTIVE_SIGNED_PRE_KEY_ID, -1)
}
fun setActiveSignedPreKeyId(context: Context, value: Int) {
setIntegerPrefrence(context, ACTIVE_SIGNED_PRE_KEY_ID, value)
}
// TODO
// fun setNeedsSqlCipherMigration(context: Context, value: Boolean) {
// setBooleanPreference(context, NEEDS_SQLCIPHER_MIGRATION, value)
// org.greenrobot.eventbus.EventBus.getDefault().post(SqlCipherNeedsMigrationEvent())
// }
@JvmStatic
fun getNeedsSqlCipherMigration(context: Context): Boolean {
return getBooleanPreference(context, NEEDS_SQLCIPHER_MIGRATION, false)
@@ -339,23 +271,11 @@ object TextSecurePreferences {
return getStringPreference(context, DATABASE_ENCRYPTED_SECRET, null)
}
fun setHasSuccessfullyRetrievedDirectory(context: Context, value: Boolean) {
setBooleanPreference(context, SUCCESSFUL_DIRECTORY_PREF, value)
}
fun hasSuccessfullyRetrievedDirectory(context: Context): Boolean {
return getBooleanPreference(context, SUCCESSFUL_DIRECTORY_PREF, false)
}
@JvmStatic
fun setUnauthorizedReceived(context: Context, value: Boolean) {
setBooleanPreference(context, UNAUTHORIZED_RECEIVED, value)
}
fun isUnauthorizedRecieved(context: Context): Boolean {
return getBooleanPreference(context, UNAUTHORIZED_RECEIVED, false)
}
@JvmStatic
fun isIncognitoKeyboardEnabled(context: Context): Boolean {
return getBooleanPreference(context, INCOGNITO_KEYBORAD_PREF, true)
@@ -449,27 +369,11 @@ object TextSecurePreferences {
return getStringPreference(context, MESSAGE_BODY_TEXT_SIZE_PREF, "16")!!.toInt()
}
fun isTurnOnly(context: Context): Boolean {
return getBooleanPreference(context, ALWAYS_RELAY_CALLS_PREF, false)
}
@JvmStatic
fun isFcmDisabled(context: Context): Boolean {
return getBooleanPreference(context, GCM_DISABLED_PREF, false)
}
fun setFcmDisabled(context: Context, disabled: Boolean) {
setBooleanPreference(context, GCM_DISABLED_PREF, disabled)
}
fun isWebrtcCallingEnabled(context: Context): Boolean {
return getBooleanPreference(context, WEBRTC_CALLING_PREF, false)
}
fun setWebrtcCallingEnabled(context: Context, enabled: Boolean) {
setBooleanPreference(context, WEBRTC_CALLING_PREF, enabled)
}
@JvmStatic
fun setDirectCaptureCameraId(context: Context, value: Int) {
setIntegerPrefrence(context, DIRECT_CAPTURE_CAMERA_ID, value)
@@ -480,57 +384,21 @@ object TextSecurePreferences {
return getIntegerPreference(context, DIRECT_CAPTURE_CAMERA_ID, Camera.CameraInfo.CAMERA_FACING_FRONT)
}
fun setMultiDevice(context: Context, value: Boolean) {
setBooleanPreference(context, MULTI_DEVICE_PROVISIONED_PREF, value)
}
@JvmStatic
fun isMultiDevice(context: Context): Boolean {
return getBooleanPreference(context, MULTI_DEVICE_PROVISIONED_PREF, false)
}
fun setSignedPreKeyFailureCount(context: Context, value: Int) {
setIntegerPrefrence(context, SIGNED_PREKEY_FAILURE_COUNT_PREF, value)
}
fun getSignedPreKeyFailureCount(context: Context): Int {
return getIntegerPreference(context, SIGNED_PREKEY_FAILURE_COUNT_PREF, 0)
}
@JvmStatic
fun getNotificationPrivacy(context: Context): NotificationPrivacyPreference {
return NotificationPrivacyPreference(getStringPreference(context, NOTIFICATION_PRIVACY_PREF, "all"))
}
fun isNewContactsNotificationEnabled(context: Context): Boolean {
return getBooleanPreference(context, NEW_CONTACTS_NOTIFICATIONS, true)
}
fun getRatingLaterTimestamp(context: Context): Long {
return getLongPreference(context, RATING_LATER_PREF, 0)
}
fun setRatingLaterTimestamp(context: Context, timestamp: Long) {
setLongPreference(context, RATING_LATER_PREF, timestamp)
}
fun isRatingEnabled(context: Context): Boolean {
return getBooleanPreference(context, RATING_ENABLED_PREF, true)
}
fun setRatingEnabled(context: Context, enabled: Boolean) {
setBooleanPreference(context, RATING_ENABLED_PREF, enabled)
}
@JvmStatic
fun isWebsocketRegistered(context: Context): Boolean {
return getBooleanPreference(context, WEBSOCKET_REGISTERED_PREF, false)
}
fun setWebsocketRegistered(context: Context, registered: Boolean) {
setBooleanPreference(context, WEBSOCKET_REGISTERED_PREF, registered)
}
@JvmStatic
fun isWifiSmsEnabled(context: Context): Boolean {
return getBooleanPreference(context, WIFI_SMS_PREF, false)
@@ -546,18 +414,6 @@ object TextSecurePreferences {
}
}
fun setRepeatAlertsCount(context: Context, count: Int) {
setStringPreference(context, REPEAT_ALERTS_PREF, count.toString())
}
fun isSignedPreKeyRegistered(context: Context): Boolean {
return getBooleanPreference(context, SIGNED_PREKEY_REGISTERED_PREF, false)
}
fun setSignedPreKeyRegistered(context: Context, value: Boolean) {
setBooleanPreference(context, SIGNED_PREKEY_REGISTERED_PREF, value)
}
fun getLocalRegistrationId(context: Context): Int {
return getIntegerPreference(context, LOCAL_REGISTRATION_ID_PREF, 0)
}
@@ -566,52 +422,16 @@ object TextSecurePreferences {
setIntegerPrefrence(context, LOCAL_REGISTRATION_ID_PREF, registrationId)
}
fun removeLocalRegistrationId(context: Context) {
removePreference(context, LOCAL_REGISTRATION_ID_PREF)
}
@JvmStatic
fun isInThreadNotifications(context: Context): Boolean {
return getBooleanPreference(context, IN_THREAD_NOTIFICATION_PREF, true)
}
fun getUnidentifiedAccessCertificateRotationTime(context: Context): Long {
return getLongPreference(context, UNIDENTIFIED_ACCESS_CERTIFICATE_ROTATION_TIME_PREF, 0L)
}
fun setUnidentifiedAccessCertificateRotationTime(context: Context, value: Long) {
setLongPreference(context, UNIDENTIFIED_ACCESS_CERTIFICATE_ROTATION_TIME_PREF, value)
}
fun setUnidentifiedAccessCertificate(context: Context, value: ByteArray?) {
setStringPreference(context, UNIDENTIFIED_ACCESS_CERTIFICATE, Base64.encodeBytes(value))
}
fun getUnidentifiedAccessCertificate(context: Context): ByteArray? {
try {
val result = getStringPreference(context, UNIDENTIFIED_ACCESS_CERTIFICATE, null)
if (result != null) {
return Base64.decode(result)
}
} catch (e: IOException) {
Log.w(TAG, e)
}
return null
}
@JvmStatic
fun isUniversalUnidentifiedAccess(context: Context): Boolean {
return getBooleanPreference(context, UNIVERSAL_UNIDENTIFIED_ACCESS, false)
}
fun isShowUnidentifiedDeliveryIndicatorsEnabled(context: Context): Boolean {
return getBooleanPreference(context, SHOW_UNIDENTIFIED_DELIVERY_INDICATORS, false)
}
fun setIsUnidentifiedDeliveryEnabled(context: Context, enabled: Boolean) {
setBooleanPreference(context, UNIDENTIFIED_DELIVERY_ENABLED, enabled)
}
@JvmStatic
fun isUnidentifiedDeliveryEnabled(context: Context): Boolean {
// Loki - Always enable unidentified sender
@@ -619,22 +439,6 @@ object TextSecurePreferences {
// return getBooleanPreference(context, UNIDENTIFIED_DELIVERY_ENABLED, true);
}
fun getSignedPreKeyRotationTime(context: Context): Long {
return getLongPreference(context, SIGNED_PREKEY_ROTATION_TIME_PREF, 0L)
}
fun setSignedPreKeyRotationTime(context: Context, value: Long) {
setLongPreference(context, SIGNED_PREKEY_ROTATION_TIME_PREF, value)
}
fun getDirectoryRefreshTime(context: Context): Long {
return getLongPreference(context, DIRECTORY_FRESH_TIME_PREF, 0L)
}
fun setDirectoryRefreshTime(context: Context, value: Long) {
setLongPreference(context, DIRECTORY_FRESH_TIME_PREF, value)
}
@JvmStatic
fun getUpdateApkRefreshTime(context: Context): Long {
return getLongPreference(context, UPDATE_APK_REFRESH_TIME_PREF, 0L)
@@ -683,19 +487,11 @@ object TextSecurePreferences {
return getStringPreference(context, GCM_PASSWORD_PREF, null)
}
fun setPushServerPassword(context: Context, password: String?) {
setStringPreference(context, GCM_PASSWORD_PREF, password)
}
@JvmStatic
fun getSignalingKey(context: Context): String? {
return getStringPreference(context, SIGNALING_KEY_PREF, null)
}
fun isEnterImeKeyEnabled(context: Context): Boolean {
return getBooleanPreference(context, ENTER_PRESENT_PREF, false)
}
@JvmStatic
fun isEnterSendsEnabled(context: Context): Boolean {
return getBooleanPreference(context, ENTER_SENDS_PREF, false)
@@ -716,113 +512,61 @@ object TextSecurePreferences {
return getBooleanPreference(context, MMSC_CUSTOM_HOST_PREF, legacy)
}
fun setUseCustomMmsc(context: Context, value: Boolean) {
setBooleanPreference(context, MMSC_CUSTOM_HOST_PREF, value)
}
@JvmStatic
fun getMmscUrl(context: Context): String? {
return getStringPreference(context, MMSC_HOST_PREF, "")
}
fun setMmscUrl(context: Context, mmsc: String?) {
setStringPreference(context, MMSC_HOST_PREF, mmsc)
}
@JvmStatic
fun getUseCustomMmscProxy(context: Context): Boolean {
val legacy: Boolean = isLegacyUseLocalApnsEnabled(context)
return getBooleanPreference(context, MMSC_CUSTOM_PROXY_PREF, legacy)
}
fun setUseCustomMmscProxy(context: Context, value: Boolean) {
setBooleanPreference(context, MMSC_CUSTOM_PROXY_PREF, value)
}
@JvmStatic
fun getMmscProxy(context: Context): String? {
return getStringPreference(context, MMSC_PROXY_HOST_PREF, "")
}
fun setMmscProxy(context: Context, value: String?) {
setStringPreference(context, MMSC_PROXY_HOST_PREF, value)
}
@JvmStatic
fun getUseCustomMmscProxyPort(context: Context): Boolean {
val legacy: Boolean = isLegacyUseLocalApnsEnabled(context)
return getBooleanPreference(context, MMSC_CUSTOM_PROXY_PORT_PREF, legacy)
}
fun setUseCustomMmscProxyPort(context: Context, value: Boolean) {
setBooleanPreference(context, MMSC_CUSTOM_PROXY_PORT_PREF, value)
}
@JvmStatic
fun getMmscProxyPort(context: Context): String? {
return getStringPreference(context, MMSC_PROXY_PORT_PREF, "")
}
fun setMmscProxyPort(context: Context, value: String?) {
setStringPreference(context, MMSC_PROXY_PORT_PREF, value)
}
@JvmStatic
fun getUseCustomMmscUsername(context: Context): Boolean {
val legacy: Boolean = isLegacyUseLocalApnsEnabled(context)
return getBooleanPreference(context, MMSC_CUSTOM_USERNAME_PREF, legacy)
}
fun setUseCustomMmscUsername(context: Context, value: Boolean) {
setBooleanPreference(context, MMSC_CUSTOM_USERNAME_PREF, value)
}
@JvmStatic
fun getMmscUsername(context: Context): String? {
return getStringPreference(context, MMSC_USERNAME_PREF, "")
}
fun setMmscUsername(context: Context, value: String?) {
setStringPreference(context, MMSC_USERNAME_PREF, value)
}
@JvmStatic
fun getUseCustomMmscPassword(context: Context): Boolean {
val legacy: Boolean = isLegacyUseLocalApnsEnabled(context)
return getBooleanPreference(context, MMSC_CUSTOM_PASSWORD_PREF, legacy)
}
fun setUseCustomMmscPassword(context: Context, value: Boolean) {
setBooleanPreference(context, MMSC_CUSTOM_PASSWORD_PREF, value)
}
@JvmStatic
fun getMmscPassword(context: Context): String? {
return getStringPreference(context, MMSC_PASSWORD_PREF, "")
}
fun setMmscPassword(context: Context, value: String?) {
setStringPreference(context, MMSC_PASSWORD_PREF, value)
}
@JvmStatic
fun getMmsUserAgent(context: Context, defaultUserAgent: String): String {
val useCustom: Boolean = getBooleanPreference(context, MMS_CUSTOM_USER_AGENT, false)
return if (useCustom) getStringPreference(context, MMS_USER_AGENT, defaultUserAgent)!! else defaultUserAgent
}
fun getIdentityContactUri(context: Context): String? {
return getStringPreference(context, IDENTITY_PREF, null)
}
fun setIdentityContactUri(context: Context, identityUri: String?) {
setStringPreference(context, IDENTITY_PREF, identityUri)
}
fun setScreenSecurityEnabled(context: Context, value: Boolean) {
setBooleanPreference(context, SCREEN_SECURITY_PREF, value)
}
@JvmStatic
fun isScreenSecurityEnabled(context: Context): Boolean {
return getBooleanPreference(context, SCREEN_SECURITY_PREF, true)
@@ -843,22 +587,10 @@ object TextSecurePreferences {
}
}
fun getLastExperienceVersionCode(context: Context): Int {
return getIntegerPreference(context, LAST_EXPERIENCE_VERSION_PREF, 0)
}
fun setLastExperienceVersionCode(context: Context, versionCode: Int) {
setIntegerPrefrence(context, LAST_EXPERIENCE_VERSION_PREF, versionCode)
}
fun getExperienceDismissedVersionCode(context: Context): Int {
return getIntegerPreference(context, EXPERIENCE_DISMISSED_PREF, 0)
}
fun setExperienceDismissedVersionCode(context: Context, versionCode: Int) {
setIntegerPrefrence(context, EXPERIENCE_DISMISSED_PREF, versionCode)
}
fun getTheme(context: Context): String? {
return getStringPreference(context, THEME_PREF, "light")
}
@@ -868,24 +600,11 @@ object TextSecurePreferences {
return getBooleanPreference(context, VERIFYING_STATE_PREF, false)
}
fun setVerifying(context: Context, verifying: Boolean) {
setBooleanPreference(context, VERIFYING_STATE_PREF, verifying)
}
@JvmStatic
fun isPushRegistered(context: Context): Boolean {
return getBooleanPreference(context, REGISTERED_GCM_PREF, false)
}
fun setPushRegistered(context: Context, registered: Boolean) {
Log.i(TAG, "Setting push registered: $registered")
setBooleanPreference(context, REGISTERED_GCM_PREF, registered)
}
fun isShowInviteReminders(context: Context): Boolean {
return getBooleanPreference(context, SHOW_INVITE_REMINDER_PREF, true)
}
@JvmStatic
fun isPassphraseTimeoutEnabled(context: Context): Boolean {
return getBooleanPreference(context, PASSPHRASE_TIMEOUT_PREF, false)
@@ -896,19 +615,11 @@ object TextSecurePreferences {
return getIntegerPreference(context, PASSPHRASE_TIMEOUT_INTERVAL_PREF, 5 * 60)
}
fun setPassphraseTimeoutInterval(context: Context, interval: Int) {
setIntegerPrefrence(context, PASSPHRASE_TIMEOUT_INTERVAL_PREF, interval)
}
@JvmStatic
fun getLanguage(context: Context): String? {
return getStringPreference(context, LANGUAGE_PREF, "zz")
}
fun setLanguage(context: Context, language: String?) {
setStringPreference(context, LANGUAGE_PREF, language)
}
@JvmStatic
fun isSmsDeliveryReportsEnabled(context: Context): Boolean {
return getBooleanPreference(context, SMS_DELIVERY_REPORT_PREF, false)
@@ -923,46 +634,6 @@ object TextSecurePreferences {
setBooleanPreference(context, SEEN_WELCOME_SCREEN_PREF, value)
}
fun hasPromptedPushRegistration(context: Context): Boolean {
return getBooleanPreference(context, PROMPTED_PUSH_REGISTRATION_PREF, false)
}
fun setPromptedPushRegistration(context: Context, value: Boolean) {
setBooleanPreference(context, PROMPTED_PUSH_REGISTRATION_PREF, value)
}
fun hasPromptedDefaultSmsProvider(context: Context): Boolean {
return getBooleanPreference(context, PROMPTED_DEFAULT_SMS_PREF, false)
}
fun setPromptedDefaultSmsProvider(context: Context, value: Boolean) {
setBooleanPreference(context, PROMPTED_DEFAULT_SMS_PREF, value)
}
fun setPromptedOptimizeDoze(context: Context, value: Boolean) {
setBooleanPreference(context, PROMPTED_OPTIMIZE_DOZE_PREF, value)
}
fun hasPromptedOptimizeDoze(context: Context): Boolean {
return getBooleanPreference(context, PROMPTED_OPTIMIZE_DOZE_PREF, false)
}
fun hasPromptedShare(context: Context): Boolean {
return getBooleanPreference(context, PROMPTED_SHARE_PREF, false)
}
fun setPromptedShare(context: Context, value: Boolean) {
setBooleanPreference(context, PROMPTED_SHARE_PREF, value)
}
fun isInterceptAllMmsEnabled(context: Context): Boolean {
return getBooleanPreference(context, ALL_MMS_PREF, true)
}
fun isInterceptAllSmsEnabled(context: Context): Boolean {
return getBooleanPreference(context, ALL_SMS_PREF, true)
}
@JvmStatic
fun isNotificationsEnabled(context: Context): Boolean {
return getBooleanPreference(context, NOTIFICATION_PREF, true)
@@ -1012,10 +683,6 @@ object TextSecurePreferences {
return getStringPreference(context, LED_BLINK_PREF_CUSTOM, "500,2000")
}
fun setNotificationLedPatternCustom(context: Context, pattern: String?) {
setStringPreference(context, LED_BLINK_PREF_CUSTOM, pattern)
}
@JvmStatic
fun isThreadLengthTrimmingEnabled(context: Context): Boolean {
return getBooleanPreference(context, THREAD_TRIM_ENABLED, false)
@@ -1050,22 +717,6 @@ object TextSecurePreferences {
return getStringSetPreference(context, key, HashSet(Arrays.asList(*context.resources.getStringArray(defaultValuesRes))))
}
fun getLastFullContactSyncTime(context: Context): Long {
return getLongPreference(context, LAST_FULL_CONTACT_SYNC_TIME, 0)
}
fun setLastFullContactSyncTime(context: Context, timestamp: Long) {
setLongPreference(context, LAST_FULL_CONTACT_SYNC_TIME, timestamp)
}
fun needsFullContactSync(context: Context): Boolean {
return getBooleanPreference(context, NEEDS_FULL_CONTACT_SYNC, false)
}
fun setNeedsFullContactSync(context: Context, needsSync: Boolean) {
setBooleanPreference(context, NEEDS_FULL_CONTACT_SYNC, needsSync)
}
@JvmStatic
fun setLogEncryptedSecret(context: Context, base64Secret: String?) {
setStringPreference(context, LOG_ENCRYPTED_SECRET, base64Secret)
@@ -1191,30 +842,6 @@ object TextSecurePreferences {
}
// region Loki
fun getBackgroundPollTime(context: Context): Long {
return getLongPreference(context, "background_poll_time", 0L)
}
fun setBackgroundPollTime(context: Context, backgroundPollTime: Long) {
setLongPreference(context, "background_poll_time", backgroundPollTime)
}
fun getOpenGroupBackgroundPollTime(context: Context): Long {
return getLongPreference(context, "public_chat_background_poll_time", 0L)
}
fun setOpenGroupBackgroundPollTime(context: Context, backgroundPollTime: Long) {
setLongPreference(context, "public_chat_background_poll_time", backgroundPollTime)
}
fun isChatSetUp(context: Context, id: String): Boolean {
return getBooleanPreference(context, "is_chat_set_up?chat=$id", false)
}
fun markChatSetUp(context: Context, id: String) {
setBooleanPreference(context, "is_chat_set_up?chat=$id", true)
}
@JvmStatic
fun getMasterHexEncodedPublicKey(context: Context): String? {
return getStringPreference(context, "master_hex_encoded_public_key", null)
@@ -1232,14 +859,6 @@ object TextSecurePreferences {
setBooleanPreference(context, "has_viewed_seed", hasViewedSeed)
}
fun setNeedsDatabaseReset(context: Context, resetDatabase: Boolean) {
getDefaultSharedPreferences(context).edit().putBoolean("database_reset", resetDatabase).commit()
}
fun getNeedsDatabaseReset(context: Context): Boolean {
return getBooleanPreference(context, "database_reset", false)
}
fun setWasUnlinked(context: Context, value: Boolean) {
// We do it this way so that it gets persisted in storage straight away
getDefaultSharedPreferences(context).edit().putBoolean("database_reset_unpair", value).commit()
@@ -1265,14 +884,6 @@ object TextSecurePreferences {
return getLongPreference(context, "restoration_time", 0)
}
fun getHasSeenOpenGroupSuggestionSheet(context: Context): Boolean {
return getBooleanPreference(context, "has_seen_open_group_suggestion_sheet", false)
}
fun setHasSeenOpenGroupSuggestionSheet(context: Context) {
setBooleanPreference(context, "has_seen_open_group_suggestion_sheet", true)
}
@JvmStatic
fun getLastProfilePictureUpload(context: Context): Long {
return getLongPreference(context, "last_profile_picture_upload", 0)
@@ -1298,22 +909,6 @@ object TextSecurePreferences {
getDefaultSharedPreferences(context).edit().clear().commit()
}
fun getHasSeenMultiDeviceRemovalSheet(context: Context): Boolean {
return getBooleanPreference(context, "has_seen_multi_device_removal_sheet", false)
}
fun setHasSeenMultiDeviceRemovalSheet(context: Context) {
setBooleanPreference(context, "has_seen_multi_device_removal_sheet", true)
}
fun hasSeenLightThemeIntroSheet(context: Context): Boolean {
return getBooleanPreference(context, "has_seen_light_theme_intro_sheet", false)
}
fun setHasSeenLightThemeIntroSheet(context: Context) {
setBooleanPreference(context, "has_seen_light_theme_intro_sheet", true)
}
fun getLastSnodePoolRefreshDate(context: Context?): Long {
return getLongPreference(context!!, "last_snode_pool_refresh_date", 0)
}
@@ -1322,14 +917,6 @@ object TextSecurePreferences {
setLongPreference(context!!, "last_snode_pool_refresh_date", date.time)
}
fun getLastKeyPairMigrationNudge(context: Context?): Long {
return getLongPreference(context!!, "last_key_pair_migration_nudge", 0)
}
fun setLastKeyPairMigrationNudge(context: Context?, newValue: Long) {
setLongPreference(context!!, "last_key_pair_migration_nudge", newValue)
}
fun getIsMigratingKeyPair(context: Context?): Boolean {
return getBooleanPreference(context!!, "is_migrating_key_pair", false)
}
@@ -1338,7 +925,6 @@ object TextSecurePreferences {
fun setIsMigratingKeyPair(context: Context?, newValue: Boolean) {
setBooleanPreference(context!!, "is_migrating_key_pair", newValue)
}
// endregion

View File

@@ -20,6 +20,7 @@ import org.session.libsignal.libsignal.logging.Log
import java.io.*
import java.nio.charset.StandardCharsets
import java.security.SecureRandom
import java.text.DecimalFormat
import java.util.*
import java.util.concurrent.CountDownLatch
import java.util.concurrent.ExecutorService
@@ -43,16 +44,16 @@ object Util {
@JvmStatic
@Throws(IOException::class)
fun copy(`in`: InputStream, out: OutputStream): Long {
fun copy(`in`: InputStream, out: OutputStream?): Long {
val buffer = ByteArray(8192)
var read: Int
var total: Long = 0
while (`in`.read(buffer).also { read = it } != -1) {
out.write(buffer, 0, read)
out?.write(buffer, 0, read)
total += read.toLong()
}
`in`.close()
out.close()
out?.close()
return total
}
@@ -327,4 +328,39 @@ object Util {
return spanned
}
@JvmStatic
fun clamp(value: Int, min: Int, max: Int): Int {
return Math.min(Math.max(value, min), max)
}
@JvmStatic
fun combine(vararg elements: ByteArray?): ByteArray? {
return try {
val baos = ByteArrayOutputStream()
for (element in elements) {
baos.write(element)
}
baos.toByteArray()
} catch (e: IOException) {
throw java.lang.AssertionError(e)
}
}
@JvmStatic
fun split(input: ByteArray?, firstLength: Int, secondLength: Int): Array<ByteArray?> {
val parts = arrayOfNulls<ByteArray>(2)
parts[0] = ByteArray(firstLength)
System.arraycopy(input, 0, parts[0], 0, firstLength)
parts[1] = ByteArray(secondLength)
System.arraycopy(input, firstLength, parts[1], 0, secondLength)
return parts
}
@JvmStatic
fun getPrettyFileSize(sizeBytes: Long): String {
if (sizeBytes <= 0) return "0"
val units = arrayOf("B", "kB", "MB", "GB", "TB")
val digitGroups = (Math.log10(sizeBytes.toDouble()) / Math.log10(1024.0)).toInt()
return DecimalFormat("#,##0.#").format(sizeBytes / Math.pow(1024.0, digitGroups.toDouble())) + " " + units[digitGroups]
}
}