Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,13 @@ import net.thunderbird.core.logging.LogLevelManager
import net.thunderbird.core.logging.Logger
import net.thunderbird.core.preference.storage.Storage
import net.thunderbird.core.preference.storage.StorageEditor
import net.thunderbird.core.preference.storage.StoragePersister

private const val TAG = "DefaultDebuggingSettingsPreferenceManager"

class DefaultDebuggingSettingsPreferenceManager(
private val logger: Logger,
private val storage: Storage,
private val storagePersister: StoragePersister,
private val storageEditor: StorageEditor,
private val logLevelManager: LogLevelManager,
private val ioDispatcher: CoroutineDispatcher = Dispatchers.IO,
Expand All @@ -30,6 +31,8 @@ class DefaultDebuggingSettingsPreferenceManager(
) : DebuggingSettingsPreferenceManager {
private val configState: MutableStateFlow<DebuggingSettings> = MutableStateFlow(value = loadConfig())
private val mutex = Mutex()
private val storage: Storage
get() = storagePersister.loadValues()

override fun getConfig(): DebuggingSettings = configState.value
override fun getConfigFlow(): Flow<DebuggingSettings> = configState
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,21 +13,24 @@ import kotlinx.coroutines.sync.withLock
import net.thunderbird.core.logging.Logger
import net.thunderbird.core.preference.storage.Storage
import net.thunderbird.core.preference.storage.StorageEditor
import net.thunderbird.core.preference.storage.StoragePersister
import net.thunderbird.core.preference.storage.getEnumOrDefault
import net.thunderbird.core.preference.storage.putEnum

private const val TAG = "DefaultDisplayCoreSettingsPreferenceManager"

class DefaultDisplayCoreSettingsPreferenceManager(
private val logger: Logger,
private val storage: Storage,
private val storagePersister: StoragePersister,
private val storageEditor: StorageEditor,
private val ioDispatcher: CoroutineDispatcher = Dispatchers.IO,
private var scope: CoroutineScope = CoroutineScope(SupervisorJob()),
) : DisplayCoreSettingsPreferenceManager {

private val configState: MutableStateFlow<DisplayCoreSettings> = MutableStateFlow(value = loadConfig())
private val mutex = Mutex()
private val storage: Storage
get() = storagePersister.loadValues()

override fun getConfig(): DisplayCoreSettings = configState.value

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,19 +13,22 @@ import kotlinx.coroutines.sync.withLock
import net.thunderbird.core.logging.Logger
import net.thunderbird.core.preference.storage.Storage
import net.thunderbird.core.preference.storage.StorageEditor
import net.thunderbird.core.preference.storage.StoragePersister

private const val TAG = "DefaultDisplayInboxSettingsPreferenceManager"

class DefaultDisplayInboxSettingsPreferenceManager(
private val logger: Logger,
private val storage: Storage,
private val storagePersister: StoragePersister,
private val storageEditor: StorageEditor,
private val ioDispatcher: CoroutineDispatcher = Dispatchers.IO,
private var scope: CoroutineScope = CoroutineScope(SupervisorJob()),
) : DisplayInboxSettingsPreferenceManager {

private val configState: MutableStateFlow<DisplayInboxSettings> = MutableStateFlow(value = loadConfig())
private val mutex = Mutex()
private val storage: Storage
get() = storagePersister.loadValues()

override fun getConfig(): DisplayInboxSettings = configState.value

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,18 +13,21 @@ import kotlinx.coroutines.sync.withLock
import net.thunderbird.core.logging.Logger
import net.thunderbird.core.preference.storage.Storage
import net.thunderbird.core.preference.storage.StorageEditor
import net.thunderbird.core.preference.storage.StoragePersister

private const val TAG = "DefaultDisplayMiscSettingsPreferenceManager"

class DefaultDisplayMiscSettingsPreferenceManager(
private val logger: Logger,
private val storage: Storage,
private val storagePersister: StoragePersister,
private val storageEditor: StorageEditor,
private val ioDispatcher: CoroutineDispatcher = Dispatchers.IO,
private var scope: CoroutineScope = CoroutineScope(SupervisorJob()),
) : DisplayMiscSettingsPreferenceManager {
private val configState: MutableStateFlow<DisplayMiscSettings> = MutableStateFlow(value = loadConfig())
private val mutex = Mutex()
private val storage: Storage
get() = storagePersister.loadValues()
override fun save(config: DisplayMiscSettings) {
logger.debug(TAG) { "save() called with: config = $config" }
writeConfig(config)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,22 +15,30 @@ import kotlinx.coroutines.launch
import kotlinx.coroutines.sync.Mutex
import kotlinx.coroutines.sync.withLock
import net.thunderbird.core.logging.Logger
import net.thunderbird.core.preference.PreferenceChangeBroker
import net.thunderbird.core.preference.PreferenceChangeSubscriber
import net.thunderbird.core.preference.display.visualSettings.message.list.MessageListPreferencesManager
import net.thunderbird.core.preference.storage.Storage
import net.thunderbird.core.preference.storage.StorageEditor
import net.thunderbird.core.preference.storage.StoragePersister
import net.thunderbird.core.preference.storage.getEnumOrDefault
import net.thunderbird.core.preference.storage.putEnum

private const val TAG = "DefaultDisplayVisualSettingsPreferenceManager"

class DefaultDisplayVisualSettingsPreferenceManager(
private val logger: Logger,
private val storage: Storage,
private val storagePersister: StoragePersister,
private val storageEditor: StorageEditor,
preferenceChangeBroker: PreferenceChangeBroker,
private val messageListPreferences: MessageListPreferencesManager,
private val ioDispatcher: CoroutineDispatcher = Dispatchers.IO,
private val scope: CoroutineScope = CoroutineScope(SupervisorJob()),
) : DisplayVisualSettingsPreferenceManager {
) : DisplayVisualSettingsPreferenceManager, PreferenceChangeSubscriber {

init {
preferenceChangeBroker.subscribe(this)
}
private val internalConfigState = MutableStateFlow(value = loadConfig())
private val configState: StateFlow<DisplayVisualSettings> = combine(
internalConfigState,
Expand All @@ -39,6 +47,8 @@ class DefaultDisplayVisualSettingsPreferenceManager(
config.copy(messageListSettings = messageListConfig)
}.stateIn(scope = scope, started = SharingStarted.Eagerly, initialValue = internalConfigState.value)
private val mutex = Mutex()
private val storage: Storage
get() = storagePersister.loadValues()

override fun save(config: DisplayVisualSettings) {
logger.debug(TAG) { "save() called with: config = $config" }
Expand Down Expand Up @@ -92,4 +102,8 @@ class DefaultDisplayVisualSettingsPreferenceManager(
override fun getConfig() = configState.value

override fun getConfigFlow(): Flow<DisplayVisualSettings> = configState

override fun receive() {
internalConfigState.update { loadConfig() }
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -14,21 +14,25 @@ import net.thunderbird.core.common.action.SwipeActions
import net.thunderbird.core.logging.Logger
import net.thunderbird.core.preference.storage.Storage
import net.thunderbird.core.preference.storage.StorageEditor
import net.thunderbird.core.preference.storage.StoragePersister
import net.thunderbird.core.preference.storage.getEnumOrDefault
import net.thunderbird.core.preference.storage.putEnum

private const val TAG = "DefaultInteractionSettingsPreferenceManager"

class DefaultInteractionSettingsPreferenceManager(
private val logger: Logger,
private val storage: Storage,
private val storagePersister: StoragePersister,
private val storageEditor: StorageEditor,
private val ioDispatcher: CoroutineDispatcher = Dispatchers.IO,
private var scope: CoroutineScope = CoroutineScope(SupervisorJob()),
) : InteractionSettingsPreferenceManager {
private val configState: MutableStateFlow<InteractionSettings> = MutableStateFlow(value = loadConfig())
private val mutex = Mutex()

private val storage: Storage
get() = storagePersister.loadValues()

override fun getConfig(): InteractionSettings = configState.value
override fun getConfigFlow(): Flow<InteractionSettings> = configState

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,20 +13,23 @@ import kotlinx.coroutines.sync.withLock
import net.thunderbird.core.logging.Logger
import net.thunderbird.core.preference.storage.Storage
import net.thunderbird.core.preference.storage.StorageEditor
import net.thunderbird.core.preference.storage.StoragePersister
import net.thunderbird.core.preference.storage.getEnumOrDefault
import net.thunderbird.core.preference.storage.putEnum

private const val TAG = "DefaultNetworkSettingsPreferenceManager"

class DefaultNetworkSettingsPreferenceManager(
private val logger: Logger,
private val storage: Storage,
private val storagePersister: StoragePersister,
private val storageEditor: StorageEditor,
private val ioDispatcher: CoroutineDispatcher = Dispatchers.IO,
private var scope: CoroutineScope = CoroutineScope(SupervisorJob()),
) : NetworkSettingsPreferenceManager {
private val configState: MutableStateFlow<NetworkSettings> = MutableStateFlow(value = loadConfig())
private val mutex = Mutex()
private val storage: Storage
get() = storagePersister.loadValues()

override fun getConfig(): NetworkSettings = configState.value
override fun getConfigFlow(): Flow<NetworkSettings> = configState
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,17 +13,20 @@ import kotlinx.coroutines.sync.withLock
import net.thunderbird.core.logging.Logger
import net.thunderbird.core.preference.storage.Storage
import net.thunderbird.core.preference.storage.StorageEditor
import net.thunderbird.core.preference.storage.StoragePersister

private const val TAG = "DefaultNotificationPreferenceManager"

class DefaultNotificationPreferenceManager(
private val logger: Logger,
storage: Storage,
private val storagePersister: StoragePersister,
private val storageEditor: StorageEditor,
private val ioDispatcher: CoroutineDispatcher = Dispatchers.IO,
private var scope: CoroutineScope = CoroutineScope(SupervisorJob()),
) : NotificationPreferenceManager {
private val mutex = Mutex()
private val storage: Storage
get() = storagePersister.loadValues()
private val configState = MutableStateFlow(
value = NotificationPreference(
isQuietTimeEnabled = storage.getBoolean(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,18 +13,21 @@ import kotlinx.coroutines.sync.withLock
import net.thunderbird.core.logging.Logger
import net.thunderbird.core.preference.storage.Storage
import net.thunderbird.core.preference.storage.StorageEditor
import net.thunderbird.core.preference.storage.StoragePersister

private const val TAG = "DefaultPrivacySettingsPreferenceManager"

class DefaultPrivacySettingsPreferenceManager(
private val logger: Logger,
private val storage: Storage,
private val storagePersister: StoragePersister,
private val storageEditor: StorageEditor,
private val ioDispatcher: CoroutineDispatcher = Dispatchers.IO,
private var scope: CoroutineScope = CoroutineScope(SupervisorJob()),
) : PrivacySettingsPreferenceManager {
private val configState: MutableStateFlow<PrivacySettings> = MutableStateFlow(value = loadConfig())
private val mutex = Mutex()
private val storage: Storage
get() = storagePersister.loadValues()

override fun getConfig(): PrivacySettings = configState.value
override fun getConfigFlow(): Flow<PrivacySettings> = configState
Expand Down
19 changes: 10 additions & 9 deletions legacy/core/src/main/java/com/fsck/k9/preferences/KoinModule.kt
Original file line number Diff line number Diff line change
Expand Up @@ -52,50 +52,51 @@ val preferencesModule = module {
single<PrivacySettingsPreferenceManager> {
DefaultPrivacySettingsPreferenceManager(
logger = get(),
storage = get<Preferences>().storage,
storagePersister = get(),
storageEditor = get<Preferences>().createStorageEditor(),
)
}
single<NotificationPreferenceManager> {
DefaultNotificationPreferenceManager(
logger = get(),
storage = get<Preferences>().storage,
storagePersister = get(),
storageEditor = get<Preferences>().createStorageEditor(),
)
}
single<DisplayCoreSettingsPreferenceManager> {
DefaultDisplayCoreSettingsPreferenceManager(
logger = get(),
storage = get<Preferences>().storage,
storagePersister = get(),
storageEditor = get<Preferences>().createStorageEditor(),
)
}
single<DisplayInboxSettingsPreferenceManager> {
DefaultDisplayInboxSettingsPreferenceManager(
logger = get(),
storage = get<Preferences>().storage,
storagePersister = get(),
storageEditor = get<Preferences>().createStorageEditor(),
)
}
single<DisplayVisualSettingsPreferenceManager> {
DefaultDisplayVisualSettingsPreferenceManager(
logger = get(),
storage = get<Preferences>().storage,
storagePersister = get(),
storageEditor = get<Preferences>().createStorageEditor(),
messageListPreferences = get(),
preferenceChangeBroker = get(),
)
}
single<DisplayMiscSettingsPreferenceManager> {
DefaultDisplayMiscSettingsPreferenceManager(
logger = get(),
storage = get<Preferences>().storage,
storagePersister = get(),
storageEditor = get<Preferences>().createStorageEditor(),
)
}
single<InteractionSettingsPreferenceManager> {
DefaultInteractionSettingsPreferenceManager(
logger = get(),
storage = get<Preferences>().storage,
storagePersister = get(),
storageEditor = get<Preferences>().createStorageEditor(),
)
}
Expand All @@ -118,14 +119,14 @@ val preferencesModule = module {
single<NetworkSettingsPreferenceManager> {
DefaultNetworkSettingsPreferenceManager(
logger = get(),
storage = get<Preferences>().storage,
storagePersister = get(),
storageEditor = get<Preferences>().createStorageEditor(),
)
}
single<DebuggingSettingsPreferenceManager> {
DefaultDebuggingSettingsPreferenceManager(
logger = get(),
storage = get<Preferences>().storage,
storagePersister = get(),
storageEditor = get<Preferences>().createStorageEditor(),
logLevelManager = get(),
platformConfigProvider = get(),
Expand Down
Loading