mirror of
https://git.selfprivacy.org/kherel/selfprivacy.org.app.git
synced 2025-01-23 09:16:54 +00:00
feat: some more decomposition in hive_config
This commit is contained in:
parent
4bda23eaf9
commit
2fbcc3c232
|
@ -116,7 +116,7 @@ class HiveConfig {
|
||||||
/// add new migrations here, like:
|
/// add new migrations here, like:
|
||||||
/// if (version < 3) {...}, etc.
|
/// if (version < 3) {...}, etc.
|
||||||
|
|
||||||
/// update saved version after successfull migraions
|
/// update saved version after successfull migrations
|
||||||
await localSettingsBox.put(BNames.databaseVersion, version);
|
await localSettingsBox.put(BNames.databaseVersion, version);
|
||||||
}
|
}
|
||||||
} catch (error, stackTrace) {
|
} catch (error, stackTrace) {
|
||||||
|
@ -135,60 +135,82 @@ class HiveConfig {
|
||||||
if (resourcesBox.isEmpty) {
|
if (resourcesBox.isEmpty) {
|
||||||
final Box serverInstallationBox = Hive.box(BNames.serverInstallationBox);
|
final Box serverInstallationBox = Hive.box(BNames.serverInstallationBox);
|
||||||
|
|
||||||
final String? serverProviderKey =
|
|
||||||
serverInstallationBox.get(BNames.hetznerKey);
|
|
||||||
final String? serverLocation =
|
|
||||||
serverInstallationBox.get(BNames.serverLocation);
|
|
||||||
final String? dnsProviderKey =
|
|
||||||
serverInstallationBox.get(BNames.cloudFlareKey);
|
|
||||||
final BackupsCredential? backblazeCredential =
|
|
||||||
serverInstallationBox.get(BNames.backblazeCredential);
|
|
||||||
final ServerDomain? serverDomain =
|
|
||||||
serverInstallationBox.get(BNames.serverDomain);
|
|
||||||
final ServerHostingDetails? serverDetails =
|
final ServerHostingDetails? serverDetails =
|
||||||
serverInstallationBox.get(BNames.serverDetails);
|
serverInstallationBox.get(BNames.serverDetails);
|
||||||
final BackblazeBucket? backblazeBucket =
|
|
||||||
serverInstallationBox.get(BNames.backblazeBucket);
|
|
||||||
final String? serverType =
|
|
||||||
serverInstallationBox.get(BNames.serverTypeIdentifier);
|
|
||||||
final ServerProviderType? serverProvider =
|
|
||||||
serverInstallationBox.get(BNames.serverProvider);
|
|
||||||
final DnsProviderType? dnsProvider =
|
|
||||||
serverInstallationBox.get(BNames.dnsProvider);
|
|
||||||
|
|
||||||
if (serverProviderKey != null &&
|
// move server provider config
|
||||||
(serverProvider != null ||
|
|
||||||
(serverDetails != null &&
|
final ServerProviderType? serverProvider =
|
||||||
serverDetails.provider != ServerProviderType.unknown))) {
|
serverInstallationBox.get(BNames.serverProvider) ??
|
||||||
|
serverDetails?.provider;
|
||||||
|
final String? serverProviderKey =
|
||||||
|
serverInstallationBox.get(BNames.hetznerKey);
|
||||||
|
|
||||||
|
if (serverProviderKey != null && serverProvider.isSpecified) {
|
||||||
final ServerProviderCredential serverProviderCredential =
|
final ServerProviderCredential serverProviderCredential =
|
||||||
ServerProviderCredential(
|
ServerProviderCredential(
|
||||||
tokenId: null,
|
tokenId: null,
|
||||||
token: serverProviderKey,
|
token: serverProviderKey,
|
||||||
provider: serverProvider ?? serverDetails!.provider,
|
provider: serverProvider!,
|
||||||
associatedServerIds: serverDetails != null ? [serverDetails.id] : [],
|
associatedServerIds: [if (serverDetails != null) serverDetails.id],
|
||||||
);
|
);
|
||||||
|
|
||||||
await resourcesBox
|
await resourcesBox.put(
|
||||||
.put(BNames.serverProviderTokens, [serverProviderCredential]);
|
BNames.serverProviderTokens,
|
||||||
|
[serverProviderCredential],
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dnsProviderKey != null &&
|
final String? serverLocation =
|
||||||
(dnsProvider != null ||
|
serverInstallationBox.get(BNames.serverLocation);
|
||||||
(serverDomain != null &&
|
final String? serverType =
|
||||||
serverDomain.provider != DnsProviderType.unknown))) {
|
serverInstallationBox.get(BNames.serverTypeIdentifier);
|
||||||
|
final ServerDomain? serverDomain =
|
||||||
|
serverInstallationBox.get(BNames.serverDomain);
|
||||||
|
|
||||||
|
if (serverDetails != null && serverDomain != null) {
|
||||||
|
await resourcesBox.put(
|
||||||
|
BNames.servers,
|
||||||
|
[
|
||||||
|
Server(
|
||||||
|
domain: serverDomain,
|
||||||
|
hostingDetails: serverDetails.copyWith(
|
||||||
|
serverLocation: serverLocation,
|
||||||
|
serverType: serverType,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// move dns config
|
||||||
|
final String? dnsProviderKey =
|
||||||
|
serverInstallationBox.get(BNames.cloudFlareKey);
|
||||||
|
final DnsProviderType? dnsProvider =
|
||||||
|
serverInstallationBox.get(BNames.dnsProvider) ??
|
||||||
|
serverDomain?.provider;
|
||||||
|
|
||||||
|
if (dnsProviderKey != null && dnsProvider.isSpecified) {
|
||||||
final DnsProviderCredential dnsProviderCredential =
|
final DnsProviderCredential dnsProviderCredential =
|
||||||
DnsProviderCredential(
|
DnsProviderCredential(
|
||||||
tokenId: null,
|
tokenId: null,
|
||||||
token: dnsProviderKey,
|
token: dnsProviderKey,
|
||||||
provider: dnsProvider ?? serverDomain!.provider,
|
provider: dnsProvider!,
|
||||||
associatedDomainNames:
|
associatedDomainNames: [
|
||||||
serverDomain != null ? [serverDomain.domainName] : [],
|
if (serverDomain != null) serverDomain.domainName,
|
||||||
|
],
|
||||||
);
|
);
|
||||||
|
|
||||||
await resourcesBox
|
await resourcesBox
|
||||||
.put(BNames.dnsProviderTokens, [dnsProviderCredential]);
|
.put(BNames.dnsProviderTokens, [dnsProviderCredential]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// move backblaze (backups) config
|
||||||
|
final BackupsCredential? backblazeCredential =
|
||||||
|
serverInstallationBox.get(BNames.backblazeCredential);
|
||||||
|
final BackblazeBucket? backblazeBucket =
|
||||||
|
serverInstallationBox.get(BNames.backblazeBucket);
|
||||||
|
|
||||||
if (backblazeCredential != null) {
|
if (backblazeCredential != null) {
|
||||||
await resourcesBox
|
await resourcesBox
|
||||||
.put(BNames.backupsProviderTokens, [backblazeCredential]);
|
.put(BNames.backupsProviderTokens, [backblazeCredential]);
|
||||||
|
@ -197,20 +219,8 @@ class HiveConfig {
|
||||||
if (backblazeBucket != null) {
|
if (backblazeBucket != null) {
|
||||||
await resourcesBox.put(BNames.backblazeBucket, backblazeBucket);
|
await resourcesBox.put(BNames.backblazeBucket, backblazeBucket);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (serverDetails != null && serverDomain != null) {
|
|
||||||
await resourcesBox.put(BNames.servers, [
|
|
||||||
Server(
|
|
||||||
domain: serverDomain,
|
|
||||||
hostingDetails: serverDetails.copyWith(
|
|
||||||
serverLocation: serverLocation,
|
|
||||||
serverType: serverType,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
]);
|
|
||||||
}
|
}
|
||||||
}
|
log('successfully migrated db from 1 to 2 version');
|
||||||
log('successfully migration of db from 1 to 2 version');
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -118,3 +118,7 @@ enum ServerProviderType {
|
||||||
unknown => 'Unknown',
|
unknown => 'Unknown',
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extension ServerProviderTypeIsSpecified on ServerProviderType? {
|
||||||
|
bool get isSpecified => this != null && this != ServerProviderType.unknown;
|
||||||
|
}
|
||||||
|
|
|
@ -57,3 +57,7 @@ enum DnsProviderType {
|
||||||
unknown => 'Unknown',
|
unknown => 'Unknown',
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extension DnsProviderTypeIsSpecified on DnsProviderType? {
|
||||||
|
bool get isSpecified => this != null && this != DnsProviderType.unknown;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue