From 9f2d423cfe5f9a0a12ef6e7aa64011f26715799c Mon Sep 17 00:00:00 2001 From: Kingkor Roy Tirtho Date: Thu, 17 Oct 2024 22:33:03 +0600 Subject: [PATCH] feat: add invidious audio source and fix auto skipping tracks (#2005) * feat: add invidious audio source with automatic track switch even on server playback endpoint * fix: switching to different source on playback endpoint error not working * chore: update invidious version * feat: invidious instances customizability --- assets/invidious.jpg | Bin 0 -> 100201 bytes build.yaml | 2 + drift_schemas/app_db/drift_schema_v1.json | 1 + drift_schemas/app_db/drift_schema_v2.json | 1 + lib/collections/assets.gen.dart | 2 + lib/l10n/app_en.arb | 4 + lib/models/connect/connect.g.dart | 4 +- lib/models/database/database.dart | 16 +- lib/models/database/database.g.dart | 3170 ++++++++++------ lib/models/database/database.steps.dart | 652 ++++ lib/models/database/tables/preferences.dart | 6 +- lib/modules/player/sibling_tracks_sheet.dart | 12 + .../getting_started/sections/playback.dart | 9 +- lib/pages/settings/sections/playback.dart | 73 +- .../sources/invidious_instances_provider.dart | 12 + .../sources}/piped_instances_provider.dart | 0 lib/provider/server/routes/playback.dart | 44 +- lib/provider/server/sourced_track.dart | 56 +- .../user_preferences_provider.dart | 4 + .../sourced_track/models/source_info.g.dart | 2 +- .../sourced_track/models/video_info.dart | 21 + lib/services/sourced_track/sourced_track.dart | 76 +- .../sourced_track/sources/invidious.dart | 266 ++ pubspec.lock | 122 +- pubspec.yaml | 8 +- test/drift/app_db/generated/schema.dart | 23 + test/drift/app_db/generated/schema_v1.dart | 3333 ++++++++++++++++ test/drift/app_db/generated/schema_v2.dart | 3366 +++++++++++++++++ test/drift/app_db/migration_test.dart | 128 + untranslated_messages.json | 184 +- 30 files changed, 10402 insertions(+), 1195 deletions(-) create mode 100644 assets/invidious.jpg create mode 100644 drift_schemas/app_db/drift_schema_v1.json create mode 100644 drift_schemas/app_db/drift_schema_v2.json create mode 100644 lib/models/database/database.steps.dart create mode 100644 lib/provider/audio_player/sources/invidious_instances_provider.dart rename lib/provider/{ => audio_player/sources}/piped_instances_provider.dart (100%) create mode 100644 lib/services/sourced_track/sources/invidious.dart create mode 100644 test/drift/app_db/generated/schema.dart create mode 100644 test/drift/app_db/generated/schema_v1.dart create mode 100644 test/drift/app_db/generated/schema_v2.dart create mode 100644 test/drift/app_db/migration_test.dart diff --git a/assets/invidious.jpg b/assets/invidious.jpg new file mode 100644 index 0000000000000000000000000000000000000000..12c5f10762bb28f352c190e2afb29225d582b56b GIT binary patch literal 100201 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 Qdf=@G{{Q!Y`f|_z0f&V`6aWAK literal 0 HcmV?d00001 diff --git a/build.yaml b/build.yaml index 8dbfe45d..17d5bc50 100644 --- a/build.yaml +++ b/build.yaml @@ -10,6 +10,8 @@ targets: explicit_to_json: true drift_dev: options: + databases: + app_db: lib/models/database/database.dart sql: dialect: sqlite options: diff --git a/drift_schemas/app_db/drift_schema_v1.json b/drift_schemas/app_db/drift_schema_v1.json new file mode 100644 index 00000000..b894446c --- /dev/null +++ b/drift_schemas/app_db/drift_schema_v1.json @@ -0,0 +1 @@ +{"_meta":{"description":"This file contains a serialized version of schema entities for drift.","version":"1.2.0"},"options":{"store_date_time_values_as_text":false},"entities":[{"id":0,"references":[],"type":"table","data":{"name":"authentication_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"cookie","getter_name":"cookie","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"EncryptedTextConverter()","dart_type_name":"DecryptedText"}},{"name":"access_token","getter_name":"accessToken","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"EncryptedTextConverter()","dart_type_name":"DecryptedText"}},{"name":"expiration","getter_name":"expiration","moor_type":"dateTime","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":1,"references":[],"type":"table","data":{"name":"blacklist_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"name","getter_name":"name","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"element_type","getter_name":"elementType","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(BlacklistedType.values)","dart_type_name":"BlacklistedType"}},{"name":"element_id","getter_name":"elementId","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":2,"references":[],"type":"table","data":{"name":"preferences_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"audio_quality","getter_name":"audioQuality","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(SourceQualities.high.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(SourceQualities.values)","dart_type_name":"SourceQualities"}},{"name":"album_color_sync","getter_name":"albumColorSync","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"album_color_sync\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"album_color_sync\" IN (0, 1))"},"default_dart":"const Constant(true)","default_client_dart":null,"dsl_features":[]},{"name":"amoled_dark_theme","getter_name":"amoledDarkTheme","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"amoled_dark_theme\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"amoled_dark_theme\" IN (0, 1))"},"default_dart":"const Constant(false)","default_client_dart":null,"dsl_features":[]},{"name":"check_update","getter_name":"checkUpdate","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"check_update\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"check_update\" IN (0, 1))"},"default_dart":"const Constant(true)","default_client_dart":null,"dsl_features":[]},{"name":"normalize_audio","getter_name":"normalizeAudio","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"normalize_audio\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"normalize_audio\" IN (0, 1))"},"default_dart":"const Constant(false)","default_client_dart":null,"dsl_features":[]},{"name":"show_system_tray_icon","getter_name":"showSystemTrayIcon","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"show_system_tray_icon\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"show_system_tray_icon\" IN (0, 1))"},"default_dart":"const Constant(false)","default_client_dart":null,"dsl_features":[]},{"name":"system_title_bar","getter_name":"systemTitleBar","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"system_title_bar\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"system_title_bar\" IN (0, 1))"},"default_dart":"const Constant(false)","default_client_dart":null,"dsl_features":[]},{"name":"skip_non_music","getter_name":"skipNonMusic","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"skip_non_music\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"skip_non_music\" IN (0, 1))"},"default_dart":"const Constant(false)","default_client_dart":null,"dsl_features":[]},{"name":"close_behavior","getter_name":"closeBehavior","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(CloseBehavior.close.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(CloseBehavior.values)","dart_type_name":"CloseBehavior"}},{"name":"accent_color_scheme","getter_name":"accentColorScheme","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"const Constant(\"Blue:0xFF2196F3\")","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const SpotubeColorConverter()","dart_type_name":"SpotubeColor"}},{"name":"layout_mode","getter_name":"layoutMode","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(LayoutMode.adaptive.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(LayoutMode.values)","dart_type_name":"LayoutMode"}},{"name":"locale","getter_name":"locale","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"const Constant('{\"languageCode\":\"system\",\"countryCode\":\"system\"}')","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const LocaleConverter()","dart_type_name":"Locale"}},{"name":"market","getter_name":"market","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(Market.US.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(Market.values)","dart_type_name":"Market"}},{"name":"search_mode","getter_name":"searchMode","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(SearchMode.youtube.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(SearchMode.values)","dart_type_name":"SearchMode"}},{"name":"download_location","getter_name":"downloadLocation","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"const Constant(\"\")","default_client_dart":null,"dsl_features":[]},{"name":"local_library_location","getter_name":"localLibraryLocation","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"const Constant(\"\")","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const StringListConverter()","dart_type_name":"List"}},{"name":"piped_instance","getter_name":"pipedInstance","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"const Constant(\"https://pipedapi.kavin.rocks\")","default_client_dart":null,"dsl_features":[]},{"name":"theme_mode","getter_name":"themeMode","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(ThemeMode.system.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(ThemeMode.values)","dart_type_name":"ThemeMode"}},{"name":"audio_source","getter_name":"audioSource","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(AudioSource.youtube.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(AudioSource.values)","dart_type_name":"AudioSource"}},{"name":"stream_music_codec","getter_name":"streamMusicCodec","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(SourceCodecs.weba.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(SourceCodecs.values)","dart_type_name":"SourceCodecs"}},{"name":"download_music_codec","getter_name":"downloadMusicCodec","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(SourceCodecs.m4a.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(SourceCodecs.values)","dart_type_name":"SourceCodecs"}},{"name":"discord_presence","getter_name":"discordPresence","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"discord_presence\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"discord_presence\" IN (0, 1))"},"default_dart":"const Constant(true)","default_client_dart":null,"dsl_features":[]},{"name":"endless_playback","getter_name":"endlessPlayback","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"endless_playback\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"endless_playback\" IN (0, 1))"},"default_dart":"const Constant(true)","default_client_dart":null,"dsl_features":[]},{"name":"enable_connect","getter_name":"enableConnect","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"enable_connect\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"enable_connect\" IN (0, 1))"},"default_dart":"const Constant(false)","default_client_dart":null,"dsl_features":[]}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":3,"references":[],"type":"table","data":{"name":"scrobbler_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"created_at","getter_name":"createdAt","moor_type":"dateTime","nullable":false,"customConstraints":null,"default_dart":"currentDateAndTime","default_client_dart":null,"dsl_features":[]},{"name":"username","getter_name":"username","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"password_hash","getter_name":"passwordHash","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"EncryptedTextConverter()","dart_type_name":"DecryptedText"}}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":4,"references":[],"type":"table","data":{"name":"skip_segment_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"start","getter_name":"start","moor_type":"int","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"end","getter_name":"end","moor_type":"int","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"track_id","getter_name":"trackId","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"created_at","getter_name":"createdAt","moor_type":"dateTime","nullable":false,"customConstraints":null,"default_dart":"currentDateAndTime","default_client_dart":null,"dsl_features":[]}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":5,"references":[],"type":"table","data":{"name":"source_match_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"track_id","getter_name":"trackId","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"source_id","getter_name":"sourceId","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"source_type","getter_name":"sourceType","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(SourceType.youtube.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(SourceType.values)","dart_type_name":"SourceType"}},{"name":"created_at","getter_name":"createdAt","moor_type":"dateTime","nullable":false,"customConstraints":null,"default_dart":"currentDateAndTime","default_client_dart":null,"dsl_features":[]}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":6,"references":[],"type":"table","data":{"name":"audio_player_state_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"playing","getter_name":"playing","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"playing\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"playing\" IN (0, 1))"},"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"loop_mode","getter_name":"loopMode","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(PlaylistMode.values)","dart_type_name":"PlaylistMode"}},{"name":"shuffled","getter_name":"shuffled","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"shuffled\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"shuffled\" IN (0, 1))"},"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"collections","getter_name":"collections","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const StringListConverter()","dart_type_name":"List"}}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":7,"references":[6],"type":"table","data":{"name":"playlist_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"audio_player_state_id","getter_name":"audioPlayerStateId","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"REFERENCES audio_player_state_table (id)","dialectAwareDefaultConstraints":{"sqlite":"REFERENCES audio_player_state_table (id)"},"default_dart":null,"default_client_dart":null,"dsl_features":["unknown"]},{"name":"index","getter_name":"index","moor_type":"int","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":8,"references":[7],"type":"table","data":{"name":"playlist_media_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"playlist_id","getter_name":"playlistId","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"REFERENCES playlist_table (id)","dialectAwareDefaultConstraints":{"sqlite":"REFERENCES playlist_table (id)"},"default_dart":null,"default_client_dart":null,"dsl_features":["unknown"]},{"name":"uri","getter_name":"uri","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"extras","getter_name":"extras","moor_type":"string","nullable":true,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const MapTypeConverter()","dart_type_name":"Map"}},{"name":"http_headers","getter_name":"httpHeaders","moor_type":"string","nullable":true,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const MapTypeConverter()","dart_type_name":"Map"}}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":9,"references":[],"type":"table","data":{"name":"history_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"created_at","getter_name":"createdAt","moor_type":"dateTime","nullable":false,"customConstraints":null,"default_dart":"currentDateAndTime","default_client_dart":null,"dsl_features":[]},{"name":"type","getter_name":"type","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(HistoryEntryType.values)","dart_type_name":"HistoryEntryType"}},{"name":"item_id","getter_name":"itemId","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"data","getter_name":"data","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const MapTypeConverter()","dart_type_name":"Map"}}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":10,"references":[],"type":"table","data":{"name":"lyrics_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"track_id","getter_name":"trackId","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"data","getter_name":"data","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"SubtitleTypeConverter()","dart_type_name":"SubtitleSimple"}}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":11,"references":[1],"type":"index","data":{"on":1,"name":"unique_blacklist","sql":null,"unique":true,"columns":["element_type","element_id"]}},{"id":12,"references":[5],"type":"index","data":{"on":5,"name":"uniq_track_match","sql":null,"unique":true,"columns":["track_id","source_id","source_type"]}}]} \ No newline at end of file diff --git a/drift_schemas/app_db/drift_schema_v2.json b/drift_schemas/app_db/drift_schema_v2.json new file mode 100644 index 00000000..668afb3f --- /dev/null +++ b/drift_schemas/app_db/drift_schema_v2.json @@ -0,0 +1 @@ +{"_meta":{"description":"This file contains a serialized version of schema entities for drift.","version":"1.2.0"},"options":{"store_date_time_values_as_text":false},"entities":[{"id":0,"references":[],"type":"table","data":{"name":"authentication_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"cookie","getter_name":"cookie","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"EncryptedTextConverter()","dart_type_name":"DecryptedText"}},{"name":"access_token","getter_name":"accessToken","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"EncryptedTextConverter()","dart_type_name":"DecryptedText"}},{"name":"expiration","getter_name":"expiration","moor_type":"dateTime","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":1,"references":[],"type":"table","data":{"name":"blacklist_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"name","getter_name":"name","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"element_type","getter_name":"elementType","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(BlacklistedType.values)","dart_type_name":"BlacklistedType"}},{"name":"element_id","getter_name":"elementId","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":2,"references":[],"type":"table","data":{"name":"preferences_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"audio_quality","getter_name":"audioQuality","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(SourceQualities.high.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(SourceQualities.values)","dart_type_name":"SourceQualities"}},{"name":"album_color_sync","getter_name":"albumColorSync","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"album_color_sync\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"album_color_sync\" IN (0, 1))"},"default_dart":"const Constant(true)","default_client_dart":null,"dsl_features":[]},{"name":"amoled_dark_theme","getter_name":"amoledDarkTheme","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"amoled_dark_theme\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"amoled_dark_theme\" IN (0, 1))"},"default_dart":"const Constant(false)","default_client_dart":null,"dsl_features":[]},{"name":"check_update","getter_name":"checkUpdate","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"check_update\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"check_update\" IN (0, 1))"},"default_dart":"const Constant(true)","default_client_dart":null,"dsl_features":[]},{"name":"normalize_audio","getter_name":"normalizeAudio","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"normalize_audio\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"normalize_audio\" IN (0, 1))"},"default_dart":"const Constant(false)","default_client_dart":null,"dsl_features":[]},{"name":"show_system_tray_icon","getter_name":"showSystemTrayIcon","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"show_system_tray_icon\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"show_system_tray_icon\" IN (0, 1))"},"default_dart":"const Constant(false)","default_client_dart":null,"dsl_features":[]},{"name":"system_title_bar","getter_name":"systemTitleBar","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"system_title_bar\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"system_title_bar\" IN (0, 1))"},"default_dart":"const Constant(false)","default_client_dart":null,"dsl_features":[]},{"name":"skip_non_music","getter_name":"skipNonMusic","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"skip_non_music\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"skip_non_music\" IN (0, 1))"},"default_dart":"const Constant(false)","default_client_dart":null,"dsl_features":[]},{"name":"close_behavior","getter_name":"closeBehavior","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(CloseBehavior.close.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(CloseBehavior.values)","dart_type_name":"CloseBehavior"}},{"name":"accent_color_scheme","getter_name":"accentColorScheme","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"const Constant(\"Blue:0xFF2196F3\")","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const SpotubeColorConverter()","dart_type_name":"SpotubeColor"}},{"name":"layout_mode","getter_name":"layoutMode","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(LayoutMode.adaptive.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(LayoutMode.values)","dart_type_name":"LayoutMode"}},{"name":"locale","getter_name":"locale","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"const Constant('{\"languageCode\":\"system\",\"countryCode\":\"system\"}')","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const LocaleConverter()","dart_type_name":"Locale"}},{"name":"market","getter_name":"market","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(Market.US.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(Market.values)","dart_type_name":"Market"}},{"name":"search_mode","getter_name":"searchMode","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(SearchMode.youtube.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(SearchMode.values)","dart_type_name":"SearchMode"}},{"name":"download_location","getter_name":"downloadLocation","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"const Constant(\"\")","default_client_dart":null,"dsl_features":[]},{"name":"local_library_location","getter_name":"localLibraryLocation","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"const Constant(\"\")","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const StringListConverter()","dart_type_name":"List"}},{"name":"piped_instance","getter_name":"pipedInstance","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"const Constant(\"https://pipedapi.kavin.rocks\")","default_client_dart":null,"dsl_features":[]},{"name":"invidious_instance","getter_name":"invidiousInstance","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"const Constant(\"https://inv.nadeko.net\")","default_client_dart":null,"dsl_features":[]},{"name":"theme_mode","getter_name":"themeMode","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(ThemeMode.system.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(ThemeMode.values)","dart_type_name":"ThemeMode"}},{"name":"audio_source","getter_name":"audioSource","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(AudioSource.youtube.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(AudioSource.values)","dart_type_name":"AudioSource"}},{"name":"stream_music_codec","getter_name":"streamMusicCodec","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(SourceCodecs.weba.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(SourceCodecs.values)","dart_type_name":"SourceCodecs"}},{"name":"download_music_codec","getter_name":"downloadMusicCodec","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(SourceCodecs.m4a.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(SourceCodecs.values)","dart_type_name":"SourceCodecs"}},{"name":"discord_presence","getter_name":"discordPresence","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"discord_presence\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"discord_presence\" IN (0, 1))"},"default_dart":"const Constant(true)","default_client_dart":null,"dsl_features":[]},{"name":"endless_playback","getter_name":"endlessPlayback","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"endless_playback\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"endless_playback\" IN (0, 1))"},"default_dart":"const Constant(true)","default_client_dart":null,"dsl_features":[]},{"name":"enable_connect","getter_name":"enableConnect","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"enable_connect\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"enable_connect\" IN (0, 1))"},"default_dart":"const Constant(false)","default_client_dart":null,"dsl_features":[]}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":3,"references":[],"type":"table","data":{"name":"scrobbler_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"created_at","getter_name":"createdAt","moor_type":"dateTime","nullable":false,"customConstraints":null,"default_dart":"currentDateAndTime","default_client_dart":null,"dsl_features":[]},{"name":"username","getter_name":"username","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"password_hash","getter_name":"passwordHash","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"EncryptedTextConverter()","dart_type_name":"DecryptedText"}}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":4,"references":[],"type":"table","data":{"name":"skip_segment_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"start","getter_name":"start","moor_type":"int","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"end","getter_name":"end","moor_type":"int","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"track_id","getter_name":"trackId","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"created_at","getter_name":"createdAt","moor_type":"dateTime","nullable":false,"customConstraints":null,"default_dart":"currentDateAndTime","default_client_dart":null,"dsl_features":[]}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":5,"references":[],"type":"table","data":{"name":"source_match_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"track_id","getter_name":"trackId","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"source_id","getter_name":"sourceId","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"source_type","getter_name":"sourceType","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":"Constant(SourceType.youtube.name)","default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(SourceType.values)","dart_type_name":"SourceType"}},{"name":"created_at","getter_name":"createdAt","moor_type":"dateTime","nullable":false,"customConstraints":null,"default_dart":"currentDateAndTime","default_client_dart":null,"dsl_features":[]}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":6,"references":[],"type":"table","data":{"name":"audio_player_state_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"playing","getter_name":"playing","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"playing\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"playing\" IN (0, 1))"},"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"loop_mode","getter_name":"loopMode","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(PlaylistMode.values)","dart_type_name":"PlaylistMode"}},{"name":"shuffled","getter_name":"shuffled","moor_type":"bool","nullable":false,"customConstraints":null,"defaultConstraints":"CHECK (\"shuffled\" IN (0, 1))","dialectAwareDefaultConstraints":{"sqlite":"CHECK (\"shuffled\" IN (0, 1))"},"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"collections","getter_name":"collections","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const StringListConverter()","dart_type_name":"List"}}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":7,"references":[6],"type":"table","data":{"name":"playlist_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"audio_player_state_id","getter_name":"audioPlayerStateId","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"REFERENCES audio_player_state_table (id)","dialectAwareDefaultConstraints":{"sqlite":"REFERENCES audio_player_state_table (id)"},"default_dart":null,"default_client_dart":null,"dsl_features":["unknown"]},{"name":"index","getter_name":"index","moor_type":"int","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":8,"references":[7],"type":"table","data":{"name":"playlist_media_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"playlist_id","getter_name":"playlistId","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"REFERENCES playlist_table (id)","dialectAwareDefaultConstraints":{"sqlite":"REFERENCES playlist_table (id)"},"default_dart":null,"default_client_dart":null,"dsl_features":["unknown"]},{"name":"uri","getter_name":"uri","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"extras","getter_name":"extras","moor_type":"string","nullable":true,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const MapTypeConverter()","dart_type_name":"Map"}},{"name":"http_headers","getter_name":"httpHeaders","moor_type":"string","nullable":true,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const MapTypeConverter()","dart_type_name":"Map"}}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":9,"references":[],"type":"table","data":{"name":"history_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"created_at","getter_name":"createdAt","moor_type":"dateTime","nullable":false,"customConstraints":null,"default_dart":"currentDateAndTime","default_client_dart":null,"dsl_features":[]},{"name":"type","getter_name":"type","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const EnumNameConverter(HistoryEntryType.values)","dart_type_name":"HistoryEntryType"}},{"name":"item_id","getter_name":"itemId","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"data","getter_name":"data","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"const MapTypeConverter()","dart_type_name":"Map"}}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":10,"references":[],"type":"table","data":{"name":"lyrics_table","was_declared_in_moor":false,"columns":[{"name":"id","getter_name":"id","moor_type":"int","nullable":false,"customConstraints":null,"defaultConstraints":"PRIMARY KEY AUTOINCREMENT","dialectAwareDefaultConstraints":{"sqlite":"PRIMARY KEY AUTOINCREMENT"},"default_dart":null,"default_client_dart":null,"dsl_features":["auto-increment"]},{"name":"track_id","getter_name":"trackId","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[]},{"name":"data","getter_name":"data","moor_type":"string","nullable":false,"customConstraints":null,"default_dart":null,"default_client_dart":null,"dsl_features":[],"type_converter":{"dart_expr":"SubtitleTypeConverter()","dart_type_name":"SubtitleSimple"}}],"is_virtual":false,"without_rowid":false,"constraints":[]}},{"id":11,"references":[1],"type":"index","data":{"on":1,"name":"unique_blacklist","sql":null,"unique":true,"columns":["element_type","element_id"]}},{"id":12,"references":[5],"type":"index","data":{"on":5,"name":"uniq_track_match","sql":null,"unique":true,"columns":["track_id","source_id","source_type"]}}]} \ No newline at end of file diff --git a/lib/collections/assets.gen.dart b/lib/collections/assets.gen.dart index cff5b74f..f10242e8 100644 --- a/lib/collections/assets.gen.dart +++ b/lib/collections/assets.gen.dart @@ -49,6 +49,7 @@ class Assets { AssetGenImage('assets/bengali-patterns-bg.jpg'); static const AssetGenImage branding = AssetGenImage('assets/branding.png'); static const AssetGenImage emptyBox = AssetGenImage('assets/empty_box.png'); + static const AssetGenImage invidious = AssetGenImage('assets/invidious.jpg'); static const AssetGenImage jiosaavn = AssetGenImage('assets/jiosaavn.png'); static const AssetGenImage likedTracks = AssetGenImage('assets/liked-tracks.jpg'); @@ -95,6 +96,7 @@ class Assets { bengaliPatternsBg, branding, emptyBox, + invidious, jiosaavn, likedTracks, placeholder, diff --git a/lib/l10n/app_en.arb b/lib/l10n/app_en.arb index c63f8543..27a64c87 100644 --- a/lib/l10n/app_en.arb +++ b/lib/l10n/app_en.arb @@ -190,6 +190,9 @@ "piped_instance": "Piped Server Instance", "piped_description": "The Piped server instance to use for track matching", "piped_warning": "Some of them might not work well. So use at your own risk", + "invidious_instance": "Invidious Server Instance", + "invidious_description": "The Invidious server instance to use for track matching", + "invidious_warning": "Some of them might not work well. So use at your own risk", "generate_playlist": "Generate Playlist", "track_exists": "Track {track} already exists", "replace_downloaded_tracks": "Replace all downloaded tracks", @@ -307,6 +310,7 @@ "youtube_source_description": "Recommended and works best.", "piped_source_description": "Feeling free? Same as YouTube but a lot free.", "jiosaavn_source_description": "Best for South Asian region.", + "invidious_source_description": "Similar to Piped but with higher availability.", "highest_quality": "Highest Quality: {quality}", "select_audio_source": "Select Audio Source", "endless_playback_description": "Automatically append new songs\nto the end of the queue", diff --git a/lib/models/connect/connect.g.dart b/lib/models/connect/connect.g.dart index f297024b..10f46c65 100644 --- a/lib/models/connect/connect.g.dart +++ b/lib/models/connect/connect.g.dart @@ -16,7 +16,7 @@ _$WebSocketLoadEventDataPlaylistImpl ? null : PlaylistSimple.fromJson( Map.from(json['collection'] as Map)), - initialIndex: json['initialIndex'] as int?, + initialIndex: (json['initialIndex'] as num?)?.toInt(), $type: json['runtimeType'] as String?, ); @@ -39,7 +39,7 @@ _$WebSocketLoadEventDataAlbumImpl _$$WebSocketLoadEventDataAlbumImplFromJson( ? null : AlbumSimple.fromJson( Map.from(json['collection'] as Map)), - initialIndex: json['initialIndex'] as int?, + initialIndex: (json['initialIndex'] as num?)?.toInt(), $type: json['runtimeType'] as String?, ); diff --git a/lib/models/database/database.dart b/lib/models/database/database.dart index 412e6868..8bb32bd5 100644 --- a/lib/models/database/database.dart +++ b/lib/models/database/database.dart @@ -9,6 +9,7 @@ import 'package:media_kit/media_kit.dart' hide Track; import 'package:path/path.dart'; import 'package:path_provider/path_provider.dart'; import 'package:spotify/spotify.dart' hide Playlist; +import 'package:spotube/models/database/database.steps.dart'; import 'package:spotube/models/lyrics.dart'; import 'package:spotube/services/kv_store/encrypted_kv_store.dart'; import 'package:spotube/services/kv_store/kv_store.dart'; @@ -57,7 +58,20 @@ class AppDatabase extends _$AppDatabase { AppDatabase() : super(_openConnection()); @override - int get schemaVersion => 1; + int get schemaVersion => 2; + + @override + MigrationStrategy get migration { + return MigrationStrategy( + onUpgrade: stepByStep(from1To2: (m, schema) async { + // Add invidiousInstance column to preferences table + await m.addColumn( + schema.preferencesTable, + schema.preferencesTable.invidiousInstance, + ); + }), + ); + } } LazyDatabase _openConnection() { diff --git a/lib/models/database/database.g.dart b/lib/models/database/database.g.dart index 1e585fa8..def70bd2 100644 --- a/lib/models/database/database.g.dart +++ b/lib/models/database/database.g.dart @@ -167,6 +167,17 @@ class AuthenticationTableData extends DataClass accessToken: accessToken ?? this.accessToken, expiration: expiration ?? this.expiration, ); + AuthenticationTableData copyWithCompanion(AuthenticationTableCompanion data) { + return AuthenticationTableData( + id: data.id.present ? data.id.value : this.id, + cookie: data.cookie.present ? data.cookie.value : this.cookie, + accessToken: + data.accessToken.present ? data.accessToken.value : this.accessToken, + expiration: + data.expiration.present ? data.expiration.value : this.expiration, + ); + } + @override String toString() { return (StringBuffer('AuthenticationTableData(') @@ -430,6 +441,16 @@ class BlacklistTableData extends DataClass elementType: elementType ?? this.elementType, elementId: elementId ?? this.elementId, ); + BlacklistTableData copyWithCompanion(BlacklistTableCompanion data) { + return BlacklistTableData( + id: data.id.present ? data.id.value : this.id, + name: data.name.present ? data.name.value : this.name, + elementType: + data.elementType.present ? data.elementType.value : this.elementType, + elementId: data.elementId.present ? data.elementId.value : this.elementId, + ); + } + @override String toString() { return (StringBuffer('BlacklistTableData(') @@ -712,6 +733,14 @@ class $PreferencesTableTable extends PreferencesTable type: DriftSqlType.string, requiredDuringInsert: false, defaultValue: const Constant("https://pipedapi.kavin.rocks")); + static const VerificationMeta _invidiousInstanceMeta = + const VerificationMeta('invidiousInstance'); + @override + late final GeneratedColumn invidiousInstance = + GeneratedColumn('invidious_instance', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: const Constant("https://inv.nadeko.net")); static const VerificationMeta _themeModeMeta = const VerificationMeta('themeMode'); @override @@ -803,6 +832,7 @@ class $PreferencesTableTable extends PreferencesTable downloadLocation, localLibraryLocation, pipedInstance, + invidiousInstance, themeMode, audioSource, streamMusicCodec, @@ -888,6 +918,12 @@ class $PreferencesTableTable extends PreferencesTable pipedInstance.isAcceptableOrUnknown( data['piped_instance']!, _pipedInstanceMeta)); } + if (data.containsKey('invidious_instance')) { + context.handle( + _invidiousInstanceMeta, + invidiousInstance.isAcceptableOrUnknown( + data['invidious_instance']!, _invidiousInstanceMeta)); + } context.handle(_themeModeMeta, const VerificationResult.success()); context.handle(_audioSourceMeta, const VerificationResult.success()); context.handle(_streamMusicCodecMeta, const VerificationResult.success()); @@ -964,6 +1000,8 @@ class $PreferencesTableTable extends PreferencesTable data['${effectivePrefix}local_library_location'])!), pipedInstance: attachedDatabase.typeMapping .read(DriftSqlType.string, data['${effectivePrefix}piped_instance'])!, + invidiousInstance: attachedDatabase.typeMapping.read( + DriftSqlType.string, data['${effectivePrefix}invidious_instance'])!, themeMode: $PreferencesTableTable.$converterthemeMode.fromSql( attachedDatabase.typeMapping.read( DriftSqlType.string, data['${effectivePrefix}theme_mode'])!), @@ -1040,6 +1078,7 @@ class PreferencesTableData extends DataClass final String downloadLocation; final List localLibraryLocation; final String pipedInstance; + final String invidiousInstance; final ThemeMode themeMode; final AudioSource audioSource; final SourceCodecs streamMusicCodec; @@ -1066,6 +1105,7 @@ class PreferencesTableData extends DataClass required this.downloadLocation, required this.localLibraryLocation, required this.pipedInstance, + required this.invidiousInstance, required this.themeMode, required this.audioSource, required this.streamMusicCodec, @@ -1120,6 +1160,7 @@ class PreferencesTableData extends DataClass .toSql(localLibraryLocation)); } map['piped_instance'] = Variable(pipedInstance); + map['invidious_instance'] = Variable(invidiousInstance); { map['theme_mode'] = Variable( $PreferencesTableTable.$converterthemeMode.toSql(themeMode)); @@ -1164,6 +1205,7 @@ class PreferencesTableData extends DataClass downloadLocation: Value(downloadLocation), localLibraryLocation: Value(localLibraryLocation), pipedInstance: Value(pipedInstance), + invidiousInstance: Value(invidiousInstance), themeMode: Value(themeMode), audioSource: Value(audioSource), streamMusicCodec: Value(streamMusicCodec), @@ -1203,6 +1245,7 @@ class PreferencesTableData extends DataClass localLibraryLocation: serializer.fromJson>(json['localLibraryLocation']), pipedInstance: serializer.fromJson(json['pipedInstance']), + invidiousInstance: serializer.fromJson(json['invidiousInstance']), themeMode: $PreferencesTableTable.$converterthemeMode .fromJson(serializer.fromJson(json['themeMode'])), audioSource: $PreferencesTableTable.$converteraudioSource @@ -1244,6 +1287,7 @@ class PreferencesTableData extends DataClass 'localLibraryLocation': serializer.toJson>(localLibraryLocation), 'pipedInstance': serializer.toJson(pipedInstance), + 'invidiousInstance': serializer.toJson(invidiousInstance), 'themeMode': serializer.toJson( $PreferencesTableTable.$converterthemeMode.toJson(themeMode)), 'audioSource': serializer.toJson( @@ -1279,6 +1323,7 @@ class PreferencesTableData extends DataClass String? downloadLocation, List? localLibraryLocation, String? pipedInstance, + String? invidiousInstance, ThemeMode? themeMode, AudioSource? audioSource, SourceCodecs? streamMusicCodec, @@ -1305,6 +1350,7 @@ class PreferencesTableData extends DataClass downloadLocation: downloadLocation ?? this.downloadLocation, localLibraryLocation: localLibraryLocation ?? this.localLibraryLocation, pipedInstance: pipedInstance ?? this.pipedInstance, + invidiousInstance: invidiousInstance ?? this.invidiousInstance, themeMode: themeMode ?? this.themeMode, audioSource: audioSource ?? this.audioSource, streamMusicCodec: streamMusicCodec ?? this.streamMusicCodec, @@ -1313,6 +1359,77 @@ class PreferencesTableData extends DataClass endlessPlayback: endlessPlayback ?? this.endlessPlayback, enableConnect: enableConnect ?? this.enableConnect, ); + PreferencesTableData copyWithCompanion(PreferencesTableCompanion data) { + return PreferencesTableData( + id: data.id.present ? data.id.value : this.id, + audioQuality: data.audioQuality.present + ? data.audioQuality.value + : this.audioQuality, + albumColorSync: data.albumColorSync.present + ? data.albumColorSync.value + : this.albumColorSync, + amoledDarkTheme: data.amoledDarkTheme.present + ? data.amoledDarkTheme.value + : this.amoledDarkTheme, + checkUpdate: + data.checkUpdate.present ? data.checkUpdate.value : this.checkUpdate, + normalizeAudio: data.normalizeAudio.present + ? data.normalizeAudio.value + : this.normalizeAudio, + showSystemTrayIcon: data.showSystemTrayIcon.present + ? data.showSystemTrayIcon.value + : this.showSystemTrayIcon, + systemTitleBar: data.systemTitleBar.present + ? data.systemTitleBar.value + : this.systemTitleBar, + skipNonMusic: data.skipNonMusic.present + ? data.skipNonMusic.value + : this.skipNonMusic, + closeBehavior: data.closeBehavior.present + ? data.closeBehavior.value + : this.closeBehavior, + accentColorScheme: data.accentColorScheme.present + ? data.accentColorScheme.value + : this.accentColorScheme, + layoutMode: + data.layoutMode.present ? data.layoutMode.value : this.layoutMode, + locale: data.locale.present ? data.locale.value : this.locale, + market: data.market.present ? data.market.value : this.market, + searchMode: + data.searchMode.present ? data.searchMode.value : this.searchMode, + downloadLocation: data.downloadLocation.present + ? data.downloadLocation.value + : this.downloadLocation, + localLibraryLocation: data.localLibraryLocation.present + ? data.localLibraryLocation.value + : this.localLibraryLocation, + pipedInstance: data.pipedInstance.present + ? data.pipedInstance.value + : this.pipedInstance, + invidiousInstance: data.invidiousInstance.present + ? data.invidiousInstance.value + : this.invidiousInstance, + themeMode: data.themeMode.present ? data.themeMode.value : this.themeMode, + audioSource: + data.audioSource.present ? data.audioSource.value : this.audioSource, + streamMusicCodec: data.streamMusicCodec.present + ? data.streamMusicCodec.value + : this.streamMusicCodec, + downloadMusicCodec: data.downloadMusicCodec.present + ? data.downloadMusicCodec.value + : this.downloadMusicCodec, + discordPresence: data.discordPresence.present + ? data.discordPresence.value + : this.discordPresence, + endlessPlayback: data.endlessPlayback.present + ? data.endlessPlayback.value + : this.endlessPlayback, + enableConnect: data.enableConnect.present + ? data.enableConnect.value + : this.enableConnect, + ); + } + @override String toString() { return (StringBuffer('PreferencesTableData(') @@ -1334,6 +1451,7 @@ class PreferencesTableData extends DataClass ..write('downloadLocation: $downloadLocation, ') ..write('localLibraryLocation: $localLibraryLocation, ') ..write('pipedInstance: $pipedInstance, ') + ..write('invidiousInstance: $invidiousInstance, ') ..write('themeMode: $themeMode, ') ..write('audioSource: $audioSource, ') ..write('streamMusicCodec: $streamMusicCodec, ') @@ -1365,6 +1483,7 @@ class PreferencesTableData extends DataClass downloadLocation, localLibraryLocation, pipedInstance, + invidiousInstance, themeMode, audioSource, streamMusicCodec, @@ -1395,6 +1514,7 @@ class PreferencesTableData extends DataClass other.downloadLocation == this.downloadLocation && other.localLibraryLocation == this.localLibraryLocation && other.pipedInstance == this.pipedInstance && + other.invidiousInstance == this.invidiousInstance && other.themeMode == this.themeMode && other.audioSource == this.audioSource && other.streamMusicCodec == this.streamMusicCodec && @@ -1423,6 +1543,7 @@ class PreferencesTableCompanion extends UpdateCompanion { final Value downloadLocation; final Value> localLibraryLocation; final Value pipedInstance; + final Value invidiousInstance; final Value themeMode; final Value audioSource; final Value streamMusicCodec; @@ -1449,6 +1570,7 @@ class PreferencesTableCompanion extends UpdateCompanion { this.downloadLocation = const Value.absent(), this.localLibraryLocation = const Value.absent(), this.pipedInstance = const Value.absent(), + this.invidiousInstance = const Value.absent(), this.themeMode = const Value.absent(), this.audioSource = const Value.absent(), this.streamMusicCodec = const Value.absent(), @@ -1476,6 +1598,7 @@ class PreferencesTableCompanion extends UpdateCompanion { this.downloadLocation = const Value.absent(), this.localLibraryLocation = const Value.absent(), this.pipedInstance = const Value.absent(), + this.invidiousInstance = const Value.absent(), this.themeMode = const Value.absent(), this.audioSource = const Value.absent(), this.streamMusicCodec = const Value.absent(), @@ -1503,6 +1626,7 @@ class PreferencesTableCompanion extends UpdateCompanion { Expression? downloadLocation, Expression? localLibraryLocation, Expression? pipedInstance, + Expression? invidiousInstance, Expression? themeMode, Expression? audioSource, Expression? streamMusicCodec, @@ -1532,6 +1656,7 @@ class PreferencesTableCompanion extends UpdateCompanion { if (localLibraryLocation != null) 'local_library_location': localLibraryLocation, if (pipedInstance != null) 'piped_instance': pipedInstance, + if (invidiousInstance != null) 'invidious_instance': invidiousInstance, if (themeMode != null) 'theme_mode': themeMode, if (audioSource != null) 'audio_source': audioSource, if (streamMusicCodec != null) 'stream_music_codec': streamMusicCodec, @@ -1562,6 +1687,7 @@ class PreferencesTableCompanion extends UpdateCompanion { Value? downloadLocation, Value>? localLibraryLocation, Value? pipedInstance, + Value? invidiousInstance, Value? themeMode, Value? audioSource, Value? streamMusicCodec, @@ -1588,6 +1714,7 @@ class PreferencesTableCompanion extends UpdateCompanion { downloadLocation: downloadLocation ?? this.downloadLocation, localLibraryLocation: localLibraryLocation ?? this.localLibraryLocation, pipedInstance: pipedInstance ?? this.pipedInstance, + invidiousInstance: invidiousInstance ?? this.invidiousInstance, themeMode: themeMode ?? this.themeMode, audioSource: audioSource ?? this.audioSource, streamMusicCodec: streamMusicCodec ?? this.streamMusicCodec, @@ -1667,6 +1794,9 @@ class PreferencesTableCompanion extends UpdateCompanion { if (pipedInstance.present) { map['piped_instance'] = Variable(pipedInstance.value); } + if (invidiousInstance.present) { + map['invidious_instance'] = Variable(invidiousInstance.value); + } if (themeMode.present) { map['theme_mode'] = Variable( $PreferencesTableTable.$converterthemeMode.toSql(themeMode.value)); @@ -1719,6 +1849,7 @@ class PreferencesTableCompanion extends UpdateCompanion { ..write('downloadLocation: $downloadLocation, ') ..write('localLibraryLocation: $localLibraryLocation, ') ..write('pipedInstance: $pipedInstance, ') + ..write('invidiousInstance: $invidiousInstance, ') ..write('themeMode: $themeMode, ') ..write('audioSource: $audioSource, ') ..write('streamMusicCodec: $streamMusicCodec, ') @@ -1890,6 +2021,17 @@ class ScrobblerTableData extends DataClass username: username ?? this.username, passwordHash: passwordHash ?? this.passwordHash, ); + ScrobblerTableData copyWithCompanion(ScrobblerTableCompanion data) { + return ScrobblerTableData( + id: data.id.present ? data.id.value : this.id, + createdAt: data.createdAt.present ? data.createdAt.value : this.createdAt, + username: data.username.present ? data.username.value : this.username, + passwordHash: data.passwordHash.present + ? data.passwordHash.value + : this.passwordHash, + ); + } + @override String toString() { return (StringBuffer('ScrobblerTableData(') @@ -2165,6 +2307,16 @@ class SkipSegmentTableData extends DataClass trackId: trackId ?? this.trackId, createdAt: createdAt ?? this.createdAt, ); + SkipSegmentTableData copyWithCompanion(SkipSegmentTableCompanion data) { + return SkipSegmentTableData( + id: data.id.present ? data.id.value : this.id, + start: data.start.present ? data.start.value : this.start, + end: data.end.present ? data.end.value : this.end, + trackId: data.trackId.present ? data.trackId.value : this.trackId, + createdAt: data.createdAt.present ? data.createdAt.value : this.createdAt, + ); + } + @override String toString() { return (StringBuffer('SkipSegmentTableData(') @@ -2463,6 +2615,17 @@ class SourceMatchTableData extends DataClass sourceType: sourceType ?? this.sourceType, createdAt: createdAt ?? this.createdAt, ); + SourceMatchTableData copyWithCompanion(SourceMatchTableCompanion data) { + return SourceMatchTableData( + id: data.id.present ? data.id.value : this.id, + trackId: data.trackId.present ? data.trackId.value : this.trackId, + sourceId: data.sourceId.present ? data.sourceId.value : this.sourceId, + sourceType: + data.sourceType.present ? data.sourceType.value : this.sourceType, + createdAt: data.createdAt.present ? data.createdAt.value : this.createdAt, + ); + } + @override String toString() { return (StringBuffer('SourceMatchTableData(') @@ -2769,6 +2932,18 @@ class AudioPlayerStateTableData extends DataClass shuffled: shuffled ?? this.shuffled, collections: collections ?? this.collections, ); + AudioPlayerStateTableData copyWithCompanion( + AudioPlayerStateTableCompanion data) { + return AudioPlayerStateTableData( + id: data.id.present ? data.id.value : this.id, + playing: data.playing.present ? data.playing.value : this.playing, + loopMode: data.loopMode.present ? data.loopMode.value : this.loopMode, + shuffled: data.shuffled.present ? data.shuffled.value : this.shuffled, + collections: + data.collections.present ? data.collections.value : this.collections, + ); + } + @override String toString() { return (StringBuffer('AudioPlayerStateTableData(') @@ -3019,6 +3194,16 @@ class PlaylistTableData extends DataClass audioPlayerStateId: audioPlayerStateId ?? this.audioPlayerStateId, index: index ?? this.index, ); + PlaylistTableData copyWithCompanion(PlaylistTableCompanion data) { + return PlaylistTableData( + id: data.id.present ? data.id.value : this.id, + audioPlayerStateId: data.audioPlayerStateId.present + ? data.audioPlayerStateId.value + : this.audioPlayerStateId, + index: data.index.present ? data.index.value : this.index, + ); + } + @override String toString() { return (StringBuffer('PlaylistTableData(') @@ -3210,11 +3395,11 @@ class $PlaylistMediaTableTable extends PlaylistMediaTable } static TypeConverter, String> $converterextras = - const MapTypeConverter(); + const MapTypeConverter(); static TypeConverter?, String?> $converterextrasn = NullAwareTypeConverter.wrap($converterextras); static TypeConverter, String> $converterhttpHeaders = - const MapTypeConverter(); + const MapTypeConverter(); static TypeConverter?, String?> $converterhttpHeadersn = NullAwareTypeConverter.wrap($converterhttpHeaders); } @@ -3299,6 +3484,18 @@ class PlaylistMediaTableData extends DataClass extras: extras.present ? extras.value : this.extras, httpHeaders: httpHeaders.present ? httpHeaders.value : this.httpHeaders, ); + PlaylistMediaTableData copyWithCompanion(PlaylistMediaTableCompanion data) { + return PlaylistMediaTableData( + id: data.id.present ? data.id.value : this.id, + playlistId: + data.playlistId.present ? data.playlistId.value : this.playlistId, + uri: data.uri.present ? data.uri.value : this.uri, + extras: data.extras.present ? data.extras.value : this.extras, + httpHeaders: + data.httpHeaders.present ? data.httpHeaders.value : this.httpHeaders, + ); + } + @override String toString() { return (StringBuffer('PlaylistMediaTableData(') @@ -3514,7 +3711,7 @@ class $HistoryTableTable extends HistoryTable static JsonTypeConverter2 $convertertype = const EnumNameConverter(HistoryEntryType.values); static TypeConverter, String> $converterdata = - const MapTypeConverter(); + const MapTypeConverter(); } class HistoryTableData extends DataClass @@ -3595,6 +3792,16 @@ class HistoryTableData extends DataClass itemId: itemId ?? this.itemId, data: data ?? this.data, ); + HistoryTableData copyWithCompanion(HistoryTableCompanion data) { + return HistoryTableData( + id: data.id.present ? data.id.value : this.id, + createdAt: data.createdAt.present ? data.createdAt.value : this.createdAt, + type: data.type.present ? data.type.value : this.type, + itemId: data.itemId.present ? data.itemId.value : this.itemId, + data: data.data.present ? data.data.value : this.data, + ); + } + @override String toString() { return (StringBuffer('HistoryTableData(') @@ -3837,6 +4044,14 @@ class LyricsTableData extends DataClass implements Insertable { trackId: trackId ?? this.trackId, data: data ?? this.data, ); + LyricsTableData copyWithCompanion(LyricsTableCompanion data) { + return LyricsTableData( + id: data.id.present ? data.id.value : this.id, + trackId: data.trackId.present ? data.trackId.value : this.trackId, + data: data.data.present ? data.data.value : this.data, + ); + } + @override String toString() { return (StringBuffer('LyricsTableData(') @@ -3923,7 +4138,7 @@ class LyricsTableCompanion extends UpdateCompanion { abstract class _$AppDatabase extends GeneratedDatabase { _$AppDatabase(QueryExecutor e) : super(e); - _$AppDatabaseManager get managers => _$AppDatabaseManager(this); + $AppDatabaseManager get managers => $AppDatabaseManager(this); late final $AuthenticationTableTable authenticationTable = $AuthenticationTableTable(this); late final $BlacklistTableTable blacklistTable = $BlacklistTableTable(this); @@ -3966,7 +4181,7 @@ abstract class _$AppDatabase extends GeneratedDatabase { ]; } -typedef $$AuthenticationTableTableInsertCompanionBuilder +typedef $$AuthenticationTableTableCreateCompanionBuilder = AuthenticationTableCompanion Function({ Value id, required DecryptedText cookie, @@ -3981,27 +4196,107 @@ typedef $$AuthenticationTableTableUpdateCompanionBuilder Value expiration, }); +class $$AuthenticationTableTableFilterComposer + extends Composer<_$AppDatabase, $AuthenticationTableTable> { + $$AuthenticationTableTableFilterComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnFilters get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters + get cookie => $composableBuilder( + column: $table.cookie, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnWithTypeConverterFilters + get accessToken => $composableBuilder( + column: $table.accessToken, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnFilters get expiration => $composableBuilder( + column: $table.expiration, builder: (column) => ColumnFilters(column)); +} + +class $$AuthenticationTableTableOrderingComposer + extends Composer<_$AppDatabase, $AuthenticationTableTable> { + $$AuthenticationTableTableOrderingComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnOrderings get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get cookie => $composableBuilder( + column: $table.cookie, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get accessToken => $composableBuilder( + column: $table.accessToken, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get expiration => $composableBuilder( + column: $table.expiration, builder: (column) => ColumnOrderings(column)); +} + +class $$AuthenticationTableTableAnnotationComposer + extends Composer<_$AppDatabase, $AuthenticationTableTable> { + $$AuthenticationTableTableAnnotationComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + GeneratedColumn get id => + $composableBuilder(column: $table.id, builder: (column) => column); + + GeneratedColumnWithTypeConverter get cookie => + $composableBuilder(column: $table.cookie, builder: (column) => column); + + GeneratedColumnWithTypeConverter get accessToken => + $composableBuilder( + column: $table.accessToken, builder: (column) => column); + + GeneratedColumn get expiration => $composableBuilder( + column: $table.expiration, builder: (column) => column); +} + class $$AuthenticationTableTableTableManager extends RootTableManager< _$AppDatabase, $AuthenticationTableTable, AuthenticationTableData, $$AuthenticationTableTableFilterComposer, $$AuthenticationTableTableOrderingComposer, - $$AuthenticationTableTableProcessedTableManager, - $$AuthenticationTableTableInsertCompanionBuilder, - $$AuthenticationTableTableUpdateCompanionBuilder> { + $$AuthenticationTableTableAnnotationComposer, + $$AuthenticationTableTableCreateCompanionBuilder, + $$AuthenticationTableTableUpdateCompanionBuilder, + ( + AuthenticationTableData, + BaseReferences<_$AppDatabase, $AuthenticationTableTable, + AuthenticationTableData> + ), + AuthenticationTableData, + PrefetchHooks Function()> { $$AuthenticationTableTableTableManager( _$AppDatabase db, $AuthenticationTableTable table) : super(TableManagerState( db: db, table: table, - filteringComposer: $$AuthenticationTableTableFilterComposer( - ComposerState(db, table)), - orderingComposer: $$AuthenticationTableTableOrderingComposer( - ComposerState(db, table)), - getChildManagerBuilder: (p) => - $$AuthenticationTableTableProcessedTableManager(p), - getUpdateCompanionBuilder: ({ + createFilteringComposer: () => + $$AuthenticationTableTableFilterComposer($db: db, $table: table), + createOrderingComposer: () => + $$AuthenticationTableTableOrderingComposer( + $db: db, $table: table), + createComputedFieldComposer: () => + $$AuthenticationTableTableAnnotationComposer( + $db: db, $table: table), + updateCompanionCallback: ({ Value id = const Value.absent(), Value cookie = const Value.absent(), Value accessToken = const Value.absent(), @@ -4013,7 +4308,7 @@ class $$AuthenticationTableTableTableManager extends RootTableManager< accessToken: accessToken, expiration: expiration, ), - getInsertCompanionBuilder: ({ + createCompanionCallback: ({ Value id = const Value.absent(), required DecryptedText cookie, required DecryptedText accessToken, @@ -4025,75 +4320,30 @@ class $$AuthenticationTableTableTableManager extends RootTableManager< accessToken: accessToken, expiration: expiration, ), + withReferenceMapper: (p0) => p0 + .map((e) => (e.readTable(table), BaseReferences(db, table, e))) + .toList(), + prefetchHooksCallback: null, )); } -class $$AuthenticationTableTableProcessedTableManager - extends ProcessedTableManager< - _$AppDatabase, - $AuthenticationTableTable, - AuthenticationTableData, - $$AuthenticationTableTableFilterComposer, - $$AuthenticationTableTableOrderingComposer, - $$AuthenticationTableTableProcessedTableManager, - $$AuthenticationTableTableInsertCompanionBuilder, - $$AuthenticationTableTableUpdateCompanionBuilder> { - $$AuthenticationTableTableProcessedTableManager(super.$state); -} - -class $$AuthenticationTableTableFilterComposer - extends FilterComposer<_$AppDatabase, $AuthenticationTableTable> { - $$AuthenticationTableTableFilterComposer(super.$state); - ColumnFilters get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get cookie => $state.composableBuilder( - column: $state.table.cookie, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get accessToken => $state.composableBuilder( - column: $state.table.accessToken, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnFilters get expiration => $state.composableBuilder( - column: $state.table.expiration, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); -} - -class $$AuthenticationTableTableOrderingComposer - extends OrderingComposer<_$AppDatabase, $AuthenticationTableTable> { - $$AuthenticationTableTableOrderingComposer(super.$state); - ColumnOrderings get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get cookie => $state.composableBuilder( - column: $state.table.cookie, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get accessToken => $state.composableBuilder( - column: $state.table.accessToken, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get expiration => $state.composableBuilder( - column: $state.table.expiration, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); -} - -typedef $$BlacklistTableTableInsertCompanionBuilder = BlacklistTableCompanion +typedef $$AuthenticationTableTableProcessedTableManager = ProcessedTableManager< + _$AppDatabase, + $AuthenticationTableTable, + AuthenticationTableData, + $$AuthenticationTableTableFilterComposer, + $$AuthenticationTableTableOrderingComposer, + $$AuthenticationTableTableAnnotationComposer, + $$AuthenticationTableTableCreateCompanionBuilder, + $$AuthenticationTableTableUpdateCompanionBuilder, + ( + AuthenticationTableData, + BaseReferences<_$AppDatabase, $AuthenticationTableTable, + AuthenticationTableData> + ), + AuthenticationTableData, + PrefetchHooks Function()>; +typedef $$BlacklistTableTableCreateCompanionBuilder = BlacklistTableCompanion Function({ Value id, required String name, @@ -4108,27 +4358,102 @@ typedef $$BlacklistTableTableUpdateCompanionBuilder = BlacklistTableCompanion Value elementId, }); +class $$BlacklistTableTableFilterComposer + extends Composer<_$AppDatabase, $BlacklistTableTable> { + $$BlacklistTableTableFilterComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnFilters get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnFilters(column)); + + ColumnFilters get name => $composableBuilder( + column: $table.name, builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters + get elementType => $composableBuilder( + column: $table.elementType, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnFilters get elementId => $composableBuilder( + column: $table.elementId, builder: (column) => ColumnFilters(column)); +} + +class $$BlacklistTableTableOrderingComposer + extends Composer<_$AppDatabase, $BlacklistTableTable> { + $$BlacklistTableTableOrderingComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnOrderings get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get name => $composableBuilder( + column: $table.name, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get elementType => $composableBuilder( + column: $table.elementType, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get elementId => $composableBuilder( + column: $table.elementId, builder: (column) => ColumnOrderings(column)); +} + +class $$BlacklistTableTableAnnotationComposer + extends Composer<_$AppDatabase, $BlacklistTableTable> { + $$BlacklistTableTableAnnotationComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + GeneratedColumn get id => + $composableBuilder(column: $table.id, builder: (column) => column); + + GeneratedColumn get name => + $composableBuilder(column: $table.name, builder: (column) => column); + + GeneratedColumnWithTypeConverter get elementType => + $composableBuilder( + column: $table.elementType, builder: (column) => column); + + GeneratedColumn get elementId => + $composableBuilder(column: $table.elementId, builder: (column) => column); +} + class $$BlacklistTableTableTableManager extends RootTableManager< _$AppDatabase, $BlacklistTableTable, BlacklistTableData, $$BlacklistTableTableFilterComposer, $$BlacklistTableTableOrderingComposer, - $$BlacklistTableTableProcessedTableManager, - $$BlacklistTableTableInsertCompanionBuilder, - $$BlacklistTableTableUpdateCompanionBuilder> { + $$BlacklistTableTableAnnotationComposer, + $$BlacklistTableTableCreateCompanionBuilder, + $$BlacklistTableTableUpdateCompanionBuilder, + ( + BlacklistTableData, + BaseReferences<_$AppDatabase, $BlacklistTableTable, BlacklistTableData> + ), + BlacklistTableData, + PrefetchHooks Function()> { $$BlacklistTableTableTableManager( _$AppDatabase db, $BlacklistTableTable table) : super(TableManagerState( db: db, table: table, - filteringComposer: - $$BlacklistTableTableFilterComposer(ComposerState(db, table)), - orderingComposer: - $$BlacklistTableTableOrderingComposer(ComposerState(db, table)), - getChildManagerBuilder: (p) => - $$BlacklistTableTableProcessedTableManager(p), - getUpdateCompanionBuilder: ({ + createFilteringComposer: () => + $$BlacklistTableTableFilterComposer($db: db, $table: table), + createOrderingComposer: () => + $$BlacklistTableTableOrderingComposer($db: db, $table: table), + createComputedFieldComposer: () => + $$BlacklistTableTableAnnotationComposer($db: db, $table: table), + updateCompanionCallback: ({ Value id = const Value.absent(), Value name = const Value.absent(), Value elementType = const Value.absent(), @@ -4140,7 +4465,7 @@ class $$BlacklistTableTableTableManager extends RootTableManager< elementType: elementType, elementId: elementId, ), - getInsertCompanionBuilder: ({ + createCompanionCallback: ({ Value id = const Value.absent(), required String name, required BlacklistedType elementType, @@ -4152,72 +4477,29 @@ class $$BlacklistTableTableTableManager extends RootTableManager< elementType: elementType, elementId: elementId, ), + withReferenceMapper: (p0) => p0 + .map((e) => (e.readTable(table), BaseReferences(db, table, e))) + .toList(), + prefetchHooksCallback: null, )); } -class $$BlacklistTableTableProcessedTableManager extends ProcessedTableManager< +typedef $$BlacklistTableTableProcessedTableManager = ProcessedTableManager< _$AppDatabase, $BlacklistTableTable, BlacklistTableData, $$BlacklistTableTableFilterComposer, $$BlacklistTableTableOrderingComposer, - $$BlacklistTableTableProcessedTableManager, - $$BlacklistTableTableInsertCompanionBuilder, - $$BlacklistTableTableUpdateCompanionBuilder> { - $$BlacklistTableTableProcessedTableManager(super.$state); -} - -class $$BlacklistTableTableFilterComposer - extends FilterComposer<_$AppDatabase, $BlacklistTableTable> { - $$BlacklistTableTableFilterComposer(super.$state); - ColumnFilters get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get name => $state.composableBuilder( - column: $state.table.name, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get elementType => $state.composableBuilder( - column: $state.table.elementType, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnFilters get elementId => $state.composableBuilder( - column: $state.table.elementId, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); -} - -class $$BlacklistTableTableOrderingComposer - extends OrderingComposer<_$AppDatabase, $BlacklistTableTable> { - $$BlacklistTableTableOrderingComposer(super.$state); - ColumnOrderings get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get name => $state.composableBuilder( - column: $state.table.name, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get elementType => $state.composableBuilder( - column: $state.table.elementType, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get elementId => $state.composableBuilder( - column: $state.table.elementId, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); -} - -typedef $$PreferencesTableTableInsertCompanionBuilder + $$BlacklistTableTableAnnotationComposer, + $$BlacklistTableTableCreateCompanionBuilder, + $$BlacklistTableTableUpdateCompanionBuilder, + ( + BlacklistTableData, + BaseReferences<_$AppDatabase, $BlacklistTableTable, BlacklistTableData> + ), + BlacklistTableData, + PrefetchHooks Function()>; +typedef $$PreferencesTableTableCreateCompanionBuilder = PreferencesTableCompanion Function({ Value id, Value audioQuality, @@ -4237,6 +4519,7 @@ typedef $$PreferencesTableTableInsertCompanionBuilder Value downloadLocation, Value> localLibraryLocation, Value pipedInstance, + Value invidiousInstance, Value themeMode, Value audioSource, Value streamMusicCodec, @@ -4265,6 +4548,7 @@ typedef $$PreferencesTableTableUpdateCompanionBuilder Value downloadLocation, Value> localLibraryLocation, Value pipedInstance, + Value invidiousInstance, Value themeMode, Value audioSource, Value streamMusicCodec, @@ -4274,27 +4558,358 @@ typedef $$PreferencesTableTableUpdateCompanionBuilder Value enableConnect, }); +class $$PreferencesTableTableFilterComposer + extends Composer<_$AppDatabase, $PreferencesTableTable> { + $$PreferencesTableTableFilterComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnFilters get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters + get audioQuality => $composableBuilder( + column: $table.audioQuality, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnFilters get albumColorSync => $composableBuilder( + column: $table.albumColorSync, + builder: (column) => ColumnFilters(column)); + + ColumnFilters get amoledDarkTheme => $composableBuilder( + column: $table.amoledDarkTheme, + builder: (column) => ColumnFilters(column)); + + ColumnFilters get checkUpdate => $composableBuilder( + column: $table.checkUpdate, builder: (column) => ColumnFilters(column)); + + ColumnFilters get normalizeAudio => $composableBuilder( + column: $table.normalizeAudio, + builder: (column) => ColumnFilters(column)); + + ColumnFilters get showSystemTrayIcon => $composableBuilder( + column: $table.showSystemTrayIcon, + builder: (column) => ColumnFilters(column)); + + ColumnFilters get systemTitleBar => $composableBuilder( + column: $table.systemTitleBar, + builder: (column) => ColumnFilters(column)); + + ColumnFilters get skipNonMusic => $composableBuilder( + column: $table.skipNonMusic, builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters + get closeBehavior => $composableBuilder( + column: $table.closeBehavior, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnWithTypeConverterFilters + get accentColorScheme => $composableBuilder( + column: $table.accentColorScheme, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnWithTypeConverterFilters + get layoutMode => $composableBuilder( + column: $table.layoutMode, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnWithTypeConverterFilters get locale => + $composableBuilder( + column: $table.locale, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnWithTypeConverterFilters get market => + $composableBuilder( + column: $table.market, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnWithTypeConverterFilters + get searchMode => $composableBuilder( + column: $table.searchMode, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnFilters get downloadLocation => $composableBuilder( + column: $table.downloadLocation, + builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters, List, String> + get localLibraryLocation => $composableBuilder( + column: $table.localLibraryLocation, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnFilters get pipedInstance => $composableBuilder( + column: $table.pipedInstance, builder: (column) => ColumnFilters(column)); + + ColumnFilters get invidiousInstance => $composableBuilder( + column: $table.invidiousInstance, + builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters get themeMode => + $composableBuilder( + column: $table.themeMode, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnWithTypeConverterFilters + get audioSource => $composableBuilder( + column: $table.audioSource, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnWithTypeConverterFilters + get streamMusicCodec => $composableBuilder( + column: $table.streamMusicCodec, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnWithTypeConverterFilters + get downloadMusicCodec => $composableBuilder( + column: $table.downloadMusicCodec, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnFilters get discordPresence => $composableBuilder( + column: $table.discordPresence, + builder: (column) => ColumnFilters(column)); + + ColumnFilters get endlessPlayback => $composableBuilder( + column: $table.endlessPlayback, + builder: (column) => ColumnFilters(column)); + + ColumnFilters get enableConnect => $composableBuilder( + column: $table.enableConnect, builder: (column) => ColumnFilters(column)); +} + +class $$PreferencesTableTableOrderingComposer + extends Composer<_$AppDatabase, $PreferencesTableTable> { + $$PreferencesTableTableOrderingComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnOrderings get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get audioQuality => $composableBuilder( + column: $table.audioQuality, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get albumColorSync => $composableBuilder( + column: $table.albumColorSync, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get amoledDarkTheme => $composableBuilder( + column: $table.amoledDarkTheme, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get checkUpdate => $composableBuilder( + column: $table.checkUpdate, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get normalizeAudio => $composableBuilder( + column: $table.normalizeAudio, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get showSystemTrayIcon => $composableBuilder( + column: $table.showSystemTrayIcon, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get systemTitleBar => $composableBuilder( + column: $table.systemTitleBar, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get skipNonMusic => $composableBuilder( + column: $table.skipNonMusic, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get closeBehavior => $composableBuilder( + column: $table.closeBehavior, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get accentColorScheme => $composableBuilder( + column: $table.accentColorScheme, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get layoutMode => $composableBuilder( + column: $table.layoutMode, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get locale => $composableBuilder( + column: $table.locale, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get market => $composableBuilder( + column: $table.market, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get searchMode => $composableBuilder( + column: $table.searchMode, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get downloadLocation => $composableBuilder( + column: $table.downloadLocation, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get localLibraryLocation => $composableBuilder( + column: $table.localLibraryLocation, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get pipedInstance => $composableBuilder( + column: $table.pipedInstance, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get invidiousInstance => $composableBuilder( + column: $table.invidiousInstance, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get themeMode => $composableBuilder( + column: $table.themeMode, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get audioSource => $composableBuilder( + column: $table.audioSource, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get streamMusicCodec => $composableBuilder( + column: $table.streamMusicCodec, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get downloadMusicCodec => $composableBuilder( + column: $table.downloadMusicCodec, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get discordPresence => $composableBuilder( + column: $table.discordPresence, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get endlessPlayback => $composableBuilder( + column: $table.endlessPlayback, + builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get enableConnect => $composableBuilder( + column: $table.enableConnect, + builder: (column) => ColumnOrderings(column)); +} + +class $$PreferencesTableTableAnnotationComposer + extends Composer<_$AppDatabase, $PreferencesTableTable> { + $$PreferencesTableTableAnnotationComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + GeneratedColumn get id => + $composableBuilder(column: $table.id, builder: (column) => column); + + GeneratedColumnWithTypeConverter get audioQuality => + $composableBuilder( + column: $table.audioQuality, builder: (column) => column); + + GeneratedColumn get albumColorSync => $composableBuilder( + column: $table.albumColorSync, builder: (column) => column); + + GeneratedColumn get amoledDarkTheme => $composableBuilder( + column: $table.amoledDarkTheme, builder: (column) => column); + + GeneratedColumn get checkUpdate => $composableBuilder( + column: $table.checkUpdate, builder: (column) => column); + + GeneratedColumn get normalizeAudio => $composableBuilder( + column: $table.normalizeAudio, builder: (column) => column); + + GeneratedColumn get showSystemTrayIcon => $composableBuilder( + column: $table.showSystemTrayIcon, builder: (column) => column); + + GeneratedColumn get systemTitleBar => $composableBuilder( + column: $table.systemTitleBar, builder: (column) => column); + + GeneratedColumn get skipNonMusic => $composableBuilder( + column: $table.skipNonMusic, builder: (column) => column); + + GeneratedColumnWithTypeConverter get closeBehavior => + $composableBuilder( + column: $table.closeBehavior, builder: (column) => column); + + GeneratedColumnWithTypeConverter + get accentColorScheme => $composableBuilder( + column: $table.accentColorScheme, builder: (column) => column); + + GeneratedColumnWithTypeConverter get layoutMode => + $composableBuilder( + column: $table.layoutMode, builder: (column) => column); + + GeneratedColumnWithTypeConverter get locale => + $composableBuilder(column: $table.locale, builder: (column) => column); + + GeneratedColumnWithTypeConverter get market => + $composableBuilder(column: $table.market, builder: (column) => column); + + GeneratedColumnWithTypeConverter get searchMode => + $composableBuilder( + column: $table.searchMode, builder: (column) => column); + + GeneratedColumn get downloadLocation => $composableBuilder( + column: $table.downloadLocation, builder: (column) => column); + + GeneratedColumnWithTypeConverter, String> + get localLibraryLocation => $composableBuilder( + column: $table.localLibraryLocation, builder: (column) => column); + + GeneratedColumn get pipedInstance => $composableBuilder( + column: $table.pipedInstance, builder: (column) => column); + + GeneratedColumn get invidiousInstance => $composableBuilder( + column: $table.invidiousInstance, builder: (column) => column); + + GeneratedColumnWithTypeConverter get themeMode => + $composableBuilder(column: $table.themeMode, builder: (column) => column); + + GeneratedColumnWithTypeConverter get audioSource => + $composableBuilder( + column: $table.audioSource, builder: (column) => column); + + GeneratedColumnWithTypeConverter get streamMusicCodec => + $composableBuilder( + column: $table.streamMusicCodec, builder: (column) => column); + + GeneratedColumnWithTypeConverter + get downloadMusicCodec => $composableBuilder( + column: $table.downloadMusicCodec, builder: (column) => column); + + GeneratedColumn get discordPresence => $composableBuilder( + column: $table.discordPresence, builder: (column) => column); + + GeneratedColumn get endlessPlayback => $composableBuilder( + column: $table.endlessPlayback, builder: (column) => column); + + GeneratedColumn get enableConnect => $composableBuilder( + column: $table.enableConnect, builder: (column) => column); +} + class $$PreferencesTableTableTableManager extends RootTableManager< _$AppDatabase, $PreferencesTableTable, PreferencesTableData, $$PreferencesTableTableFilterComposer, $$PreferencesTableTableOrderingComposer, - $$PreferencesTableTableProcessedTableManager, - $$PreferencesTableTableInsertCompanionBuilder, - $$PreferencesTableTableUpdateCompanionBuilder> { + $$PreferencesTableTableAnnotationComposer, + $$PreferencesTableTableCreateCompanionBuilder, + $$PreferencesTableTableUpdateCompanionBuilder, + ( + PreferencesTableData, + BaseReferences<_$AppDatabase, $PreferencesTableTable, + PreferencesTableData> + ), + PreferencesTableData, + PrefetchHooks Function()> { $$PreferencesTableTableTableManager( _$AppDatabase db, $PreferencesTableTable table) : super(TableManagerState( db: db, table: table, - filteringComposer: - $$PreferencesTableTableFilterComposer(ComposerState(db, table)), - orderingComposer: - $$PreferencesTableTableOrderingComposer(ComposerState(db, table)), - getChildManagerBuilder: (p) => - $$PreferencesTableTableProcessedTableManager(p), - getUpdateCompanionBuilder: ({ + createFilteringComposer: () => + $$PreferencesTableTableFilterComposer($db: db, $table: table), + createOrderingComposer: () => + $$PreferencesTableTableOrderingComposer($db: db, $table: table), + createComputedFieldComposer: () => + $$PreferencesTableTableAnnotationComposer($db: db, $table: table), + updateCompanionCallback: ({ Value id = const Value.absent(), Value audioQuality = const Value.absent(), Value albumColorSync = const Value.absent(), @@ -4313,6 +4928,7 @@ class $$PreferencesTableTableTableManager extends RootTableManager< Value downloadLocation = const Value.absent(), Value> localLibraryLocation = const Value.absent(), Value pipedInstance = const Value.absent(), + Value invidiousInstance = const Value.absent(), Value themeMode = const Value.absent(), Value audioSource = const Value.absent(), Value streamMusicCodec = const Value.absent(), @@ -4340,6 +4956,7 @@ class $$PreferencesTableTableTableManager extends RootTableManager< downloadLocation: downloadLocation, localLibraryLocation: localLibraryLocation, pipedInstance: pipedInstance, + invidiousInstance: invidiousInstance, themeMode: themeMode, audioSource: audioSource, streamMusicCodec: streamMusicCodec, @@ -4348,7 +4965,7 @@ class $$PreferencesTableTableTableManager extends RootTableManager< endlessPlayback: endlessPlayback, enableConnect: enableConnect, ), - getInsertCompanionBuilder: ({ + createCompanionCallback: ({ Value id = const Value.absent(), Value audioQuality = const Value.absent(), Value albumColorSync = const Value.absent(), @@ -4367,6 +4984,7 @@ class $$PreferencesTableTableTableManager extends RootTableManager< Value downloadLocation = const Value.absent(), Value> localLibraryLocation = const Value.absent(), Value pipedInstance = const Value.absent(), + Value invidiousInstance = const Value.absent(), Value themeMode = const Value.absent(), Value audioSource = const Value.absent(), Value streamMusicCodec = const Value.absent(), @@ -4394,6 +5012,7 @@ class $$PreferencesTableTableTableManager extends RootTableManager< downloadLocation: downloadLocation, localLibraryLocation: localLibraryLocation, pipedInstance: pipedInstance, + invidiousInstance: invidiousInstance, themeMode: themeMode, audioSource: audioSource, streamMusicCodec: streamMusicCodec, @@ -4402,305 +5021,30 @@ class $$PreferencesTableTableTableManager extends RootTableManager< endlessPlayback: endlessPlayback, enableConnect: enableConnect, ), + withReferenceMapper: (p0) => p0 + .map((e) => (e.readTable(table), BaseReferences(db, table, e))) + .toList(), + prefetchHooksCallback: null, )); } -class $$PreferencesTableTableProcessedTableManager - extends ProcessedTableManager< - _$AppDatabase, - $PreferencesTableTable, - PreferencesTableData, - $$PreferencesTableTableFilterComposer, - $$PreferencesTableTableOrderingComposer, - $$PreferencesTableTableProcessedTableManager, - $$PreferencesTableTableInsertCompanionBuilder, - $$PreferencesTableTableUpdateCompanionBuilder> { - $$PreferencesTableTableProcessedTableManager(super.$state); -} - -class $$PreferencesTableTableFilterComposer - extends FilterComposer<_$AppDatabase, $PreferencesTableTable> { - $$PreferencesTableTableFilterComposer(super.$state); - ColumnFilters get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get audioQuality => $state.composableBuilder( - column: $state.table.audioQuality, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnFilters get albumColorSync => $state.composableBuilder( - column: $state.table.albumColorSync, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get amoledDarkTheme => $state.composableBuilder( - column: $state.table.amoledDarkTheme, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get checkUpdate => $state.composableBuilder( - column: $state.table.checkUpdate, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get normalizeAudio => $state.composableBuilder( - column: $state.table.normalizeAudio, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get showSystemTrayIcon => $state.composableBuilder( - column: $state.table.showSystemTrayIcon, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get systemTitleBar => $state.composableBuilder( - column: $state.table.systemTitleBar, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get skipNonMusic => $state.composableBuilder( - column: $state.table.skipNonMusic, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get closeBehavior => $state.composableBuilder( - column: $state.table.closeBehavior, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get accentColorScheme => $state.composableBuilder( - column: $state.table.accentColorScheme, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get layoutMode => $state.composableBuilder( - column: $state.table.layoutMode, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters get locale => - $state.composableBuilder( - column: $state.table.locale, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters get market => - $state.composableBuilder( - column: $state.table.market, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get searchMode => $state.composableBuilder( - column: $state.table.searchMode, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnFilters get downloadLocation => $state.composableBuilder( - column: $state.table.downloadLocation, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters, List, String> - get localLibraryLocation => $state.composableBuilder( - column: $state.table.localLibraryLocation, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnFilters get pipedInstance => $state.composableBuilder( - column: $state.table.pipedInstance, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters get themeMode => - $state.composableBuilder( - column: $state.table.themeMode, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get audioSource => $state.composableBuilder( - column: $state.table.audioSource, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get streamMusicCodec => $state.composableBuilder( - column: $state.table.streamMusicCodec, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get downloadMusicCodec => $state.composableBuilder( - column: $state.table.downloadMusicCodec, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnFilters get discordPresence => $state.composableBuilder( - column: $state.table.discordPresence, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get endlessPlayback => $state.composableBuilder( - column: $state.table.endlessPlayback, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get enableConnect => $state.composableBuilder( - column: $state.table.enableConnect, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); -} - -class $$PreferencesTableTableOrderingComposer - extends OrderingComposer<_$AppDatabase, $PreferencesTableTable> { - $$PreferencesTableTableOrderingComposer(super.$state); - ColumnOrderings get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get audioQuality => $state.composableBuilder( - column: $state.table.audioQuality, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get albumColorSync => $state.composableBuilder( - column: $state.table.albumColorSync, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get amoledDarkTheme => $state.composableBuilder( - column: $state.table.amoledDarkTheme, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get checkUpdate => $state.composableBuilder( - column: $state.table.checkUpdate, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get normalizeAudio => $state.composableBuilder( - column: $state.table.normalizeAudio, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get showSystemTrayIcon => $state.composableBuilder( - column: $state.table.showSystemTrayIcon, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get systemTitleBar => $state.composableBuilder( - column: $state.table.systemTitleBar, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get skipNonMusic => $state.composableBuilder( - column: $state.table.skipNonMusic, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get closeBehavior => $state.composableBuilder( - column: $state.table.closeBehavior, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get accentColorScheme => $state.composableBuilder( - column: $state.table.accentColorScheme, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get layoutMode => $state.composableBuilder( - column: $state.table.layoutMode, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get locale => $state.composableBuilder( - column: $state.table.locale, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get market => $state.composableBuilder( - column: $state.table.market, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get searchMode => $state.composableBuilder( - column: $state.table.searchMode, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get downloadLocation => $state.composableBuilder( - column: $state.table.downloadLocation, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get localLibraryLocation => $state.composableBuilder( - column: $state.table.localLibraryLocation, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get pipedInstance => $state.composableBuilder( - column: $state.table.pipedInstance, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get themeMode => $state.composableBuilder( - column: $state.table.themeMode, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get audioSource => $state.composableBuilder( - column: $state.table.audioSource, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get streamMusicCodec => $state.composableBuilder( - column: $state.table.streamMusicCodec, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get downloadMusicCodec => $state.composableBuilder( - column: $state.table.downloadMusicCodec, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get discordPresence => $state.composableBuilder( - column: $state.table.discordPresence, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get endlessPlayback => $state.composableBuilder( - column: $state.table.endlessPlayback, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get enableConnect => $state.composableBuilder( - column: $state.table.enableConnect, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); -} - -typedef $$ScrobblerTableTableInsertCompanionBuilder = ScrobblerTableCompanion +typedef $$PreferencesTableTableProcessedTableManager = ProcessedTableManager< + _$AppDatabase, + $PreferencesTableTable, + PreferencesTableData, + $$PreferencesTableTableFilterComposer, + $$PreferencesTableTableOrderingComposer, + $$PreferencesTableTableAnnotationComposer, + $$PreferencesTableTableCreateCompanionBuilder, + $$PreferencesTableTableUpdateCompanionBuilder, + ( + PreferencesTableData, + BaseReferences<_$AppDatabase, $PreferencesTableTable, + PreferencesTableData> + ), + PreferencesTableData, + PrefetchHooks Function()>; +typedef $$ScrobblerTableTableCreateCompanionBuilder = ScrobblerTableCompanion Function({ Value id, Value createdAt, @@ -4715,27 +5059,103 @@ typedef $$ScrobblerTableTableUpdateCompanionBuilder = ScrobblerTableCompanion Value passwordHash, }); +class $$ScrobblerTableTableFilterComposer + extends Composer<_$AppDatabase, $ScrobblerTableTable> { + $$ScrobblerTableTableFilterComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnFilters get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnFilters(column)); + + ColumnFilters get createdAt => $composableBuilder( + column: $table.createdAt, builder: (column) => ColumnFilters(column)); + + ColumnFilters get username => $composableBuilder( + column: $table.username, builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters + get passwordHash => $composableBuilder( + column: $table.passwordHash, + builder: (column) => ColumnWithTypeConverterFilters(column)); +} + +class $$ScrobblerTableTableOrderingComposer + extends Composer<_$AppDatabase, $ScrobblerTableTable> { + $$ScrobblerTableTableOrderingComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnOrderings get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get createdAt => $composableBuilder( + column: $table.createdAt, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get username => $composableBuilder( + column: $table.username, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get passwordHash => $composableBuilder( + column: $table.passwordHash, + builder: (column) => ColumnOrderings(column)); +} + +class $$ScrobblerTableTableAnnotationComposer + extends Composer<_$AppDatabase, $ScrobblerTableTable> { + $$ScrobblerTableTableAnnotationComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + GeneratedColumn get id => + $composableBuilder(column: $table.id, builder: (column) => column); + + GeneratedColumn get createdAt => + $composableBuilder(column: $table.createdAt, builder: (column) => column); + + GeneratedColumn get username => + $composableBuilder(column: $table.username, builder: (column) => column); + + GeneratedColumnWithTypeConverter get passwordHash => + $composableBuilder( + column: $table.passwordHash, builder: (column) => column); +} + class $$ScrobblerTableTableTableManager extends RootTableManager< _$AppDatabase, $ScrobblerTableTable, ScrobblerTableData, $$ScrobblerTableTableFilterComposer, $$ScrobblerTableTableOrderingComposer, - $$ScrobblerTableTableProcessedTableManager, - $$ScrobblerTableTableInsertCompanionBuilder, - $$ScrobblerTableTableUpdateCompanionBuilder> { + $$ScrobblerTableTableAnnotationComposer, + $$ScrobblerTableTableCreateCompanionBuilder, + $$ScrobblerTableTableUpdateCompanionBuilder, + ( + ScrobblerTableData, + BaseReferences<_$AppDatabase, $ScrobblerTableTable, ScrobblerTableData> + ), + ScrobblerTableData, + PrefetchHooks Function()> { $$ScrobblerTableTableTableManager( _$AppDatabase db, $ScrobblerTableTable table) : super(TableManagerState( db: db, table: table, - filteringComposer: - $$ScrobblerTableTableFilterComposer(ComposerState(db, table)), - orderingComposer: - $$ScrobblerTableTableOrderingComposer(ComposerState(db, table)), - getChildManagerBuilder: (p) => - $$ScrobblerTableTableProcessedTableManager(p), - getUpdateCompanionBuilder: ({ + createFilteringComposer: () => + $$ScrobblerTableTableFilterComposer($db: db, $table: table), + createOrderingComposer: () => + $$ScrobblerTableTableOrderingComposer($db: db, $table: table), + createComputedFieldComposer: () => + $$ScrobblerTableTableAnnotationComposer($db: db, $table: table), + updateCompanionCallback: ({ Value id = const Value.absent(), Value createdAt = const Value.absent(), Value username = const Value.absent(), @@ -4747,7 +5167,7 @@ class $$ScrobblerTableTableTableManager extends RootTableManager< username: username, passwordHash: passwordHash, ), - getInsertCompanionBuilder: ({ + createCompanionCallback: ({ Value id = const Value.absent(), Value createdAt = const Value.absent(), required String username, @@ -4759,72 +5179,29 @@ class $$ScrobblerTableTableTableManager extends RootTableManager< username: username, passwordHash: passwordHash, ), + withReferenceMapper: (p0) => p0 + .map((e) => (e.readTable(table), BaseReferences(db, table, e))) + .toList(), + prefetchHooksCallback: null, )); } -class $$ScrobblerTableTableProcessedTableManager extends ProcessedTableManager< +typedef $$ScrobblerTableTableProcessedTableManager = ProcessedTableManager< _$AppDatabase, $ScrobblerTableTable, ScrobblerTableData, $$ScrobblerTableTableFilterComposer, $$ScrobblerTableTableOrderingComposer, - $$ScrobblerTableTableProcessedTableManager, - $$ScrobblerTableTableInsertCompanionBuilder, - $$ScrobblerTableTableUpdateCompanionBuilder> { - $$ScrobblerTableTableProcessedTableManager(super.$state); -} - -class $$ScrobblerTableTableFilterComposer - extends FilterComposer<_$AppDatabase, $ScrobblerTableTable> { - $$ScrobblerTableTableFilterComposer(super.$state); - ColumnFilters get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get createdAt => $state.composableBuilder( - column: $state.table.createdAt, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get username => $state.composableBuilder( - column: $state.table.username, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get passwordHash => $state.composableBuilder( - column: $state.table.passwordHash, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); -} - -class $$ScrobblerTableTableOrderingComposer - extends OrderingComposer<_$AppDatabase, $ScrobblerTableTable> { - $$ScrobblerTableTableOrderingComposer(super.$state); - ColumnOrderings get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get createdAt => $state.composableBuilder( - column: $state.table.createdAt, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get username => $state.composableBuilder( - column: $state.table.username, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get passwordHash => $state.composableBuilder( - column: $state.table.passwordHash, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); -} - -typedef $$SkipSegmentTableTableInsertCompanionBuilder + $$ScrobblerTableTableAnnotationComposer, + $$ScrobblerTableTableCreateCompanionBuilder, + $$ScrobblerTableTableUpdateCompanionBuilder, + ( + ScrobblerTableData, + BaseReferences<_$AppDatabase, $ScrobblerTableTable, ScrobblerTableData> + ), + ScrobblerTableData, + PrefetchHooks Function()>; +typedef $$SkipSegmentTableTableCreateCompanionBuilder = SkipSegmentTableCompanion Function({ Value id, required int start, @@ -4841,27 +5218,109 @@ typedef $$SkipSegmentTableTableUpdateCompanionBuilder Value createdAt, }); +class $$SkipSegmentTableTableFilterComposer + extends Composer<_$AppDatabase, $SkipSegmentTableTable> { + $$SkipSegmentTableTableFilterComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnFilters get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnFilters(column)); + + ColumnFilters get start => $composableBuilder( + column: $table.start, builder: (column) => ColumnFilters(column)); + + ColumnFilters get end => $composableBuilder( + column: $table.end, builder: (column) => ColumnFilters(column)); + + ColumnFilters get trackId => $composableBuilder( + column: $table.trackId, builder: (column) => ColumnFilters(column)); + + ColumnFilters get createdAt => $composableBuilder( + column: $table.createdAt, builder: (column) => ColumnFilters(column)); +} + +class $$SkipSegmentTableTableOrderingComposer + extends Composer<_$AppDatabase, $SkipSegmentTableTable> { + $$SkipSegmentTableTableOrderingComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnOrderings get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get start => $composableBuilder( + column: $table.start, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get end => $composableBuilder( + column: $table.end, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get trackId => $composableBuilder( + column: $table.trackId, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get createdAt => $composableBuilder( + column: $table.createdAt, builder: (column) => ColumnOrderings(column)); +} + +class $$SkipSegmentTableTableAnnotationComposer + extends Composer<_$AppDatabase, $SkipSegmentTableTable> { + $$SkipSegmentTableTableAnnotationComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + GeneratedColumn get id => + $composableBuilder(column: $table.id, builder: (column) => column); + + GeneratedColumn get start => + $composableBuilder(column: $table.start, builder: (column) => column); + + GeneratedColumn get end => + $composableBuilder(column: $table.end, builder: (column) => column); + + GeneratedColumn get trackId => + $composableBuilder(column: $table.trackId, builder: (column) => column); + + GeneratedColumn get createdAt => + $composableBuilder(column: $table.createdAt, builder: (column) => column); +} + class $$SkipSegmentTableTableTableManager extends RootTableManager< _$AppDatabase, $SkipSegmentTableTable, SkipSegmentTableData, $$SkipSegmentTableTableFilterComposer, $$SkipSegmentTableTableOrderingComposer, - $$SkipSegmentTableTableProcessedTableManager, - $$SkipSegmentTableTableInsertCompanionBuilder, - $$SkipSegmentTableTableUpdateCompanionBuilder> { + $$SkipSegmentTableTableAnnotationComposer, + $$SkipSegmentTableTableCreateCompanionBuilder, + $$SkipSegmentTableTableUpdateCompanionBuilder, + ( + SkipSegmentTableData, + BaseReferences<_$AppDatabase, $SkipSegmentTableTable, + SkipSegmentTableData> + ), + SkipSegmentTableData, + PrefetchHooks Function()> { $$SkipSegmentTableTableTableManager( _$AppDatabase db, $SkipSegmentTableTable table) : super(TableManagerState( db: db, table: table, - filteringComposer: - $$SkipSegmentTableTableFilterComposer(ComposerState(db, table)), - orderingComposer: - $$SkipSegmentTableTableOrderingComposer(ComposerState(db, table)), - getChildManagerBuilder: (p) => - $$SkipSegmentTableTableProcessedTableManager(p), - getUpdateCompanionBuilder: ({ + createFilteringComposer: () => + $$SkipSegmentTableTableFilterComposer($db: db, $table: table), + createOrderingComposer: () => + $$SkipSegmentTableTableOrderingComposer($db: db, $table: table), + createComputedFieldComposer: () => + $$SkipSegmentTableTableAnnotationComposer($db: db, $table: table), + updateCompanionCallback: ({ Value id = const Value.absent(), Value start = const Value.absent(), Value end = const Value.absent(), @@ -4875,7 +5334,7 @@ class $$SkipSegmentTableTableTableManager extends RootTableManager< trackId: trackId, createdAt: createdAt, ), - getInsertCompanionBuilder: ({ + createCompanionCallback: ({ Value id = const Value.absent(), required int start, required int end, @@ -4889,81 +5348,30 @@ class $$SkipSegmentTableTableTableManager extends RootTableManager< trackId: trackId, createdAt: createdAt, ), + withReferenceMapper: (p0) => p0 + .map((e) => (e.readTable(table), BaseReferences(db, table, e))) + .toList(), + prefetchHooksCallback: null, )); } -class $$SkipSegmentTableTableProcessedTableManager - extends ProcessedTableManager< - _$AppDatabase, - $SkipSegmentTableTable, - SkipSegmentTableData, - $$SkipSegmentTableTableFilterComposer, - $$SkipSegmentTableTableOrderingComposer, - $$SkipSegmentTableTableProcessedTableManager, - $$SkipSegmentTableTableInsertCompanionBuilder, - $$SkipSegmentTableTableUpdateCompanionBuilder> { - $$SkipSegmentTableTableProcessedTableManager(super.$state); -} - -class $$SkipSegmentTableTableFilterComposer - extends FilterComposer<_$AppDatabase, $SkipSegmentTableTable> { - $$SkipSegmentTableTableFilterComposer(super.$state); - ColumnFilters get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get start => $state.composableBuilder( - column: $state.table.start, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get end => $state.composableBuilder( - column: $state.table.end, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get trackId => $state.composableBuilder( - column: $state.table.trackId, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get createdAt => $state.composableBuilder( - column: $state.table.createdAt, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); -} - -class $$SkipSegmentTableTableOrderingComposer - extends OrderingComposer<_$AppDatabase, $SkipSegmentTableTable> { - $$SkipSegmentTableTableOrderingComposer(super.$state); - ColumnOrderings get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get start => $state.composableBuilder( - column: $state.table.start, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get end => $state.composableBuilder( - column: $state.table.end, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get trackId => $state.composableBuilder( - column: $state.table.trackId, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get createdAt => $state.composableBuilder( - column: $state.table.createdAt, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); -} - -typedef $$SourceMatchTableTableInsertCompanionBuilder +typedef $$SkipSegmentTableTableProcessedTableManager = ProcessedTableManager< + _$AppDatabase, + $SkipSegmentTableTable, + SkipSegmentTableData, + $$SkipSegmentTableTableFilterComposer, + $$SkipSegmentTableTableOrderingComposer, + $$SkipSegmentTableTableAnnotationComposer, + $$SkipSegmentTableTableCreateCompanionBuilder, + $$SkipSegmentTableTableUpdateCompanionBuilder, + ( + SkipSegmentTableData, + BaseReferences<_$AppDatabase, $SkipSegmentTableTable, + SkipSegmentTableData> + ), + SkipSegmentTableData, + PrefetchHooks Function()>; +typedef $$SourceMatchTableTableCreateCompanionBuilder = SourceMatchTableCompanion Function({ Value id, required String trackId, @@ -4980,27 +5388,112 @@ typedef $$SourceMatchTableTableUpdateCompanionBuilder Value createdAt, }); +class $$SourceMatchTableTableFilterComposer + extends Composer<_$AppDatabase, $SourceMatchTableTable> { + $$SourceMatchTableTableFilterComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnFilters get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnFilters(column)); + + ColumnFilters get trackId => $composableBuilder( + column: $table.trackId, builder: (column) => ColumnFilters(column)); + + ColumnFilters get sourceId => $composableBuilder( + column: $table.sourceId, builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters + get sourceType => $composableBuilder( + column: $table.sourceType, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnFilters get createdAt => $composableBuilder( + column: $table.createdAt, builder: (column) => ColumnFilters(column)); +} + +class $$SourceMatchTableTableOrderingComposer + extends Composer<_$AppDatabase, $SourceMatchTableTable> { + $$SourceMatchTableTableOrderingComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnOrderings get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get trackId => $composableBuilder( + column: $table.trackId, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get sourceId => $composableBuilder( + column: $table.sourceId, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get sourceType => $composableBuilder( + column: $table.sourceType, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get createdAt => $composableBuilder( + column: $table.createdAt, builder: (column) => ColumnOrderings(column)); +} + +class $$SourceMatchTableTableAnnotationComposer + extends Composer<_$AppDatabase, $SourceMatchTableTable> { + $$SourceMatchTableTableAnnotationComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + GeneratedColumn get id => + $composableBuilder(column: $table.id, builder: (column) => column); + + GeneratedColumn get trackId => + $composableBuilder(column: $table.trackId, builder: (column) => column); + + GeneratedColumn get sourceId => + $composableBuilder(column: $table.sourceId, builder: (column) => column); + + GeneratedColumnWithTypeConverter get sourceType => + $composableBuilder( + column: $table.sourceType, builder: (column) => column); + + GeneratedColumn get createdAt => + $composableBuilder(column: $table.createdAt, builder: (column) => column); +} + class $$SourceMatchTableTableTableManager extends RootTableManager< _$AppDatabase, $SourceMatchTableTable, SourceMatchTableData, $$SourceMatchTableTableFilterComposer, $$SourceMatchTableTableOrderingComposer, - $$SourceMatchTableTableProcessedTableManager, - $$SourceMatchTableTableInsertCompanionBuilder, - $$SourceMatchTableTableUpdateCompanionBuilder> { + $$SourceMatchTableTableAnnotationComposer, + $$SourceMatchTableTableCreateCompanionBuilder, + $$SourceMatchTableTableUpdateCompanionBuilder, + ( + SourceMatchTableData, + BaseReferences<_$AppDatabase, $SourceMatchTableTable, + SourceMatchTableData> + ), + SourceMatchTableData, + PrefetchHooks Function()> { $$SourceMatchTableTableTableManager( _$AppDatabase db, $SourceMatchTableTable table) : super(TableManagerState( db: db, table: table, - filteringComposer: - $$SourceMatchTableTableFilterComposer(ComposerState(db, table)), - orderingComposer: - $$SourceMatchTableTableOrderingComposer(ComposerState(db, table)), - getChildManagerBuilder: (p) => - $$SourceMatchTableTableProcessedTableManager(p), - getUpdateCompanionBuilder: ({ + createFilteringComposer: () => + $$SourceMatchTableTableFilterComposer($db: db, $table: table), + createOrderingComposer: () => + $$SourceMatchTableTableOrderingComposer($db: db, $table: table), + createComputedFieldComposer: () => + $$SourceMatchTableTableAnnotationComposer($db: db, $table: table), + updateCompanionCallback: ({ Value id = const Value.absent(), Value trackId = const Value.absent(), Value sourceId = const Value.absent(), @@ -5014,7 +5507,7 @@ class $$SourceMatchTableTableTableManager extends RootTableManager< sourceType: sourceType, createdAt: createdAt, ), - getInsertCompanionBuilder: ({ + createCompanionCallback: ({ Value id = const Value.absent(), required String trackId, required String sourceId, @@ -5028,83 +5521,30 @@ class $$SourceMatchTableTableTableManager extends RootTableManager< sourceType: sourceType, createdAt: createdAt, ), + withReferenceMapper: (p0) => p0 + .map((e) => (e.readTable(table), BaseReferences(db, table, e))) + .toList(), + prefetchHooksCallback: null, )); } -class $$SourceMatchTableTableProcessedTableManager - extends ProcessedTableManager< - _$AppDatabase, - $SourceMatchTableTable, - SourceMatchTableData, - $$SourceMatchTableTableFilterComposer, - $$SourceMatchTableTableOrderingComposer, - $$SourceMatchTableTableProcessedTableManager, - $$SourceMatchTableTableInsertCompanionBuilder, - $$SourceMatchTableTableUpdateCompanionBuilder> { - $$SourceMatchTableTableProcessedTableManager(super.$state); -} - -class $$SourceMatchTableTableFilterComposer - extends FilterComposer<_$AppDatabase, $SourceMatchTableTable> { - $$SourceMatchTableTableFilterComposer(super.$state); - ColumnFilters get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get trackId => $state.composableBuilder( - column: $state.table.trackId, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get sourceId => $state.composableBuilder( - column: $state.table.sourceId, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get sourceType => $state.composableBuilder( - column: $state.table.sourceType, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnFilters get createdAt => $state.composableBuilder( - column: $state.table.createdAt, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); -} - -class $$SourceMatchTableTableOrderingComposer - extends OrderingComposer<_$AppDatabase, $SourceMatchTableTable> { - $$SourceMatchTableTableOrderingComposer(super.$state); - ColumnOrderings get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get trackId => $state.composableBuilder( - column: $state.table.trackId, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get sourceId => $state.composableBuilder( - column: $state.table.sourceId, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get sourceType => $state.composableBuilder( - column: $state.table.sourceType, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get createdAt => $state.composableBuilder( - column: $state.table.createdAt, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); -} - -typedef $$AudioPlayerStateTableTableInsertCompanionBuilder +typedef $$SourceMatchTableTableProcessedTableManager = ProcessedTableManager< + _$AppDatabase, + $SourceMatchTableTable, + SourceMatchTableData, + $$SourceMatchTableTableFilterComposer, + $$SourceMatchTableTableOrderingComposer, + $$SourceMatchTableTableAnnotationComposer, + $$SourceMatchTableTableCreateCompanionBuilder, + $$SourceMatchTableTableUpdateCompanionBuilder, + ( + SourceMatchTableData, + BaseReferences<_$AppDatabase, $SourceMatchTableTable, + SourceMatchTableData> + ), + SourceMatchTableData, + PrefetchHooks Function()>; +typedef $$AudioPlayerStateTableTableCreateCompanionBuilder = AudioPlayerStateTableCompanion Function({ Value id, required bool playing, @@ -5121,27 +5561,176 @@ typedef $$AudioPlayerStateTableTableUpdateCompanionBuilder Value> collections, }); +final class $$AudioPlayerStateTableTableReferences extends BaseReferences< + _$AppDatabase, $AudioPlayerStateTableTable, AudioPlayerStateTableData> { + $$AudioPlayerStateTableTableReferences( + super.$_db, super.$_table, super.$_typedResult); + + static MultiTypedResultKey<$PlaylistTableTable, List> + _playlistTableRefsTable(_$AppDatabase db) => + MultiTypedResultKey.fromTable(db.playlistTable, + aliasName: $_aliasNameGenerator(db.audioPlayerStateTable.id, + db.playlistTable.audioPlayerStateId)); + + $$PlaylistTableTableProcessedTableManager get playlistTableRefs { + final manager = $$PlaylistTableTableTableManager($_db, $_db.playlistTable) + .filter((f) => f.audioPlayerStateId.id($_item.id)); + + final cache = $_typedResult.readTableOrNull(_playlistTableRefsTable($_db)); + return ProcessedTableManager( + manager.$state.copyWith(prefetchedData: cache)); + } +} + +class $$AudioPlayerStateTableTableFilterComposer + extends Composer<_$AppDatabase, $AudioPlayerStateTableTable> { + $$AudioPlayerStateTableTableFilterComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnFilters get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnFilters(column)); + + ColumnFilters get playing => $composableBuilder( + column: $table.playing, builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters + get loopMode => $composableBuilder( + column: $table.loopMode, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnFilters get shuffled => $composableBuilder( + column: $table.shuffled, builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters, List, String> + get collections => $composableBuilder( + column: $table.collections, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + Expression playlistTableRefs( + Expression Function($$PlaylistTableTableFilterComposer f) f) { + final $$PlaylistTableTableFilterComposer composer = $composerBuilder( + composer: this, + getCurrentColumn: (t) => t.id, + referencedTable: $db.playlistTable, + getReferencedColumn: (t) => t.audioPlayerStateId, + builder: (joinBuilder, + {$addJoinBuilderToRootComposer, + $removeJoinBuilderFromRootComposer}) => + $$PlaylistTableTableFilterComposer( + $db: $db, + $table: $db.playlistTable, + $addJoinBuilderToRootComposer: $addJoinBuilderToRootComposer, + joinBuilder: joinBuilder, + $removeJoinBuilderFromRootComposer: + $removeJoinBuilderFromRootComposer, + )); + return f(composer); + } +} + +class $$AudioPlayerStateTableTableOrderingComposer + extends Composer<_$AppDatabase, $AudioPlayerStateTableTable> { + $$AudioPlayerStateTableTableOrderingComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnOrderings get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get playing => $composableBuilder( + column: $table.playing, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get loopMode => $composableBuilder( + column: $table.loopMode, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get shuffled => $composableBuilder( + column: $table.shuffled, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get collections => $composableBuilder( + column: $table.collections, builder: (column) => ColumnOrderings(column)); +} + +class $$AudioPlayerStateTableTableAnnotationComposer + extends Composer<_$AppDatabase, $AudioPlayerStateTableTable> { + $$AudioPlayerStateTableTableAnnotationComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + GeneratedColumn get id => + $composableBuilder(column: $table.id, builder: (column) => column); + + GeneratedColumn get playing => + $composableBuilder(column: $table.playing, builder: (column) => column); + + GeneratedColumnWithTypeConverter get loopMode => + $composableBuilder(column: $table.loopMode, builder: (column) => column); + + GeneratedColumn get shuffled => + $composableBuilder(column: $table.shuffled, builder: (column) => column); + + GeneratedColumnWithTypeConverter, String> get collections => + $composableBuilder( + column: $table.collections, builder: (column) => column); + + Expression playlistTableRefs( + Expression Function($$PlaylistTableTableAnnotationComposer a) f) { + final $$PlaylistTableTableAnnotationComposer composer = $composerBuilder( + composer: this, + getCurrentColumn: (t) => t.id, + referencedTable: $db.playlistTable, + getReferencedColumn: (t) => t.audioPlayerStateId, + builder: (joinBuilder, + {$addJoinBuilderToRootComposer, + $removeJoinBuilderFromRootComposer}) => + $$PlaylistTableTableAnnotationComposer( + $db: $db, + $table: $db.playlistTable, + $addJoinBuilderToRootComposer: $addJoinBuilderToRootComposer, + joinBuilder: joinBuilder, + $removeJoinBuilderFromRootComposer: + $removeJoinBuilderFromRootComposer, + )); + return f(composer); + } +} + class $$AudioPlayerStateTableTableTableManager extends RootTableManager< _$AppDatabase, $AudioPlayerStateTableTable, AudioPlayerStateTableData, $$AudioPlayerStateTableTableFilterComposer, $$AudioPlayerStateTableTableOrderingComposer, - $$AudioPlayerStateTableTableProcessedTableManager, - $$AudioPlayerStateTableTableInsertCompanionBuilder, - $$AudioPlayerStateTableTableUpdateCompanionBuilder> { + $$AudioPlayerStateTableTableAnnotationComposer, + $$AudioPlayerStateTableTableCreateCompanionBuilder, + $$AudioPlayerStateTableTableUpdateCompanionBuilder, + (AudioPlayerStateTableData, $$AudioPlayerStateTableTableReferences), + AudioPlayerStateTableData, + PrefetchHooks Function({bool playlistTableRefs})> { $$AudioPlayerStateTableTableTableManager( _$AppDatabase db, $AudioPlayerStateTableTable table) : super(TableManagerState( db: db, table: table, - filteringComposer: $$AudioPlayerStateTableTableFilterComposer( - ComposerState(db, table)), - orderingComposer: $$AudioPlayerStateTableTableOrderingComposer( - ComposerState(db, table)), - getChildManagerBuilder: (p) => - $$AudioPlayerStateTableTableProcessedTableManager(p), - getUpdateCompanionBuilder: ({ + createFilteringComposer: () => + $$AudioPlayerStateTableTableFilterComposer( + $db: db, $table: table), + createOrderingComposer: () => + $$AudioPlayerStateTableTableOrderingComposer( + $db: db, $table: table), + createComputedFieldComposer: () => + $$AudioPlayerStateTableTableAnnotationComposer( + $db: db, $table: table), + updateCompanionCallback: ({ Value id = const Value.absent(), Value playing = const Value.absent(), Value loopMode = const Value.absent(), @@ -5155,7 +5744,7 @@ class $$AudioPlayerStateTableTableTableManager extends RootTableManager< shuffled: shuffled, collections: collections, ), - getInsertCompanionBuilder: ({ + createCompanionCallback: ({ Value id = const Value.absent(), required bool playing, required PlaylistMode loopMode, @@ -5169,98 +5758,55 @@ class $$AudioPlayerStateTableTableTableManager extends RootTableManager< shuffled: shuffled, collections: collections, ), + withReferenceMapper: (p0) => p0 + .map((e) => ( + e.readTable(table), + $$AudioPlayerStateTableTableReferences(db, table, e) + )) + .toList(), + prefetchHooksCallback: ({playlistTableRefs = false}) { + return PrefetchHooks( + db: db, + explicitlyWatchedTables: [ + if (playlistTableRefs) db.playlistTable + ], + addJoins: null, + getPrefetchedDataCallback: (items) async { + return [ + if (playlistTableRefs) + await $_getPrefetchedData( + currentTable: table, + referencedTable: $$AudioPlayerStateTableTableReferences + ._playlistTableRefsTable(db), + managerFromTypedResult: (p0) => + $$AudioPlayerStateTableTableReferences( + db, table, p0) + .playlistTableRefs, + referencedItemsForCurrentItem: + (item, referencedItems) => referencedItems + .where((e) => e.audioPlayerStateId == item.id), + typedResults: items) + ]; + }, + ); + }, )); } -class $$AudioPlayerStateTableTableProcessedTableManager - extends ProcessedTableManager< +typedef $$AudioPlayerStateTableTableProcessedTableManager + = ProcessedTableManager< _$AppDatabase, $AudioPlayerStateTableTable, AudioPlayerStateTableData, $$AudioPlayerStateTableTableFilterComposer, $$AudioPlayerStateTableTableOrderingComposer, - $$AudioPlayerStateTableTableProcessedTableManager, - $$AudioPlayerStateTableTableInsertCompanionBuilder, - $$AudioPlayerStateTableTableUpdateCompanionBuilder> { - $$AudioPlayerStateTableTableProcessedTableManager(super.$state); -} - -class $$AudioPlayerStateTableTableFilterComposer - extends FilterComposer<_$AppDatabase, $AudioPlayerStateTableTable> { - $$AudioPlayerStateTableTableFilterComposer(super.$state); - ColumnFilters get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get playing => $state.composableBuilder( - column: $state.table.playing, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get loopMode => $state.composableBuilder( - column: $state.table.loopMode, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnFilters get shuffled => $state.composableBuilder( - column: $state.table.shuffled, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters, List, String> - get collections => $state.composableBuilder( - column: $state.table.collections, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ComposableFilter playlistTableRefs( - ComposableFilter Function($$PlaylistTableTableFilterComposer f) f) { - final $$PlaylistTableTableFilterComposer composer = $state.composerBuilder( - composer: this, - getCurrentColumn: (t) => t.id, - referencedTable: $state.db.playlistTable, - getReferencedColumn: (t) => t.audioPlayerStateId, - builder: (joinBuilder, parentComposers) => - $$PlaylistTableTableFilterComposer(ComposerState($state.db, - $state.db.playlistTable, joinBuilder, parentComposers))); - return f(composer); - } -} - -class $$AudioPlayerStateTableTableOrderingComposer - extends OrderingComposer<_$AppDatabase, $AudioPlayerStateTableTable> { - $$AudioPlayerStateTableTableOrderingComposer(super.$state); - ColumnOrderings get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get playing => $state.composableBuilder( - column: $state.table.playing, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get loopMode => $state.composableBuilder( - column: $state.table.loopMode, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get shuffled => $state.composableBuilder( - column: $state.table.shuffled, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get collections => $state.composableBuilder( - column: $state.table.collections, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); -} - -typedef $$PlaylistTableTableInsertCompanionBuilder = PlaylistTableCompanion + $$AudioPlayerStateTableTableAnnotationComposer, + $$AudioPlayerStateTableTableCreateCompanionBuilder, + $$AudioPlayerStateTableTableUpdateCompanionBuilder, + (AudioPlayerStateTableData, $$AudioPlayerStateTableTableReferences), + AudioPlayerStateTableData, + PrefetchHooks Function({bool playlistTableRefs})>; +typedef $$PlaylistTableTableCreateCompanionBuilder = PlaylistTableCompanion Function({ Value id, required int audioPlayerStateId, @@ -5273,26 +5819,224 @@ typedef $$PlaylistTableTableUpdateCompanionBuilder = PlaylistTableCompanion Value index, }); +final class $$PlaylistTableTableReferences extends BaseReferences<_$AppDatabase, + $PlaylistTableTable, PlaylistTableData> { + $$PlaylistTableTableReferences( + super.$_db, super.$_table, super.$_typedResult); + + static $AudioPlayerStateTableTable _audioPlayerStateIdTable( + _$AppDatabase db) => + db.audioPlayerStateTable.createAlias($_aliasNameGenerator( + db.playlistTable.audioPlayerStateId, db.audioPlayerStateTable.id)); + + $$AudioPlayerStateTableTableProcessedTableManager? get audioPlayerStateId { + if ($_item.audioPlayerStateId == null) return null; + final manager = $$AudioPlayerStateTableTableTableManager( + $_db, $_db.audioPlayerStateTable) + .filter((f) => f.id($_item.audioPlayerStateId!)); + final item = $_typedResult.readTableOrNull(_audioPlayerStateIdTable($_db)); + if (item == null) return manager; + return ProcessedTableManager( + manager.$state.copyWith(prefetchedData: [item])); + } + + static MultiTypedResultKey<$PlaylistMediaTableTable, + List> _playlistMediaTableRefsTable( + _$AppDatabase db) => + MultiTypedResultKey.fromTable(db.playlistMediaTable, + aliasName: $_aliasNameGenerator( + db.playlistTable.id, db.playlistMediaTable.playlistId)); + + $$PlaylistMediaTableTableProcessedTableManager get playlistMediaTableRefs { + final manager = + $$PlaylistMediaTableTableTableManager($_db, $_db.playlistMediaTable) + .filter((f) => f.playlistId.id($_item.id)); + + final cache = + $_typedResult.readTableOrNull(_playlistMediaTableRefsTable($_db)); + return ProcessedTableManager( + manager.$state.copyWith(prefetchedData: cache)); + } +} + +class $$PlaylistTableTableFilterComposer + extends Composer<_$AppDatabase, $PlaylistTableTable> { + $$PlaylistTableTableFilterComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnFilters get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnFilters(column)); + + ColumnFilters get index => $composableBuilder( + column: $table.index, builder: (column) => ColumnFilters(column)); + + $$AudioPlayerStateTableTableFilterComposer get audioPlayerStateId { + final $$AudioPlayerStateTableTableFilterComposer composer = + $composerBuilder( + composer: this, + getCurrentColumn: (t) => t.audioPlayerStateId, + referencedTable: $db.audioPlayerStateTable, + getReferencedColumn: (t) => t.id, + builder: (joinBuilder, + {$addJoinBuilderToRootComposer, + $removeJoinBuilderFromRootComposer}) => + $$AudioPlayerStateTableTableFilterComposer( + $db: $db, + $table: $db.audioPlayerStateTable, + $addJoinBuilderToRootComposer: $addJoinBuilderToRootComposer, + joinBuilder: joinBuilder, + $removeJoinBuilderFromRootComposer: + $removeJoinBuilderFromRootComposer, + )); + return composer; + } + + Expression playlistMediaTableRefs( + Expression Function($$PlaylistMediaTableTableFilterComposer f) f) { + final $$PlaylistMediaTableTableFilterComposer composer = $composerBuilder( + composer: this, + getCurrentColumn: (t) => t.id, + referencedTable: $db.playlistMediaTable, + getReferencedColumn: (t) => t.playlistId, + builder: (joinBuilder, + {$addJoinBuilderToRootComposer, + $removeJoinBuilderFromRootComposer}) => + $$PlaylistMediaTableTableFilterComposer( + $db: $db, + $table: $db.playlistMediaTable, + $addJoinBuilderToRootComposer: $addJoinBuilderToRootComposer, + joinBuilder: joinBuilder, + $removeJoinBuilderFromRootComposer: + $removeJoinBuilderFromRootComposer, + )); + return f(composer); + } +} + +class $$PlaylistTableTableOrderingComposer + extends Composer<_$AppDatabase, $PlaylistTableTable> { + $$PlaylistTableTableOrderingComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnOrderings get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get index => $composableBuilder( + column: $table.index, builder: (column) => ColumnOrderings(column)); + + $$AudioPlayerStateTableTableOrderingComposer get audioPlayerStateId { + final $$AudioPlayerStateTableTableOrderingComposer composer = + $composerBuilder( + composer: this, + getCurrentColumn: (t) => t.audioPlayerStateId, + referencedTable: $db.audioPlayerStateTable, + getReferencedColumn: (t) => t.id, + builder: (joinBuilder, + {$addJoinBuilderToRootComposer, + $removeJoinBuilderFromRootComposer}) => + $$AudioPlayerStateTableTableOrderingComposer( + $db: $db, + $table: $db.audioPlayerStateTable, + $addJoinBuilderToRootComposer: $addJoinBuilderToRootComposer, + joinBuilder: joinBuilder, + $removeJoinBuilderFromRootComposer: + $removeJoinBuilderFromRootComposer, + )); + return composer; + } +} + +class $$PlaylistTableTableAnnotationComposer + extends Composer<_$AppDatabase, $PlaylistTableTable> { + $$PlaylistTableTableAnnotationComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + GeneratedColumn get id => + $composableBuilder(column: $table.id, builder: (column) => column); + + GeneratedColumn get index => + $composableBuilder(column: $table.index, builder: (column) => column); + + $$AudioPlayerStateTableTableAnnotationComposer get audioPlayerStateId { + final $$AudioPlayerStateTableTableAnnotationComposer composer = + $composerBuilder( + composer: this, + getCurrentColumn: (t) => t.audioPlayerStateId, + referencedTable: $db.audioPlayerStateTable, + getReferencedColumn: (t) => t.id, + builder: (joinBuilder, + {$addJoinBuilderToRootComposer, + $removeJoinBuilderFromRootComposer}) => + $$AudioPlayerStateTableTableAnnotationComposer( + $db: $db, + $table: $db.audioPlayerStateTable, + $addJoinBuilderToRootComposer: $addJoinBuilderToRootComposer, + joinBuilder: joinBuilder, + $removeJoinBuilderFromRootComposer: + $removeJoinBuilderFromRootComposer, + )); + return composer; + } + + Expression playlistMediaTableRefs( + Expression Function($$PlaylistMediaTableTableAnnotationComposer a) f) { + final $$PlaylistMediaTableTableAnnotationComposer composer = + $composerBuilder( + composer: this, + getCurrentColumn: (t) => t.id, + referencedTable: $db.playlistMediaTable, + getReferencedColumn: (t) => t.playlistId, + builder: (joinBuilder, + {$addJoinBuilderToRootComposer, + $removeJoinBuilderFromRootComposer}) => + $$PlaylistMediaTableTableAnnotationComposer( + $db: $db, + $table: $db.playlistMediaTable, + $addJoinBuilderToRootComposer: $addJoinBuilderToRootComposer, + joinBuilder: joinBuilder, + $removeJoinBuilderFromRootComposer: + $removeJoinBuilderFromRootComposer, + )); + return f(composer); + } +} + class $$PlaylistTableTableTableManager extends RootTableManager< _$AppDatabase, $PlaylistTableTable, PlaylistTableData, $$PlaylistTableTableFilterComposer, $$PlaylistTableTableOrderingComposer, - $$PlaylistTableTableProcessedTableManager, - $$PlaylistTableTableInsertCompanionBuilder, - $$PlaylistTableTableUpdateCompanionBuilder> { + $$PlaylistTableTableAnnotationComposer, + $$PlaylistTableTableCreateCompanionBuilder, + $$PlaylistTableTableUpdateCompanionBuilder, + (PlaylistTableData, $$PlaylistTableTableReferences), + PlaylistTableData, + PrefetchHooks Function( + {bool audioPlayerStateId, bool playlistMediaTableRefs})> { $$PlaylistTableTableTableManager(_$AppDatabase db, $PlaylistTableTable table) : super(TableManagerState( db: db, table: table, - filteringComposer: - $$PlaylistTableTableFilterComposer(ComposerState(db, table)), - orderingComposer: - $$PlaylistTableTableOrderingComposer(ComposerState(db, table)), - getChildManagerBuilder: (p) => - $$PlaylistTableTableProcessedTableManager(p), - getUpdateCompanionBuilder: ({ + createFilteringComposer: () => + $$PlaylistTableTableFilterComposer($db: db, $table: table), + createOrderingComposer: () => + $$PlaylistTableTableOrderingComposer($db: db, $table: table), + createComputedFieldComposer: () => + $$PlaylistTableTableAnnotationComposer($db: db, $table: table), + updateCompanionCallback: ({ Value id = const Value.absent(), Value audioPlayerStateId = const Value.absent(), Value index = const Value.absent(), @@ -5302,7 +6046,7 @@ class $$PlaylistTableTableTableManager extends RootTableManager< audioPlayerStateId: audioPlayerStateId, index: index, ), - getInsertCompanionBuilder: ({ + createCompanionCallback: ({ Value id = const Value.absent(), required int audioPlayerStateId, required int index, @@ -5312,99 +6056,81 @@ class $$PlaylistTableTableTableManager extends RootTableManager< audioPlayerStateId: audioPlayerStateId, index: index, ), + withReferenceMapper: (p0) => p0 + .map((e) => ( + e.readTable(table), + $$PlaylistTableTableReferences(db, table, e) + )) + .toList(), + prefetchHooksCallback: ( + {audioPlayerStateId = false, playlistMediaTableRefs = false}) { + return PrefetchHooks( + db: db, + explicitlyWatchedTables: [ + if (playlistMediaTableRefs) db.playlistMediaTable + ], + addJoins: < + T extends TableManagerState< + dynamic, + dynamic, + dynamic, + dynamic, + dynamic, + dynamic, + dynamic, + dynamic, + dynamic, + dynamic, + dynamic>>(state) { + if (audioPlayerStateId) { + state = state.withJoin( + currentTable: table, + currentColumn: table.audioPlayerStateId, + referencedTable: $$PlaylistTableTableReferences + ._audioPlayerStateIdTable(db), + referencedColumn: $$PlaylistTableTableReferences + ._audioPlayerStateIdTable(db) + .id, + ) as T; + } + + return state; + }, + getPrefetchedDataCallback: (items) async { + return [ + if (playlistMediaTableRefs) + await $_getPrefetchedData( + currentTable: table, + referencedTable: $$PlaylistTableTableReferences + ._playlistMediaTableRefsTable(db), + managerFromTypedResult: (p0) => + $$PlaylistTableTableReferences(db, table, p0) + .playlistMediaTableRefs, + referencedItemsForCurrentItem: + (item, referencedItems) => referencedItems + .where((e) => e.playlistId == item.id), + typedResults: items) + ]; + }, + ); + }, )); } -class $$PlaylistTableTableProcessedTableManager extends ProcessedTableManager< +typedef $$PlaylistTableTableProcessedTableManager = ProcessedTableManager< _$AppDatabase, $PlaylistTableTable, PlaylistTableData, $$PlaylistTableTableFilterComposer, $$PlaylistTableTableOrderingComposer, - $$PlaylistTableTableProcessedTableManager, - $$PlaylistTableTableInsertCompanionBuilder, - $$PlaylistTableTableUpdateCompanionBuilder> { - $$PlaylistTableTableProcessedTableManager(super.$state); -} - -class $$PlaylistTableTableFilterComposer - extends FilterComposer<_$AppDatabase, $PlaylistTableTable> { - $$PlaylistTableTableFilterComposer(super.$state); - ColumnFilters get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get index => $state.composableBuilder( - column: $state.table.index, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - $$AudioPlayerStateTableTableFilterComposer get audioPlayerStateId { - final $$AudioPlayerStateTableTableFilterComposer composer = - $state.composerBuilder( - composer: this, - getCurrentColumn: (t) => t.audioPlayerStateId, - referencedTable: $state.db.audioPlayerStateTable, - getReferencedColumn: (t) => t.id, - builder: (joinBuilder, parentComposers) => - $$AudioPlayerStateTableTableFilterComposer(ComposerState( - $state.db, - $state.db.audioPlayerStateTable, - joinBuilder, - parentComposers))); - return composer; - } - - ComposableFilter playlistMediaTableRefs( - ComposableFilter Function($$PlaylistMediaTableTableFilterComposer f) f) { - final $$PlaylistMediaTableTableFilterComposer composer = $state - .composerBuilder( - composer: this, - getCurrentColumn: (t) => t.id, - referencedTable: $state.db.playlistMediaTable, - getReferencedColumn: (t) => t.playlistId, - builder: (joinBuilder, parentComposers) => - $$PlaylistMediaTableTableFilterComposer(ComposerState( - $state.db, - $state.db.playlistMediaTable, - joinBuilder, - parentComposers))); - return f(composer); - } -} - -class $$PlaylistTableTableOrderingComposer - extends OrderingComposer<_$AppDatabase, $PlaylistTableTable> { - $$PlaylistTableTableOrderingComposer(super.$state); - ColumnOrderings get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get index => $state.composableBuilder( - column: $state.table.index, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - $$AudioPlayerStateTableTableOrderingComposer get audioPlayerStateId { - final $$AudioPlayerStateTableTableOrderingComposer composer = - $state.composerBuilder( - composer: this, - getCurrentColumn: (t) => t.audioPlayerStateId, - referencedTable: $state.db.audioPlayerStateTable, - getReferencedColumn: (t) => t.id, - builder: (joinBuilder, parentComposers) => - $$AudioPlayerStateTableTableOrderingComposer(ComposerState( - $state.db, - $state.db.audioPlayerStateTable, - joinBuilder, - parentComposers))); - return composer; - } -} - -typedef $$PlaylistMediaTableTableInsertCompanionBuilder + $$PlaylistTableTableAnnotationComposer, + $$PlaylistTableTableCreateCompanionBuilder, + $$PlaylistTableTableUpdateCompanionBuilder, + (PlaylistTableData, $$PlaylistTableTableReferences), + PlaylistTableData, + PrefetchHooks Function( + {bool audioPlayerStateId, bool playlistMediaTableRefs})>; +typedef $$PlaylistMediaTableTableCreateCompanionBuilder = PlaylistMediaTableCompanion Function({ Value id, required int playlistId, @@ -5421,27 +6147,184 @@ typedef $$PlaylistMediaTableTableUpdateCompanionBuilder Value?> httpHeaders, }); +final class $$PlaylistMediaTableTableReferences extends BaseReferences< + _$AppDatabase, $PlaylistMediaTableTable, PlaylistMediaTableData> { + $$PlaylistMediaTableTableReferences( + super.$_db, super.$_table, super.$_typedResult); + + static $PlaylistTableTable _playlistIdTable(_$AppDatabase db) => + db.playlistTable.createAlias($_aliasNameGenerator( + db.playlistMediaTable.playlistId, db.playlistTable.id)); + + $$PlaylistTableTableProcessedTableManager? get playlistId { + if ($_item.playlistId == null) return null; + final manager = $$PlaylistTableTableTableManager($_db, $_db.playlistTable) + .filter((f) => f.id($_item.playlistId!)); + final item = $_typedResult.readTableOrNull(_playlistIdTable($_db)); + if (item == null) return manager; + return ProcessedTableManager( + manager.$state.copyWith(prefetchedData: [item])); + } +} + +class $$PlaylistMediaTableTableFilterComposer + extends Composer<_$AppDatabase, $PlaylistMediaTableTable> { + $$PlaylistMediaTableTableFilterComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnFilters get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnFilters(column)); + + ColumnFilters get uri => $composableBuilder( + column: $table.uri, builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters?, Map, + String> + get extras => $composableBuilder( + column: $table.extras, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnWithTypeConverterFilters?, Map, + String> + get httpHeaders => $composableBuilder( + column: $table.httpHeaders, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + $$PlaylistTableTableFilterComposer get playlistId { + final $$PlaylistTableTableFilterComposer composer = $composerBuilder( + composer: this, + getCurrentColumn: (t) => t.playlistId, + referencedTable: $db.playlistTable, + getReferencedColumn: (t) => t.id, + builder: (joinBuilder, + {$addJoinBuilderToRootComposer, + $removeJoinBuilderFromRootComposer}) => + $$PlaylistTableTableFilterComposer( + $db: $db, + $table: $db.playlistTable, + $addJoinBuilderToRootComposer: $addJoinBuilderToRootComposer, + joinBuilder: joinBuilder, + $removeJoinBuilderFromRootComposer: + $removeJoinBuilderFromRootComposer, + )); + return composer; + } +} + +class $$PlaylistMediaTableTableOrderingComposer + extends Composer<_$AppDatabase, $PlaylistMediaTableTable> { + $$PlaylistMediaTableTableOrderingComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnOrderings get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get uri => $composableBuilder( + column: $table.uri, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get extras => $composableBuilder( + column: $table.extras, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get httpHeaders => $composableBuilder( + column: $table.httpHeaders, builder: (column) => ColumnOrderings(column)); + + $$PlaylistTableTableOrderingComposer get playlistId { + final $$PlaylistTableTableOrderingComposer composer = $composerBuilder( + composer: this, + getCurrentColumn: (t) => t.playlistId, + referencedTable: $db.playlistTable, + getReferencedColumn: (t) => t.id, + builder: (joinBuilder, + {$addJoinBuilderToRootComposer, + $removeJoinBuilderFromRootComposer}) => + $$PlaylistTableTableOrderingComposer( + $db: $db, + $table: $db.playlistTable, + $addJoinBuilderToRootComposer: $addJoinBuilderToRootComposer, + joinBuilder: joinBuilder, + $removeJoinBuilderFromRootComposer: + $removeJoinBuilderFromRootComposer, + )); + return composer; + } +} + +class $$PlaylistMediaTableTableAnnotationComposer + extends Composer<_$AppDatabase, $PlaylistMediaTableTable> { + $$PlaylistMediaTableTableAnnotationComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + GeneratedColumn get id => + $composableBuilder(column: $table.id, builder: (column) => column); + + GeneratedColumn get uri => + $composableBuilder(column: $table.uri, builder: (column) => column); + + GeneratedColumnWithTypeConverter?, String> get extras => + $composableBuilder(column: $table.extras, builder: (column) => column); + + GeneratedColumnWithTypeConverter?, String> + get httpHeaders => $composableBuilder( + column: $table.httpHeaders, builder: (column) => column); + + $$PlaylistTableTableAnnotationComposer get playlistId { + final $$PlaylistTableTableAnnotationComposer composer = $composerBuilder( + composer: this, + getCurrentColumn: (t) => t.playlistId, + referencedTable: $db.playlistTable, + getReferencedColumn: (t) => t.id, + builder: (joinBuilder, + {$addJoinBuilderToRootComposer, + $removeJoinBuilderFromRootComposer}) => + $$PlaylistTableTableAnnotationComposer( + $db: $db, + $table: $db.playlistTable, + $addJoinBuilderToRootComposer: $addJoinBuilderToRootComposer, + joinBuilder: joinBuilder, + $removeJoinBuilderFromRootComposer: + $removeJoinBuilderFromRootComposer, + )); + return composer; + } +} + class $$PlaylistMediaTableTableTableManager extends RootTableManager< _$AppDatabase, $PlaylistMediaTableTable, PlaylistMediaTableData, $$PlaylistMediaTableTableFilterComposer, $$PlaylistMediaTableTableOrderingComposer, - $$PlaylistMediaTableTableProcessedTableManager, - $$PlaylistMediaTableTableInsertCompanionBuilder, - $$PlaylistMediaTableTableUpdateCompanionBuilder> { + $$PlaylistMediaTableTableAnnotationComposer, + $$PlaylistMediaTableTableCreateCompanionBuilder, + $$PlaylistMediaTableTableUpdateCompanionBuilder, + (PlaylistMediaTableData, $$PlaylistMediaTableTableReferences), + PlaylistMediaTableData, + PrefetchHooks Function({bool playlistId})> { $$PlaylistMediaTableTableTableManager( _$AppDatabase db, $PlaylistMediaTableTable table) : super(TableManagerState( db: db, table: table, - filteringComposer: - $$PlaylistMediaTableTableFilterComposer(ComposerState(db, table)), - orderingComposer: $$PlaylistMediaTableTableOrderingComposer( - ComposerState(db, table)), - getChildManagerBuilder: (p) => - $$PlaylistMediaTableTableProcessedTableManager(p), - getUpdateCompanionBuilder: ({ + createFilteringComposer: () => + $$PlaylistMediaTableTableFilterComposer($db: db, $table: table), + createOrderingComposer: () => + $$PlaylistMediaTableTableOrderingComposer($db: db, $table: table), + createComputedFieldComposer: () => + $$PlaylistMediaTableTableAnnotationComposer( + $db: db, $table: table), + updateCompanionCallback: ({ Value id = const Value.absent(), Value playlistId = const Value.absent(), Value uri = const Value.absent(), @@ -5455,7 +6338,7 @@ class $$PlaylistMediaTableTableTableManager extends RootTableManager< extras: extras, httpHeaders: httpHeaders, ), - getInsertCompanionBuilder: ({ + createCompanionCallback: ({ Value id = const Value.absent(), required int playlistId, required String uri, @@ -5469,102 +6352,64 @@ class $$PlaylistMediaTableTableTableManager extends RootTableManager< extras: extras, httpHeaders: httpHeaders, ), + withReferenceMapper: (p0) => p0 + .map((e) => ( + e.readTable(table), + $$PlaylistMediaTableTableReferences(db, table, e) + )) + .toList(), + prefetchHooksCallback: ({playlistId = false}) { + return PrefetchHooks( + db: db, + explicitlyWatchedTables: [], + addJoins: < + T extends TableManagerState< + dynamic, + dynamic, + dynamic, + dynamic, + dynamic, + dynamic, + dynamic, + dynamic, + dynamic, + dynamic, + dynamic>>(state) { + if (playlistId) { + state = state.withJoin( + currentTable: table, + currentColumn: table.playlistId, + referencedTable: $$PlaylistMediaTableTableReferences + ._playlistIdTable(db), + referencedColumn: $$PlaylistMediaTableTableReferences + ._playlistIdTable(db) + .id, + ) as T; + } + + return state; + }, + getPrefetchedDataCallback: (items) async { + return []; + }, + ); + }, )); } -class $$PlaylistMediaTableTableProcessedTableManager - extends ProcessedTableManager< - _$AppDatabase, - $PlaylistMediaTableTable, - PlaylistMediaTableData, - $$PlaylistMediaTableTableFilterComposer, - $$PlaylistMediaTableTableOrderingComposer, - $$PlaylistMediaTableTableProcessedTableManager, - $$PlaylistMediaTableTableInsertCompanionBuilder, - $$PlaylistMediaTableTableUpdateCompanionBuilder> { - $$PlaylistMediaTableTableProcessedTableManager(super.$state); -} - -class $$PlaylistMediaTableTableFilterComposer - extends FilterComposer<_$AppDatabase, $PlaylistMediaTableTable> { - $$PlaylistMediaTableTableFilterComposer(super.$state); - ColumnFilters get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get uri => $state.composableBuilder( - column: $state.table.uri, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters?, Map, - String> - get extras => $state.composableBuilder( - column: $state.table.extras, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters?, Map, - String> - get httpHeaders => $state.composableBuilder( - column: $state.table.httpHeaders, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - $$PlaylistTableTableFilterComposer get playlistId { - final $$PlaylistTableTableFilterComposer composer = $state.composerBuilder( - composer: this, - getCurrentColumn: (t) => t.playlistId, - referencedTable: $state.db.playlistTable, - getReferencedColumn: (t) => t.id, - builder: (joinBuilder, parentComposers) => - $$PlaylistTableTableFilterComposer(ComposerState($state.db, - $state.db.playlistTable, joinBuilder, parentComposers))); - return composer; - } -} - -class $$PlaylistMediaTableTableOrderingComposer - extends OrderingComposer<_$AppDatabase, $PlaylistMediaTableTable> { - $$PlaylistMediaTableTableOrderingComposer(super.$state); - ColumnOrderings get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get uri => $state.composableBuilder( - column: $state.table.uri, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get extras => $state.composableBuilder( - column: $state.table.extras, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get httpHeaders => $state.composableBuilder( - column: $state.table.httpHeaders, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - $$PlaylistTableTableOrderingComposer get playlistId { - final $$PlaylistTableTableOrderingComposer composer = - $state.composerBuilder( - composer: this, - getCurrentColumn: (t) => t.playlistId, - referencedTable: $state.db.playlistTable, - getReferencedColumn: (t) => t.id, - builder: (joinBuilder, parentComposers) => - $$PlaylistTableTableOrderingComposer(ComposerState($state.db, - $state.db.playlistTable, joinBuilder, parentComposers))); - return composer; - } -} - -typedef $$HistoryTableTableInsertCompanionBuilder = HistoryTableCompanion +typedef $$PlaylistMediaTableTableProcessedTableManager = ProcessedTableManager< + _$AppDatabase, + $PlaylistMediaTableTable, + PlaylistMediaTableData, + $$PlaylistMediaTableTableFilterComposer, + $$PlaylistMediaTableTableOrderingComposer, + $$PlaylistMediaTableTableAnnotationComposer, + $$PlaylistMediaTableTableCreateCompanionBuilder, + $$PlaylistMediaTableTableUpdateCompanionBuilder, + (PlaylistMediaTableData, $$PlaylistMediaTableTableReferences), + PlaylistMediaTableData, + PrefetchHooks Function({bool playlistId})>; +typedef $$HistoryTableTableCreateCompanionBuilder = HistoryTableCompanion Function({ Value id, Value createdAt, @@ -5581,26 +6426,112 @@ typedef $$HistoryTableTableUpdateCompanionBuilder = HistoryTableCompanion Value> data, }); +class $$HistoryTableTableFilterComposer + extends Composer<_$AppDatabase, $HistoryTableTable> { + $$HistoryTableTableFilterComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnFilters get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnFilters(column)); + + ColumnFilters get createdAt => $composableBuilder( + column: $table.createdAt, builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters + get type => $composableBuilder( + column: $table.type, + builder: (column) => ColumnWithTypeConverterFilters(column)); + + ColumnFilters get itemId => $composableBuilder( + column: $table.itemId, builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters, Map, + String> + get data => $composableBuilder( + column: $table.data, + builder: (column) => ColumnWithTypeConverterFilters(column)); +} + +class $$HistoryTableTableOrderingComposer + extends Composer<_$AppDatabase, $HistoryTableTable> { + $$HistoryTableTableOrderingComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnOrderings get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get createdAt => $composableBuilder( + column: $table.createdAt, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get type => $composableBuilder( + column: $table.type, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get itemId => $composableBuilder( + column: $table.itemId, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get data => $composableBuilder( + column: $table.data, builder: (column) => ColumnOrderings(column)); +} + +class $$HistoryTableTableAnnotationComposer + extends Composer<_$AppDatabase, $HistoryTableTable> { + $$HistoryTableTableAnnotationComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + GeneratedColumn get id => + $composableBuilder(column: $table.id, builder: (column) => column); + + GeneratedColumn get createdAt => + $composableBuilder(column: $table.createdAt, builder: (column) => column); + + GeneratedColumnWithTypeConverter get type => + $composableBuilder(column: $table.type, builder: (column) => column); + + GeneratedColumn get itemId => + $composableBuilder(column: $table.itemId, builder: (column) => column); + + GeneratedColumnWithTypeConverter, String> get data => + $composableBuilder(column: $table.data, builder: (column) => column); +} + class $$HistoryTableTableTableManager extends RootTableManager< _$AppDatabase, $HistoryTableTable, HistoryTableData, $$HistoryTableTableFilterComposer, $$HistoryTableTableOrderingComposer, - $$HistoryTableTableProcessedTableManager, - $$HistoryTableTableInsertCompanionBuilder, - $$HistoryTableTableUpdateCompanionBuilder> { + $$HistoryTableTableAnnotationComposer, + $$HistoryTableTableCreateCompanionBuilder, + $$HistoryTableTableUpdateCompanionBuilder, + ( + HistoryTableData, + BaseReferences<_$AppDatabase, $HistoryTableTable, HistoryTableData> + ), + HistoryTableData, + PrefetchHooks Function()> { $$HistoryTableTableTableManager(_$AppDatabase db, $HistoryTableTable table) : super(TableManagerState( db: db, table: table, - filteringComposer: - $$HistoryTableTableFilterComposer(ComposerState(db, table)), - orderingComposer: - $$HistoryTableTableOrderingComposer(ComposerState(db, table)), - getChildManagerBuilder: (p) => - $$HistoryTableTableProcessedTableManager(p), - getUpdateCompanionBuilder: ({ + createFilteringComposer: () => + $$HistoryTableTableFilterComposer($db: db, $table: table), + createOrderingComposer: () => + $$HistoryTableTableOrderingComposer($db: db, $table: table), + createComputedFieldComposer: () => + $$HistoryTableTableAnnotationComposer($db: db, $table: table), + updateCompanionCallback: ({ Value id = const Value.absent(), Value createdAt = const Value.absent(), Value type = const Value.absent(), @@ -5614,7 +6545,7 @@ class $$HistoryTableTableTableManager extends RootTableManager< itemId: itemId, data: data, ), - getInsertCompanionBuilder: ({ + createCompanionCallback: ({ Value id = const Value.absent(), Value createdAt = const Value.absent(), required HistoryEntryType type, @@ -5628,85 +6559,29 @@ class $$HistoryTableTableTableManager extends RootTableManager< itemId: itemId, data: data, ), + withReferenceMapper: (p0) => p0 + .map((e) => (e.readTable(table), BaseReferences(db, table, e))) + .toList(), + prefetchHooksCallback: null, )); } -class $$HistoryTableTableProcessedTableManager extends ProcessedTableManager< +typedef $$HistoryTableTableProcessedTableManager = ProcessedTableManager< _$AppDatabase, $HistoryTableTable, HistoryTableData, $$HistoryTableTableFilterComposer, $$HistoryTableTableOrderingComposer, - $$HistoryTableTableProcessedTableManager, - $$HistoryTableTableInsertCompanionBuilder, - $$HistoryTableTableUpdateCompanionBuilder> { - $$HistoryTableTableProcessedTableManager(super.$state); -} - -class $$HistoryTableTableFilterComposer - extends FilterComposer<_$AppDatabase, $HistoryTableTable> { - $$HistoryTableTableFilterComposer(super.$state); - ColumnFilters get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get createdAt => $state.composableBuilder( - column: $state.table.createdAt, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get type => $state.composableBuilder( - column: $state.table.type, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); - - ColumnFilters get itemId => $state.composableBuilder( - column: $state.table.itemId, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters, Map, - String> - get data => $state.composableBuilder( - column: $state.table.data, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); -} - -class $$HistoryTableTableOrderingComposer - extends OrderingComposer<_$AppDatabase, $HistoryTableTable> { - $$HistoryTableTableOrderingComposer(super.$state); - ColumnOrderings get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get createdAt => $state.composableBuilder( - column: $state.table.createdAt, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get type => $state.composableBuilder( - column: $state.table.type, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get itemId => $state.composableBuilder( - column: $state.table.itemId, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get data => $state.composableBuilder( - column: $state.table.data, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); -} - -typedef $$LyricsTableTableInsertCompanionBuilder = LyricsTableCompanion + $$HistoryTableTableAnnotationComposer, + $$HistoryTableTableCreateCompanionBuilder, + $$HistoryTableTableUpdateCompanionBuilder, + ( + HistoryTableData, + BaseReferences<_$AppDatabase, $HistoryTableTable, HistoryTableData> + ), + HistoryTableData, + PrefetchHooks Function()>; +typedef $$LyricsTableTableCreateCompanionBuilder = LyricsTableCompanion Function({ Value id, required String trackId, @@ -5719,26 +6594,91 @@ typedef $$LyricsTableTableUpdateCompanionBuilder = LyricsTableCompanion Value data, }); +class $$LyricsTableTableFilterComposer + extends Composer<_$AppDatabase, $LyricsTableTable> { + $$LyricsTableTableFilterComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnFilters get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnFilters(column)); + + ColumnFilters get trackId => $composableBuilder( + column: $table.trackId, builder: (column) => ColumnFilters(column)); + + ColumnWithTypeConverterFilters + get data => $composableBuilder( + column: $table.data, + builder: (column) => ColumnWithTypeConverterFilters(column)); +} + +class $$LyricsTableTableOrderingComposer + extends Composer<_$AppDatabase, $LyricsTableTable> { + $$LyricsTableTableOrderingComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + ColumnOrderings get id => $composableBuilder( + column: $table.id, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get trackId => $composableBuilder( + column: $table.trackId, builder: (column) => ColumnOrderings(column)); + + ColumnOrderings get data => $composableBuilder( + column: $table.data, builder: (column) => ColumnOrderings(column)); +} + +class $$LyricsTableTableAnnotationComposer + extends Composer<_$AppDatabase, $LyricsTableTable> { + $$LyricsTableTableAnnotationComposer({ + required super.$db, + required super.$table, + super.joinBuilder, + super.$addJoinBuilderToRootComposer, + super.$removeJoinBuilderFromRootComposer, + }); + GeneratedColumn get id => + $composableBuilder(column: $table.id, builder: (column) => column); + + GeneratedColumn get trackId => + $composableBuilder(column: $table.trackId, builder: (column) => column); + + GeneratedColumnWithTypeConverter get data => + $composableBuilder(column: $table.data, builder: (column) => column); +} + class $$LyricsTableTableTableManager extends RootTableManager< _$AppDatabase, $LyricsTableTable, LyricsTableData, $$LyricsTableTableFilterComposer, $$LyricsTableTableOrderingComposer, - $$LyricsTableTableProcessedTableManager, - $$LyricsTableTableInsertCompanionBuilder, - $$LyricsTableTableUpdateCompanionBuilder> { + $$LyricsTableTableAnnotationComposer, + $$LyricsTableTableCreateCompanionBuilder, + $$LyricsTableTableUpdateCompanionBuilder, + ( + LyricsTableData, + BaseReferences<_$AppDatabase, $LyricsTableTable, LyricsTableData> + ), + LyricsTableData, + PrefetchHooks Function()> { $$LyricsTableTableTableManager(_$AppDatabase db, $LyricsTableTable table) : super(TableManagerState( db: db, table: table, - filteringComposer: - $$LyricsTableTableFilterComposer(ComposerState(db, table)), - orderingComposer: - $$LyricsTableTableOrderingComposer(ComposerState(db, table)), - getChildManagerBuilder: (p) => - $$LyricsTableTableProcessedTableManager(p), - getUpdateCompanionBuilder: ({ + createFilteringComposer: () => + $$LyricsTableTableFilterComposer($db: db, $table: table), + createOrderingComposer: () => + $$LyricsTableTableOrderingComposer($db: db, $table: table), + createComputedFieldComposer: () => + $$LyricsTableTableAnnotationComposer($db: db, $table: table), + updateCompanionCallback: ({ Value id = const Value.absent(), Value trackId = const Value.absent(), Value data = const Value.absent(), @@ -5748,7 +6688,7 @@ class $$LyricsTableTableTableManager extends RootTableManager< trackId: trackId, data: data, ), - getInsertCompanionBuilder: ({ + createCompanionCallback: ({ Value id = const Value.absent(), required String trackId, required SubtitleSimple data, @@ -5758,64 +6698,32 @@ class $$LyricsTableTableTableManager extends RootTableManager< trackId: trackId, data: data, ), + withReferenceMapper: (p0) => p0 + .map((e) => (e.readTable(table), BaseReferences(db, table, e))) + .toList(), + prefetchHooksCallback: null, )); } -class $$LyricsTableTableProcessedTableManager extends ProcessedTableManager< +typedef $$LyricsTableTableProcessedTableManager = ProcessedTableManager< _$AppDatabase, $LyricsTableTable, LyricsTableData, $$LyricsTableTableFilterComposer, $$LyricsTableTableOrderingComposer, - $$LyricsTableTableProcessedTableManager, - $$LyricsTableTableInsertCompanionBuilder, - $$LyricsTableTableUpdateCompanionBuilder> { - $$LyricsTableTableProcessedTableManager(super.$state); -} + $$LyricsTableTableAnnotationComposer, + $$LyricsTableTableCreateCompanionBuilder, + $$LyricsTableTableUpdateCompanionBuilder, + ( + LyricsTableData, + BaseReferences<_$AppDatabase, $LyricsTableTable, LyricsTableData> + ), + LyricsTableData, + PrefetchHooks Function()>; -class $$LyricsTableTableFilterComposer - extends FilterComposer<_$AppDatabase, $LyricsTableTable> { - $$LyricsTableTableFilterComposer(super.$state); - ColumnFilters get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnFilters get trackId => $state.composableBuilder( - column: $state.table.trackId, - builder: (column, joinBuilders) => - ColumnFilters(column, joinBuilders: joinBuilders)); - - ColumnWithTypeConverterFilters - get data => $state.composableBuilder( - column: $state.table.data, - builder: (column, joinBuilders) => ColumnWithTypeConverterFilters( - column, - joinBuilders: joinBuilders)); -} - -class $$LyricsTableTableOrderingComposer - extends OrderingComposer<_$AppDatabase, $LyricsTableTable> { - $$LyricsTableTableOrderingComposer(super.$state); - ColumnOrderings get id => $state.composableBuilder( - column: $state.table.id, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get trackId => $state.composableBuilder( - column: $state.table.trackId, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); - - ColumnOrderings get data => $state.composableBuilder( - column: $state.table.data, - builder: (column, joinBuilders) => - ColumnOrderings(column, joinBuilders: joinBuilders)); -} - -class _$AppDatabaseManager { +class $AppDatabaseManager { final _$AppDatabase _db; - _$AppDatabaseManager(this._db); + $AppDatabaseManager(this._db); $$AuthenticationTableTableTableManager get authenticationTable => $$AuthenticationTableTableTableManager(_db, _db.authenticationTable); $$BlacklistTableTableTableManager get blacklistTable => diff --git a/lib/models/database/database.steps.dart b/lib/models/database/database.steps.dart new file mode 100644 index 00000000..4814fa5a --- /dev/null +++ b/lib/models/database/database.steps.dart @@ -0,0 +1,652 @@ +import 'package:drift/internal/versioned_schema.dart' as i0; +import 'package:drift/drift.dart' as i1; +import 'package:drift/drift.dart'; +import 'package:flutter/material.dart'; +import 'package:spotify/spotify.dart'; +import 'package:spotube/services/sourced_track/enums.dart'; +import 'package:spotube/utils/migrations/adapters.dart'; // ignore_for_file: type=lint,unused_import + +// GENERATED BY drift_dev, DO NOT MODIFY. +final class Schema2 extends i0.VersionedSchema { + Schema2({required super.database}) : super(version: 2); + @override + late final List entities = [ + authenticationTable, + blacklistTable, + preferencesTable, + scrobblerTable, + skipSegmentTable, + sourceMatchTable, + audioPlayerStateTable, + playlistTable, + playlistMediaTable, + historyTable, + lyricsTable, + uniqueBlacklist, + uniqTrackMatch, + ]; + late final Shape0 authenticationTable = Shape0( + source: i0.VersionedTable( + entityName: 'authentication_table', + withoutRowId: false, + isStrict: false, + tableConstraints: [], + columns: [ + _column_0, + _column_1, + _column_2, + _column_3, + ], + attachedDatabase: database, + ), + alias: null); + late final Shape1 blacklistTable = Shape1( + source: i0.VersionedTable( + entityName: 'blacklist_table', + withoutRowId: false, + isStrict: false, + tableConstraints: [], + columns: [ + _column_0, + _column_4, + _column_5, + _column_6, + ], + attachedDatabase: database, + ), + alias: null); + late final Shape2 preferencesTable = Shape2( + source: i0.VersionedTable( + entityName: 'preferences_table', + withoutRowId: false, + isStrict: false, + tableConstraints: [], + columns: [ + _column_0, + _column_7, + _column_8, + _column_9, + _column_10, + _column_11, + _column_12, + _column_13, + _column_14, + _column_15, + _column_16, + _column_17, + _column_18, + _column_19, + _column_20, + _column_21, + _column_22, + _column_23, + _column_24, + _column_25, + _column_26, + _column_27, + _column_28, + _column_29, + _column_30, + _column_31, + ], + attachedDatabase: database, + ), + alias: null); + late final Shape3 scrobblerTable = Shape3( + source: i0.VersionedTable( + entityName: 'scrobbler_table', + withoutRowId: false, + isStrict: false, + tableConstraints: [], + columns: [ + _column_0, + _column_32, + _column_33, + _column_34, + ], + attachedDatabase: database, + ), + alias: null); + late final Shape4 skipSegmentTable = Shape4( + source: i0.VersionedTable( + entityName: 'skip_segment_table', + withoutRowId: false, + isStrict: false, + tableConstraints: [], + columns: [ + _column_0, + _column_35, + _column_36, + _column_37, + _column_32, + ], + attachedDatabase: database, + ), + alias: null); + late final Shape5 sourceMatchTable = Shape5( + source: i0.VersionedTable( + entityName: 'source_match_table', + withoutRowId: false, + isStrict: false, + tableConstraints: [], + columns: [ + _column_0, + _column_37, + _column_38, + _column_39, + _column_32, + ], + attachedDatabase: database, + ), + alias: null); + late final Shape6 audioPlayerStateTable = Shape6( + source: i0.VersionedTable( + entityName: 'audio_player_state_table', + withoutRowId: false, + isStrict: false, + tableConstraints: [], + columns: [ + _column_0, + _column_40, + _column_41, + _column_42, + _column_43, + ], + attachedDatabase: database, + ), + alias: null); + late final Shape7 playlistTable = Shape7( + source: i0.VersionedTable( + entityName: 'playlist_table', + withoutRowId: false, + isStrict: false, + tableConstraints: [], + columns: [ + _column_0, + _column_44, + _column_45, + ], + attachedDatabase: database, + ), + alias: null); + late final Shape8 playlistMediaTable = Shape8( + source: i0.VersionedTable( + entityName: 'playlist_media_table', + withoutRowId: false, + isStrict: false, + tableConstraints: [], + columns: [ + _column_0, + _column_46, + _column_47, + _column_48, + _column_49, + ], + attachedDatabase: database, + ), + alias: null); + late final Shape9 historyTable = Shape9( + source: i0.VersionedTable( + entityName: 'history_table', + withoutRowId: false, + isStrict: false, + tableConstraints: [], + columns: [ + _column_0, + _column_32, + _column_50, + _column_51, + _column_52, + ], + attachedDatabase: database, + ), + alias: null); + late final Shape10 lyricsTable = Shape10( + source: i0.VersionedTable( + entityName: 'lyrics_table', + withoutRowId: false, + isStrict: false, + tableConstraints: [], + columns: [ + _column_0, + _column_37, + _column_52, + ], + attachedDatabase: database, + ), + alias: null); + final i1.Index uniqueBlacklist = i1.Index('unique_blacklist', + 'CREATE UNIQUE INDEX unique_blacklist ON blacklist_table (element_type, element_id)'); + final i1.Index uniqTrackMatch = i1.Index('uniq_track_match', + 'CREATE UNIQUE INDEX uniq_track_match ON source_match_table (track_id, source_id, source_type)'); +} + +class Shape0 extends i0.VersionedTable { + Shape0({required super.source, required super.alias}) : super.aliased(); + i1.GeneratedColumn get id => + columnsByName['id']! as i1.GeneratedColumn; + i1.GeneratedColumn get cookie => + columnsByName['cookie']! as i1.GeneratedColumn; + i1.GeneratedColumn get accessToken => + columnsByName['access_token']! as i1.GeneratedColumn; + i1.GeneratedColumn get expiration => + columnsByName['expiration']! as i1.GeneratedColumn; +} + +i1.GeneratedColumn _column_0(String aliasedName) => + i1.GeneratedColumn('id', aliasedName, false, + hasAutoIncrement: true, + type: i1.DriftSqlType.int, + defaultConstraints: + i1.GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); +i1.GeneratedColumn _column_1(String aliasedName) => + i1.GeneratedColumn('cookie', aliasedName, false, + type: i1.DriftSqlType.string); +i1.GeneratedColumn _column_2(String aliasedName) => + i1.GeneratedColumn('access_token', aliasedName, false, + type: i1.DriftSqlType.string); +i1.GeneratedColumn _column_3(String aliasedName) => + i1.GeneratedColumn('expiration', aliasedName, false, + type: i1.DriftSqlType.dateTime); + +class Shape1 extends i0.VersionedTable { + Shape1({required super.source, required super.alias}) : super.aliased(); + i1.GeneratedColumn get id => + columnsByName['id']! as i1.GeneratedColumn; + i1.GeneratedColumn get name => + columnsByName['name']! as i1.GeneratedColumn; + i1.GeneratedColumn get elementType => + columnsByName['element_type']! as i1.GeneratedColumn; + i1.GeneratedColumn get elementId => + columnsByName['element_id']! as i1.GeneratedColumn; +} + +i1.GeneratedColumn _column_4(String aliasedName) => + i1.GeneratedColumn('name', aliasedName, false, + type: i1.DriftSqlType.string); +i1.GeneratedColumn _column_5(String aliasedName) => + i1.GeneratedColumn('element_type', aliasedName, false, + type: i1.DriftSqlType.string); +i1.GeneratedColumn _column_6(String aliasedName) => + i1.GeneratedColumn('element_id', aliasedName, false, + type: i1.DriftSqlType.string); + +class Shape2 extends i0.VersionedTable { + Shape2({required super.source, required super.alias}) : super.aliased(); + i1.GeneratedColumn get id => + columnsByName['id']! as i1.GeneratedColumn; + i1.GeneratedColumn get audioQuality => + columnsByName['audio_quality']! as i1.GeneratedColumn; + i1.GeneratedColumn get albumColorSync => + columnsByName['album_color_sync']! as i1.GeneratedColumn; + i1.GeneratedColumn get amoledDarkTheme => + columnsByName['amoled_dark_theme']! as i1.GeneratedColumn; + i1.GeneratedColumn get checkUpdate => + columnsByName['check_update']! as i1.GeneratedColumn; + i1.GeneratedColumn get normalizeAudio => + columnsByName['normalize_audio']! as i1.GeneratedColumn; + i1.GeneratedColumn get showSystemTrayIcon => + columnsByName['show_system_tray_icon']! as i1.GeneratedColumn; + i1.GeneratedColumn get systemTitleBar => + columnsByName['system_title_bar']! as i1.GeneratedColumn; + i1.GeneratedColumn get skipNonMusic => + columnsByName['skip_non_music']! as i1.GeneratedColumn; + i1.GeneratedColumn get closeBehavior => + columnsByName['close_behavior']! as i1.GeneratedColumn; + i1.GeneratedColumn get accentColorScheme => + columnsByName['accent_color_scheme']! as i1.GeneratedColumn; + i1.GeneratedColumn get layoutMode => + columnsByName['layout_mode']! as i1.GeneratedColumn; + i1.GeneratedColumn get locale => + columnsByName['locale']! as i1.GeneratedColumn; + i1.GeneratedColumn get market => + columnsByName['market']! as i1.GeneratedColumn; + i1.GeneratedColumn get searchMode => + columnsByName['search_mode']! as i1.GeneratedColumn; + i1.GeneratedColumn get downloadLocation => + columnsByName['download_location']! as i1.GeneratedColumn; + i1.GeneratedColumn get localLibraryLocation => + columnsByName['local_library_location']! as i1.GeneratedColumn; + i1.GeneratedColumn get pipedInstance => + columnsByName['piped_instance']! as i1.GeneratedColumn; + i1.GeneratedColumn get invidiousInstance => + columnsByName['invidious_instance']! as i1.GeneratedColumn; + i1.GeneratedColumn get themeMode => + columnsByName['theme_mode']! as i1.GeneratedColumn; + i1.GeneratedColumn get audioSource => + columnsByName['audio_source']! as i1.GeneratedColumn; + i1.GeneratedColumn get streamMusicCodec => + columnsByName['stream_music_codec']! as i1.GeneratedColumn; + i1.GeneratedColumn get downloadMusicCodec => + columnsByName['download_music_codec']! as i1.GeneratedColumn; + i1.GeneratedColumn get discordPresence => + columnsByName['discord_presence']! as i1.GeneratedColumn; + i1.GeneratedColumn get endlessPlayback => + columnsByName['endless_playback']! as i1.GeneratedColumn; + i1.GeneratedColumn get enableConnect => + columnsByName['enable_connect']! as i1.GeneratedColumn; +} + +i1.GeneratedColumn _column_7(String aliasedName) => + i1.GeneratedColumn('audio_quality', aliasedName, false, + type: i1.DriftSqlType.string, + defaultValue: Constant(SourceQualities.high.name)); +i1.GeneratedColumn _column_8(String aliasedName) => + i1.GeneratedColumn('album_color_sync', aliasedName, false, + type: i1.DriftSqlType.bool, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'CHECK ("album_color_sync" IN (0, 1))'), + defaultValue: const Constant(true)); +i1.GeneratedColumn _column_9(String aliasedName) => + i1.GeneratedColumn('amoled_dark_theme', aliasedName, false, + type: i1.DriftSqlType.bool, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'CHECK ("amoled_dark_theme" IN (0, 1))'), + defaultValue: const Constant(false)); +i1.GeneratedColumn _column_10(String aliasedName) => + i1.GeneratedColumn('check_update', aliasedName, false, + type: i1.DriftSqlType.bool, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'CHECK ("check_update" IN (0, 1))'), + defaultValue: const Constant(true)); +i1.GeneratedColumn _column_11(String aliasedName) => + i1.GeneratedColumn('normalize_audio', aliasedName, false, + type: i1.DriftSqlType.bool, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'CHECK ("normalize_audio" IN (0, 1))'), + defaultValue: const Constant(false)); +i1.GeneratedColumn _column_12(String aliasedName) => + i1.GeneratedColumn('show_system_tray_icon', aliasedName, false, + type: i1.DriftSqlType.bool, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'CHECK ("show_system_tray_icon" IN (0, 1))'), + defaultValue: const Constant(false)); +i1.GeneratedColumn _column_13(String aliasedName) => + i1.GeneratedColumn('system_title_bar', aliasedName, false, + type: i1.DriftSqlType.bool, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'CHECK ("system_title_bar" IN (0, 1))'), + defaultValue: const Constant(false)); +i1.GeneratedColumn _column_14(String aliasedName) => + i1.GeneratedColumn('skip_non_music', aliasedName, false, + type: i1.DriftSqlType.bool, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'CHECK ("skip_non_music" IN (0, 1))'), + defaultValue: const Constant(false)); +i1.GeneratedColumn _column_15(String aliasedName) => + i1.GeneratedColumn('close_behavior', aliasedName, false, + type: i1.DriftSqlType.string, + defaultValue: Constant(CloseBehavior.close.name)); +i1.GeneratedColumn _column_16(String aliasedName) => + i1.GeneratedColumn('accent_color_scheme', aliasedName, false, + type: i1.DriftSqlType.string, + defaultValue: const Constant("Blue:0xFF2196F3")); +i1.GeneratedColumn _column_17(String aliasedName) => + i1.GeneratedColumn('layout_mode', aliasedName, false, + type: i1.DriftSqlType.string, + defaultValue: Constant(LayoutMode.adaptive.name)); +i1.GeneratedColumn _column_18(String aliasedName) => + i1.GeneratedColumn('locale', aliasedName, false, + type: i1.DriftSqlType.string, + defaultValue: + const Constant('{"languageCode":"system","countryCode":"system"}')); +i1.GeneratedColumn _column_19(String aliasedName) => + i1.GeneratedColumn('market', aliasedName, false, + type: i1.DriftSqlType.string, defaultValue: Constant(Market.US.name)); +i1.GeneratedColumn _column_20(String aliasedName) => + i1.GeneratedColumn('search_mode', aliasedName, false, + type: i1.DriftSqlType.string, + defaultValue: Constant(SearchMode.youtube.name)); +i1.GeneratedColumn _column_21(String aliasedName) => + i1.GeneratedColumn('download_location', aliasedName, false, + type: i1.DriftSqlType.string, defaultValue: const Constant("")); +i1.GeneratedColumn _column_22(String aliasedName) => + i1.GeneratedColumn('local_library_location', aliasedName, false, + type: i1.DriftSqlType.string, defaultValue: const Constant("")); +i1.GeneratedColumn _column_23(String aliasedName) => + i1.GeneratedColumn('piped_instance', aliasedName, false, + type: i1.DriftSqlType.string, + defaultValue: const Constant("https://pipedapi.kavin.rocks")); +i1.GeneratedColumn _column_24(String aliasedName) => + i1.GeneratedColumn('invidious_instance', aliasedName, false, + type: i1.DriftSqlType.string, + defaultValue: const Constant("https://inv.nadeko.net")); +i1.GeneratedColumn _column_25(String aliasedName) => + i1.GeneratedColumn('theme_mode', aliasedName, false, + type: i1.DriftSqlType.string, + defaultValue: Constant(ThemeMode.system.name)); +i1.GeneratedColumn _column_26(String aliasedName) => + i1.GeneratedColumn('audio_source', aliasedName, false, + type: i1.DriftSqlType.string, + defaultValue: Constant(AudioSource.youtube.name)); +i1.GeneratedColumn _column_27(String aliasedName) => + i1.GeneratedColumn('stream_music_codec', aliasedName, false, + type: i1.DriftSqlType.string, + defaultValue: Constant(SourceCodecs.weba.name)); +i1.GeneratedColumn _column_28(String aliasedName) => + i1.GeneratedColumn('download_music_codec', aliasedName, false, + type: i1.DriftSqlType.string, + defaultValue: Constant(SourceCodecs.m4a.name)); +i1.GeneratedColumn _column_29(String aliasedName) => + i1.GeneratedColumn('discord_presence', aliasedName, false, + type: i1.DriftSqlType.bool, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'CHECK ("discord_presence" IN (0, 1))'), + defaultValue: const Constant(true)); +i1.GeneratedColumn _column_30(String aliasedName) => + i1.GeneratedColumn('endless_playback', aliasedName, false, + type: i1.DriftSqlType.bool, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'CHECK ("endless_playback" IN (0, 1))'), + defaultValue: const Constant(true)); +i1.GeneratedColumn _column_31(String aliasedName) => + i1.GeneratedColumn('enable_connect', aliasedName, false, + type: i1.DriftSqlType.bool, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'CHECK ("enable_connect" IN (0, 1))'), + defaultValue: const Constant(false)); + +class Shape3 extends i0.VersionedTable { + Shape3({required super.source, required super.alias}) : super.aliased(); + i1.GeneratedColumn get id => + columnsByName['id']! as i1.GeneratedColumn; + i1.GeneratedColumn get createdAt => + columnsByName['created_at']! as i1.GeneratedColumn; + i1.GeneratedColumn get username => + columnsByName['username']! as i1.GeneratedColumn; + i1.GeneratedColumn get passwordHash => + columnsByName['password_hash']! as i1.GeneratedColumn; +} + +i1.GeneratedColumn _column_32(String aliasedName) => + i1.GeneratedColumn('created_at', aliasedName, false, + type: i1.DriftSqlType.dateTime, defaultValue: currentDateAndTime); +i1.GeneratedColumn _column_33(String aliasedName) => + i1.GeneratedColumn('username', aliasedName, false, + type: i1.DriftSqlType.string); +i1.GeneratedColumn _column_34(String aliasedName) => + i1.GeneratedColumn('password_hash', aliasedName, false, + type: i1.DriftSqlType.string); + +class Shape4 extends i0.VersionedTable { + Shape4({required super.source, required super.alias}) : super.aliased(); + i1.GeneratedColumn get id => + columnsByName['id']! as i1.GeneratedColumn; + i1.GeneratedColumn get start => + columnsByName['start']! as i1.GeneratedColumn; + i1.GeneratedColumn get end => + columnsByName['end']! as i1.GeneratedColumn; + i1.GeneratedColumn get trackId => + columnsByName['track_id']! as i1.GeneratedColumn; + i1.GeneratedColumn get createdAt => + columnsByName['created_at']! as i1.GeneratedColumn; +} + +i1.GeneratedColumn _column_35(String aliasedName) => + i1.GeneratedColumn('start', aliasedName, false, + type: i1.DriftSqlType.int); +i1.GeneratedColumn _column_36(String aliasedName) => + i1.GeneratedColumn('end', aliasedName, false, + type: i1.DriftSqlType.int); +i1.GeneratedColumn _column_37(String aliasedName) => + i1.GeneratedColumn('track_id', aliasedName, false, + type: i1.DriftSqlType.string); + +class Shape5 extends i0.VersionedTable { + Shape5({required super.source, required super.alias}) : super.aliased(); + i1.GeneratedColumn get id => + columnsByName['id']! as i1.GeneratedColumn; + i1.GeneratedColumn get trackId => + columnsByName['track_id']! as i1.GeneratedColumn; + i1.GeneratedColumn get sourceId => + columnsByName['source_id']! as i1.GeneratedColumn; + i1.GeneratedColumn get sourceType => + columnsByName['source_type']! as i1.GeneratedColumn; + i1.GeneratedColumn get createdAt => + columnsByName['created_at']! as i1.GeneratedColumn; +} + +i1.GeneratedColumn _column_38(String aliasedName) => + i1.GeneratedColumn('source_id', aliasedName, false, + type: i1.DriftSqlType.string); +i1.GeneratedColumn _column_39(String aliasedName) => + i1.GeneratedColumn('source_type', aliasedName, false, + type: i1.DriftSqlType.string, + defaultValue: Constant(SourceType.youtube.name)); + +class Shape6 extends i0.VersionedTable { + Shape6({required super.source, required super.alias}) : super.aliased(); + i1.GeneratedColumn get id => + columnsByName['id']! as i1.GeneratedColumn; + i1.GeneratedColumn get playing => + columnsByName['playing']! as i1.GeneratedColumn; + i1.GeneratedColumn get loopMode => + columnsByName['loop_mode']! as i1.GeneratedColumn; + i1.GeneratedColumn get shuffled => + columnsByName['shuffled']! as i1.GeneratedColumn; + i1.GeneratedColumn get collections => + columnsByName['collections']! as i1.GeneratedColumn; +} + +i1.GeneratedColumn _column_40(String aliasedName) => + i1.GeneratedColumn('playing', aliasedName, false, + type: i1.DriftSqlType.bool, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'CHECK ("playing" IN (0, 1))')); +i1.GeneratedColumn _column_41(String aliasedName) => + i1.GeneratedColumn('loop_mode', aliasedName, false, + type: i1.DriftSqlType.string); +i1.GeneratedColumn _column_42(String aliasedName) => + i1.GeneratedColumn('shuffled', aliasedName, false, + type: i1.DriftSqlType.bool, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'CHECK ("shuffled" IN (0, 1))')); +i1.GeneratedColumn _column_43(String aliasedName) => + i1.GeneratedColumn('collections', aliasedName, false, + type: i1.DriftSqlType.string); + +class Shape7 extends i0.VersionedTable { + Shape7({required super.source, required super.alias}) : super.aliased(); + i1.GeneratedColumn get id => + columnsByName['id']! as i1.GeneratedColumn; + i1.GeneratedColumn get audioPlayerStateId => + columnsByName['audio_player_state_id']! as i1.GeneratedColumn; + i1.GeneratedColumn get index => + columnsByName['index']! as i1.GeneratedColumn; +} + +i1.GeneratedColumn _column_44(String aliasedName) => + i1.GeneratedColumn('audio_player_state_id', aliasedName, false, + type: i1.DriftSqlType.int, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'REFERENCES audio_player_state_table (id)')); +i1.GeneratedColumn _column_45(String aliasedName) => + i1.GeneratedColumn('index', aliasedName, false, + type: i1.DriftSqlType.int); + +class Shape8 extends i0.VersionedTable { + Shape8({required super.source, required super.alias}) : super.aliased(); + i1.GeneratedColumn get id => + columnsByName['id']! as i1.GeneratedColumn; + i1.GeneratedColumn get playlistId => + columnsByName['playlist_id']! as i1.GeneratedColumn; + i1.GeneratedColumn get uri => + columnsByName['uri']! as i1.GeneratedColumn; + i1.GeneratedColumn get extras => + columnsByName['extras']! as i1.GeneratedColumn; + i1.GeneratedColumn get httpHeaders => + columnsByName['http_headers']! as i1.GeneratedColumn; +} + +i1.GeneratedColumn _column_46(String aliasedName) => + i1.GeneratedColumn('playlist_id', aliasedName, false, + type: i1.DriftSqlType.int, + defaultConstraints: i1.GeneratedColumn.constraintIsAlways( + 'REFERENCES playlist_table (id)')); +i1.GeneratedColumn _column_47(String aliasedName) => + i1.GeneratedColumn('uri', aliasedName, false, + type: i1.DriftSqlType.string); +i1.GeneratedColumn _column_48(String aliasedName) => + i1.GeneratedColumn('extras', aliasedName, true, + type: i1.DriftSqlType.string); +i1.GeneratedColumn _column_49(String aliasedName) => + i1.GeneratedColumn('http_headers', aliasedName, true, + type: i1.DriftSqlType.string); + +class Shape9 extends i0.VersionedTable { + Shape9({required super.source, required super.alias}) : super.aliased(); + i1.GeneratedColumn get id => + columnsByName['id']! as i1.GeneratedColumn; + i1.GeneratedColumn get createdAt => + columnsByName['created_at']! as i1.GeneratedColumn; + i1.GeneratedColumn get type => + columnsByName['type']! as i1.GeneratedColumn; + i1.GeneratedColumn get itemId => + columnsByName['item_id']! as i1.GeneratedColumn; + i1.GeneratedColumn get data => + columnsByName['data']! as i1.GeneratedColumn; +} + +i1.GeneratedColumn _column_50(String aliasedName) => + i1.GeneratedColumn('type', aliasedName, false, + type: i1.DriftSqlType.string); +i1.GeneratedColumn _column_51(String aliasedName) => + i1.GeneratedColumn('item_id', aliasedName, false, + type: i1.DriftSqlType.string); +i1.GeneratedColumn _column_52(String aliasedName) => + i1.GeneratedColumn('data', aliasedName, false, + type: i1.DriftSqlType.string); + +class Shape10 extends i0.VersionedTable { + Shape10({required super.source, required super.alias}) : super.aliased(); + i1.GeneratedColumn get id => + columnsByName['id']! as i1.GeneratedColumn; + i1.GeneratedColumn get trackId => + columnsByName['track_id']! as i1.GeneratedColumn; + i1.GeneratedColumn get data => + columnsByName['data']! as i1.GeneratedColumn; +} + +i0.MigrationStepWithVersion migrationSteps({ + required Future Function(i1.Migrator m, Schema2 schema) from1To2, +}) { + return (currentVersion, database) async { + switch (currentVersion) { + case 1: + final schema = Schema2(database: database); + final migrator = i1.Migrator(database, schema); + await from1To2(migrator, schema); + return 2; + default: + throw ArgumentError.value('Unknown migration from $currentVersion'); + } + }; +} + +i1.OnUpgrade stepByStep({ + required Future Function(i1.Migrator m, Schema2 schema) from1To2, +}) => + i0.VersionedSchema.stepByStepHelper( + step: migrationSteps( + from1To2: from1To2, + )); diff --git a/lib/models/database/tables/preferences.dart b/lib/models/database/tables/preferences.dart index ae4ec1e8..96132de8 100644 --- a/lib/models/database/tables/preferences.dart +++ b/lib/models/database/tables/preferences.dart @@ -14,7 +14,8 @@ enum CloseBehavior { enum AudioSource { youtube, piped, - jiosaavn; + jiosaavn, + invidious; String get label => name[0].toUpperCase() + name.substring(1); } @@ -77,6 +78,8 @@ class PreferencesTable extends Table { text().withDefault(const Constant("")).map(const StringListConverter())(); TextColumn get pipedInstance => text().withDefault(const Constant("https://pipedapi.kavin.rocks"))(); + TextColumn get invidiousInstance => + text().withDefault(const Constant("https://inv.nadeko.net"))(); TextColumn get themeMode => textEnum().withDefault(Constant(ThemeMode.system.name))(); TextColumn get audioSource => @@ -113,6 +116,7 @@ class PreferencesTable extends Table { downloadLocation: "", localLibraryLocation: [], pipedInstance: "https://pipedapi.kavin.rocks", + invidiousInstance: "https://inv.nadeko.net", themeMode: ThemeMode.system, audioSource: AudioSource.youtube, streamMusicCodec: SourceCodecs.weba, diff --git a/lib/modules/player/sibling_tracks_sheet.dart b/lib/modules/player/sibling_tracks_sheet.dart index b58a5894..3a31d88e 100644 --- a/lib/modules/player/sibling_tracks_sheet.dart +++ b/lib/modules/player/sibling_tracks_sheet.dart @@ -23,6 +23,7 @@ import 'package:spotube/provider/user_preferences/user_preferences_provider.dart import 'package:spotube/services/sourced_track/models/source_info.dart'; import 'package:spotube/services/sourced_track/models/video_info.dart'; import 'package:spotube/services/sourced_track/sourced_track.dart'; +import 'package:spotube/services/sourced_track/sources/invidious.dart'; import 'package:spotube/services/sourced_track/sources/jiosaavn.dart'; import 'package:spotube/services/sourced_track/sources/piped.dart'; import 'package:spotube/services/sourced_track/sources/youtube.dart'; @@ -42,6 +43,17 @@ final sourceInfoToIconMap = { ), ), PipedSourceInfo: const Icon(SpotubeIcons.piped), + InvidiousSourceInfo: Container( + height: 18, + width: 18, + decoration: BoxDecoration( + borderRadius: BorderRadius.circular(90), + image: DecorationImage( + image: Assets.invidious.provider(), + fit: BoxFit.cover, + ), + ), + ), }; class SiblingTracksSheet extends HookConsumerWidget { diff --git a/lib/pages/getting_started/sections/playback.dart b/lib/pages/getting_started/sections/playback.dart index e7087afd..dbf0bda2 100644 --- a/lib/pages/getting_started/sections/playback.dart +++ b/lib/pages/getting_started/sections/playback.dart @@ -17,6 +17,10 @@ final audioSourceToIconMap = { size: 30, ), AudioSource.piped: const Icon(SpotubeIcons.piped, size: 30), + AudioSource.invidious: ClipRRect( + borderRadius: BorderRadius.circular(48), + child: Assets.invidious.image(width: 48, height: 48), + ), AudioSource.jiosaavn: Assets.jiosaavn.image(width: 48, height: 48), }; @@ -45,6 +49,7 @@ class GettingStartedPagePlaybackSection extends HookConsumerWidget { AudioSource.jiosaavn: "${context.l10n.jiosaavn_source_description}\n" "${context.l10n.highest_quality("320kbps mp")}", + AudioSource.invidious: context.l10n.invidious_source_description, }, []); @@ -104,7 +109,9 @@ class GettingStartedPagePlaybackSection extends HookConsumerWidget { title: Align( alignment: switch (preferences.audioSource) { AudioSource.youtube => Alignment.centerLeft, - AudioSource.piped => Alignment.center, + AudioSource.piped || + AudioSource.invidious => + Alignment.center, AudioSource.jiosaavn => Alignment.centerRight, }, child: Text( diff --git a/lib/pages/settings/sections/playback.dart b/lib/pages/settings/sections/playback.dart index 6273c557..1101f424 100644 --- a/lib/pages/settings/sections/playback.dart +++ b/lib/pages/settings/sections/playback.dart @@ -10,7 +10,8 @@ import 'package:spotube/models/database/database.dart'; import 'package:spotube/modules/settings/section_card_with_heading.dart'; import 'package:spotube/components/adaptive/adaptive_select_tile.dart'; import 'package:spotube/extensions/context.dart'; -import 'package:spotube/provider/piped_instances_provider.dart'; +import 'package:spotube/provider/audio_player/sources/invidious_instances_provider.dart'; +import 'package:spotube/provider/audio_player/sources/piped_instances_provider.dart'; import 'package:spotube/provider/user_preferences/user_preferences_provider.dart'; import 'package:spotube/services/sourced_track/enums.dart'; @@ -135,6 +136,73 @@ class SettingsPlaybackSection extends HookConsumerWidget { ); }), ), + AnimatedSwitcher( + duration: const Duration(milliseconds: 300), + child: preferences.audioSource != AudioSource.invidious + ? const SizedBox.shrink() + : Consumer(builder: (context, ref, child) { + final instanceList = ref.watch(invidiousInstancesProvider); + + return instanceList.when( + data: (data) { + return AdaptiveSelectTile( + secondary: const Icon(SpotubeIcons.piped), + title: Text(context.l10n.invidious_instance), + subtitle: RichText( + text: TextSpan( + children: [ + TextSpan( + text: context.l10n.invidious_description, + style: theme.textTheme.bodyMedium, + ), + const TextSpan(text: "\n"), + TextSpan( + text: context.l10n.invidious_warning, + style: theme.textTheme.labelMedium, + ) + ], + ), + ), + value: preferences.invidiousInstance, + showValueWhenUnfolded: false, + options: data + .sortedBy((e) => e.name) + .map( + (e) => DropdownMenuItem( + value: e.details.uri, + child: RichText( + text: TextSpan( + children: [ + TextSpan( + text: "${e.name.trim()}\n", + style: theme.textTheme.labelLarge, + ), + TextSpan( + text: countryCodeToEmoji( + e.details.region, + ), + style: GoogleFonts.notoColorEmoji(), + ), + ], + ), + ), + ), + ) + .toList(), + onChanged: (value) { + if (value != null) { + preferencesNotifier.setInvidiousInstance(value); + } + }, + ); + }, + loading: () => const Center( + child: CircularProgressIndicator(), + ), + error: (error, stackTrace) => Text(error.toString()), + ); + }), + ), AnimatedSwitcher( duration: const Duration(milliseconds: 300), child: preferences.audioSource != AudioSource.piped @@ -159,7 +227,8 @@ class SettingsPlaybackSection extends HookConsumerWidget { duration: const Duration(milliseconds: 300), child: preferences.searchMode == SearchMode.youtube && (preferences.audioSource == AudioSource.piped || - preferences.audioSource == AudioSource.youtube) + preferences.audioSource == AudioSource.youtube || + preferences.audioSource == AudioSource.invidious) ? SwitchListTile( secondary: const Icon(SpotubeIcons.skip), title: Text(context.l10n.skip_non_music), diff --git a/lib/provider/audio_player/sources/invidious_instances_provider.dart b/lib/provider/audio_player/sources/invidious_instances_provider.dart new file mode 100644 index 00000000..c04ac765 --- /dev/null +++ b/lib/provider/audio_player/sources/invidious_instances_provider.dart @@ -0,0 +1,12 @@ +import 'package:flutter_riverpod/flutter_riverpod.dart'; +import 'package:spotube/services/sourced_track/sources/invidious.dart'; + +final invidiousInstancesProvider = FutureProvider((ref) async { + final invidious = ref.watch(invidiousProvider); + + final instances = await invidious.instances(); + + return instances + .where((instance) => instance.details.type == "https") + .toList(); +}); diff --git a/lib/provider/piped_instances_provider.dart b/lib/provider/audio_player/sources/piped_instances_provider.dart similarity index 100% rename from lib/provider/piped_instances_provider.dart rename to lib/provider/audio_player/sources/piped_instances_provider.dart diff --git a/lib/provider/server/routes/playback.dart b/lib/provider/server/routes/playback.dart index 30322a6f..93f5dac2 100644 --- a/lib/provider/server/routes/playback.dart +++ b/lib/provider/server/routes/playback.dart @@ -20,6 +20,17 @@ class ServerPlaybackRoutes { /// @get('/stream/') Future getStreamTrackId(Request request, String trackId) async { + final options = Options( + headers: { + ...request.headers, + "User-Agent": + "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/123.0.0.0 Safari/537.36", + "Cache-Control": "max-age=0", + "Connection": "keep-alive", + }, + responseType: ResponseType.stream, + validateStatus: (status) => status! < 400, + ); try { final track = playlist.tracks.firstWhere((element) => element.id == trackId); @@ -30,22 +41,33 @@ class ServerPlaybackRoutes { : await ref.read(sourcedTrackProvider(SpotubeMedia(track)).future); ref.read(activeSourcedTrackProvider.notifier).update(sourcedTrack); - - final res = await dio.get( + final res = await dio + .get( sourcedTrack!.url, - options: Options( + options: options.copyWith( headers: { - ...request.headers, - "User-Agent": - "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/123.0.0.0 Safari/537.36", + ...options.headers!, "host": Uri.parse(sourcedTrack.url).host, - "Cache-Control": "max-age=0", - "Connection": "keep-alive", }, - responseType: ResponseType.stream, - validateStatus: (status) => status! < 500, ), - ); + ) + .catchError((e, stack) async { + final sourcedTrack = await ref + .read(sourcedTrackProvider(SpotubeMedia(track)).notifier) + .switchToAlternativeSources(); + + ref.read(activeSourcedTrackProvider.notifier).update(sourcedTrack); + + return await dio.get( + sourcedTrack!.url, + options: options.copyWith( + headers: { + ...options.headers!, + "host": Uri.parse(sourcedTrack.url).host, + }, + ), + ); + }); final audioStream = (res.data?.stream as Stream?)?.asBroadcastStream(); diff --git a/lib/provider/server/sourced_track.dart b/lib/provider/server/sourced_track.dart index 53a04023..58531523 100644 --- a/lib/provider/server/sourced_track.dart +++ b/lib/provider/server/sourced_track.dart @@ -5,24 +5,44 @@ import 'package:spotube/provider/audio_player/audio_player.dart'; import 'package:spotube/services/audio_player/audio_player.dart'; import 'package:spotube/services/sourced_track/sourced_track.dart'; -final sourcedTrackProvider = - FutureProvider.family((ref, media) async { - final track = media?.track; - if (track == null || track is LocalTrack) { - return null; +class SourcedTrackNotifier + extends FamilyAsyncNotifier { + @override + build(media) async { + final track = media?.track; + if (track == null || track is LocalTrack) { + return null; + } + + ref.listen( + audioPlayerProvider.select((value) => value.tracks), + (old, next) { + if (next.isEmpty || next.none((element) => element.id == track.id)) { + ref.invalidateSelf(); + } + }, + ); + + final sourcedTrack = + await SourcedTrack.fetchFromTrack(track: track, ref: ref); + + return sourcedTrack; } - ref.listen( - audioPlayerProvider.select((value) => value.tracks), - (old, next) { - if (next.isEmpty || next.none((element) => element.id == track.id)) { - ref.invalidateSelf(); - } - }, - ); + Future switchToAlternativeSources() async { + if (arg == null) { + return null; + } + return await update((prev) async { + return await SourcedTrack.fetchFromTrackAltSource( + track: arg!.track, + ref: ref, + ); + }); + } +} - final sourcedTrack = - await SourcedTrack.fetchFromTrack(track: track, ref: ref); - - return sourcedTrack; -}); +final sourcedTrackProvider = AsyncNotifierProviderFamily( + () => SourcedTrackNotifier(), +); diff --git a/lib/provider/user_preferences/user_preferences_provider.dart b/lib/provider/user_preferences/user_preferences_provider.dart index 23479b71..5fe3cb11 100644 --- a/lib/provider/user_preferences/user_preferences_provider.dart +++ b/lib/provider/user_preferences/user_preferences_provider.dart @@ -167,6 +167,10 @@ class UserPreferencesNotifier extends Notifier { setData(PreferencesTableCompanion(pipedInstance: Value(instance))); } + void setInvidiousInstance(String instance) { + setData(PreferencesTableCompanion(invidiousInstance: Value(instance))); + } + void setSearchMode(SearchMode mode) { setData(PreferencesTableCompanion(searchMode: Value(mode))); } diff --git a/lib/services/sourced_track/models/source_info.g.dart b/lib/services/sourced_track/models/source_info.g.dart index 5fe136ce..54671f63 100644 --- a/lib/services/sourced_track/models/source_info.g.dart +++ b/lib/services/sourced_track/models/source_info.g.dart @@ -12,7 +12,7 @@ SourceInfo _$SourceInfoFromJson(Map json) => SourceInfo( artist: json['artist'] as String, thumbnail: json['thumbnail'] as String, pageUrl: json['pageUrl'] as String, - duration: Duration(microseconds: json['duration'] as int), + duration: Duration(microseconds: (json['duration'] as num).toInt()), artistUrl: json['artistUrl'] as String, album: json['album'] as String?, ); diff --git a/lib/services/sourced_track/models/video_info.dart b/lib/services/sourced_track/models/video_info.dart index 58dd0280..e3452c61 100644 --- a/lib/services/sourced_track/models/video_info.dart +++ b/lib/services/sourced_track/models/video_info.dart @@ -1,3 +1,4 @@ +import 'package:invidious/invidious.dart'; import 'package:piped_client/piped_client.dart'; import 'package:spotube/models/database/database.dart'; @@ -112,4 +113,24 @@ class YoutubeVideoInfo { channelId: stream.uploaderUrl, ); } + + factory YoutubeVideoInfo.fromSearchResponse( + InvidiousSearchResponseVideo searchResponse, + SearchMode searchMode, + ) { + return YoutubeVideoInfo( + searchMode: searchMode, + title: searchResponse.title, + duration: Duration(seconds: searchResponse.lengthSeconds), + thumbnailUrl: searchResponse.videoThumbnails.first.url, + id: searchResponse.videoId, + likes: 0, + dislikes: 0, + views: searchResponse.viewCount, + channelName: searchResponse.author, + channelId: searchResponse.authorId, + publishedAt: + DateTime.fromMillisecondsSinceEpoch(searchResponse.published * 1000), + ); + } } diff --git a/lib/services/sourced_track/sourced_track.dart b/lib/services/sourced_track/sourced_track.dart index 977b980b..38f01498 100644 --- a/lib/services/sourced_track/sourced_track.dart +++ b/lib/services/sourced_track/sourced_track.dart @@ -12,6 +12,7 @@ import 'package:spotube/services/sourced_track/enums.dart'; import 'package:spotube/services/sourced_track/exceptions.dart'; import 'package:spotube/services/sourced_track/models/source_info.dart'; import 'package:spotube/services/sourced_track/models/source_map.dart'; +import 'package:spotube/services/sourced_track/sources/invidious.dart'; import 'package:spotube/services/sourced_track/sources/jiosaavn.dart'; import 'package:spotube/services/sourced_track/sources/piped.dart'; import 'package:spotube/services/sourced_track/sources/youtube.dart'; @@ -85,6 +86,13 @@ abstract class SourcedTrack extends Track { sourceInfo: sourceInfo, track: track, ), + AudioSource.invidious => InvidiousSourcedTrack( + ref: ref, + source: source, + siblings: siblings, + sourceInfo: sourceInfo, + track: track, + ), }; } @@ -104,6 +112,49 @@ abstract class SourcedTrack extends Track { return "$title - ${artists.join(", ")}"; } + static fetchFromTrackAltSource({ + required Track track, + required Ref ref, + }) async { + final preferences = ref.read(userPreferencesProvider); + try { + return switch (preferences.audioSource) { + AudioSource.piped || + AudioSource.invidious || + AudioSource.jiosaavn => + await YoutubeSourcedTrack.fetchFromTrack(track: track, ref: ref), + AudioSource.youtube => + await JioSaavnSourcedTrack.fetchFromTrack(track: track, ref: ref), + }; + } on TrackNotFoundError catch (_) { + return switch (preferences.audioSource) { + AudioSource.piped || + AudioSource.youtube || + AudioSource.invidious => + await JioSaavnSourcedTrack.fetchFromTrack( + track: track, + ref: ref, + weakMatch: true, + ), + AudioSource.jiosaavn => + await YoutubeSourcedTrack.fetchFromTrack(track: track, ref: ref), + }; + } on HttpClientClosedException catch (_) { + return await PipedSourcedTrack.fetchFromTrack(track: track, ref: ref); + } on VideoUnplayableException catch (_) { + return await InvidiousSourcedTrack.fetchFromTrack(track: track, ref: ref); + } catch (e) { + if (e is DioException || e is ClientException || e is SocketException) { + return await JioSaavnSourcedTrack.fetchFromTrack( + track: track, + ref: ref, + weakMatch: preferences.audioSource == AudioSource.jiosaavn, + ); + } + rethrow; + } + } + static Future fetchFromTrack({ required Track track, required Ref ref, @@ -117,11 +168,14 @@ abstract class SourcedTrack extends Track { await YoutubeSourcedTrack.fetchFromTrack(track: track, ref: ref), AudioSource.jiosaavn => await JioSaavnSourcedTrack.fetchFromTrack(track: track, ref: ref), + AudioSource.invidious => + await InvidiousSourcedTrack.fetchFromTrack(track: track, ref: ref), }; } on TrackNotFoundError catch (_) { return switch (preferences.audioSource) { AudioSource.piped || - AudioSource.youtube => + AudioSource.youtube || + AudioSource.invidious => await JioSaavnSourcedTrack.fetchFromTrack( track: track, ref: ref, @@ -136,11 +190,19 @@ abstract class SourcedTrack extends Track { return await PipedSourcedTrack.fetchFromTrack(track: track, ref: ref); } catch (e) { if (e is DioException || e is ClientException || e is SocketException) { - return await JioSaavnSourcedTrack.fetchFromTrack( - track: track, - ref: ref, - weakMatch: preferences.audioSource == AudioSource.jiosaavn, - ); + return switch (preferences.audioSource) { + AudioSource.piped || + AudioSource.invidious => + await YoutubeSourcedTrack.fetchFromTrack( + track: track, + ref: ref, + ), + _ => await JioSaavnSourcedTrack.fetchFromTrack( + track: track, + ref: ref, + weakMatch: preferences.audioSource == AudioSource.jiosaavn, + ) + }; } rethrow; } @@ -159,6 +221,8 @@ abstract class SourcedTrack extends Track { YoutubeSourcedTrack.fetchSiblings(track: track, ref: ref), AudioSource.jiosaavn => JioSaavnSourcedTrack.fetchSiblings(track: track, ref: ref), + AudioSource.invidious => + InvidiousSourcedTrack.fetchSiblings(track: track, ref: ref), }; } diff --git a/lib/services/sourced_track/sources/invidious.dart b/lib/services/sourced_track/sources/invidious.dart new file mode 100644 index 00000000..2ec5068e --- /dev/null +++ b/lib/services/sourced_track/sources/invidious.dart @@ -0,0 +1,266 @@ +import 'package:collection/collection.dart'; +import 'package:drift/drift.dart'; +import 'package:flutter_riverpod/flutter_riverpod.dart'; +import 'package:spotify/spotify.dart'; +import 'package:spotube/models/database/database.dart'; +import 'package:spotube/provider/database/database.dart'; +import 'package:spotube/provider/user_preferences/user_preferences_provider.dart'; +import 'package:spotube/services/sourced_track/enums.dart'; +import 'package:spotube/services/sourced_track/exceptions.dart'; +import 'package:spotube/services/sourced_track/models/source_info.dart'; +import 'package:spotube/services/sourced_track/models/source_map.dart'; +import 'package:spotube/services/sourced_track/models/video_info.dart'; +import 'package:spotube/services/sourced_track/sourced_track.dart'; +import 'package:invidious/invidious.dart'; +import 'package:spotube/services/sourced_track/sources/youtube.dart'; +import 'package:spotube/utils/service_utils.dart'; + +final invidiousProvider = Provider( + (ref) { + final invidiousInstance = ref.watch( + userPreferencesProvider.select((s) => s.invidiousInstance), + ); + return InvidiousClient(server: invidiousInstance); + }, +); + +class InvidiousSourceInfo extends SourceInfo { + InvidiousSourceInfo({ + required super.id, + required super.title, + required super.artist, + required super.thumbnail, + required super.pageUrl, + required super.duration, + required super.artistUrl, + required super.album, + }); +} + +class InvidiousSourcedTrack extends SourcedTrack { + InvidiousSourcedTrack({ + required super.ref, + required super.source, + required super.siblings, + required super.sourceInfo, + required super.track, + }); + + static Future fetchFromTrack({ + required Track track, + required Ref ref, + }) async { + final database = ref.read(databaseProvider); + final cachedSource = await (database.select(database.sourceMatchTable) + ..where((s) => s.trackId.equals(track.id!)) + ..limit(1) + ..orderBy([ + (s) => + OrderingTerm(expression: s.createdAt, mode: OrderingMode.desc), + ])) + .getSingleOrNull(); + final invidiousClient = ref.read(invidiousProvider); + + if (cachedSource == null) { + final siblings = await fetchSiblings(ref: ref, track: track); + if (siblings.isEmpty) { + throw TrackNotFoundError(track); + } + + await database.into(database.sourceMatchTable).insert( + SourceMatchTableCompanion.insert( + trackId: track.id!, + sourceId: siblings.first.info.id, + sourceType: const Value(SourceType.youtube), + ), + ); + + return InvidiousSourcedTrack( + ref: ref, + siblings: siblings.map((s) => s.info).skip(1).toList(), + source: siblings.first.source as SourceMap, + sourceInfo: siblings.first.info, + track: track, + ); + } else { + final manifest = + await invidiousClient.videos.get(cachedSource.sourceId, local: true); + + return InvidiousSourcedTrack( + ref: ref, + siblings: [], + source: toSourceMap(manifest), + sourceInfo: InvidiousSourceInfo( + id: manifest.videoId, + artist: manifest.author, + artistUrl: manifest.authorUrl, + pageUrl: "https://www.youtube.com/watch?v=${manifest.videoId}", + thumbnail: manifest.videoThumbnails.first.url, + title: manifest.title, + duration: Duration(seconds: manifest.lengthSeconds), + album: null, + ), + track: track, + ); + } + } + + static SourceMap toSourceMap(InvidiousVideoResponse manifest) { + final m4a = manifest.adaptiveFormats + .where((audio) => audio.type.contains("audio/mp4")) + .sorted((a, b) => int.parse(a.bitrate).compareTo(int.parse(b.bitrate))); + + final weba = manifest.adaptiveFormats + .where((audio) => audio.type.contains("audio/webm")) + .sorted((a, b) => int.parse(a.bitrate).compareTo(int.parse(b.bitrate))); + + return SourceMap( + m4a: SourceQualityMap( + high: m4a.first.url.toString(), + medium: (m4a.elementAtOrNull(m4a.length ~/ 2) ?? m4a[1]).url.toString(), + low: m4a.last.url.toString(), + ), + weba: SourceQualityMap( + high: weba.first.url.toString(), + medium: + (weba.elementAtOrNull(weba.length ~/ 2) ?? weba[1]).url.toString(), + low: weba.last.url.toString(), + ), + ); + } + + static Future toSiblingType( + int index, + YoutubeVideoInfo item, + InvidiousClient invidiousClient, + ) async { + SourceMap? sourceMap; + if (index == 0) { + final manifest = await invidiousClient.videos.get(item.id, local: true); + sourceMap = toSourceMap(manifest); + } + + final SiblingType sibling = ( + info: InvidiousSourceInfo( + id: item.id, + artist: item.channelName, + artistUrl: "https://www.youtube.com/${item.channelId}", + pageUrl: "https://www.youtube.com/watch?v=${item.id}", + thumbnail: item.thumbnailUrl, + title: item.title, + duration: item.duration, + album: null, + ), + source: sourceMap, + ); + + return sibling; + } + + static Future> fetchSiblings({ + required Track track, + required Ref ref, + }) async { + final invidiousClient = ref.read(invidiousProvider); + final preference = ref.read(userPreferencesProvider); + + final query = SourcedTrack.getSearchTerm(track); + + final searchResults = await invidiousClient.search.list( + query, + type: InvidiousSearchType.video, + ); + + if (ServiceUtils.onlyContainsEnglish(query)) { + return await Future.wait( + searchResults + .whereType() + .map( + (result) => YoutubeVideoInfo.fromSearchResponse( + result, + preference.searchMode, + ), + ) + .mapIndexed((i, r) => toSiblingType(i, r, invidiousClient)), + ); + } + + final rankedSiblings = YoutubeSourcedTrack.rankResults( + searchResults + .whereType() + .map( + (result) => YoutubeVideoInfo.fromSearchResponse( + result, + preference.searchMode, + ), + ) + .toList(), + track, + ); + + return await Future.wait( + rankedSiblings.mapIndexed((i, r) => toSiblingType(i, r, invidiousClient)), + ); + } + + @override + Future copyWithSibling() async { + if (siblings.isNotEmpty) { + return this; + } + final fetchedSiblings = await fetchSiblings(ref: ref, track: this); + + return InvidiousSourcedTrack( + ref: ref, + siblings: fetchedSiblings + .where((s) => s.info.id != sourceInfo.id) + .map((s) => s.info) + .toList(), + source: source, + sourceInfo: sourceInfo, + track: this, + ); + } + + @override + Future swapWithSibling(SourceInfo sibling) async { + if (sibling.id == sourceInfo.id) { + return null; + } + + // a sibling source that was fetched from the search results + final isStepSibling = siblings.none((s) => s.id == sibling.id); + + final newSourceInfo = isStepSibling + ? sibling + : siblings.firstWhere((s) => s.id == sibling.id); + final newSiblings = siblings.where((s) => s.id != sibling.id).toList() + ..insert(0, sourceInfo); + + final pipedClient = ref.read(invidiousProvider); + + final manifest = + await pipedClient.videos.get(newSourceInfo.id, local: true); + + final database = ref.read(databaseProvider); + await database.into(database.sourceMatchTable).insert( + SourceMatchTableCompanion.insert( + trackId: id!, + sourceId: newSourceInfo.id, + sourceType: const Value(SourceType.youtube), + // Because we're sorting by createdAt in the query + // we have to update it to indicate priority + createdAt: Value(DateTime.now()), + ), + mode: InsertMode.replace, + ); + + return InvidiousSourcedTrack( + ref: ref, + siblings: newSiblings, + source: toSourceMap(manifest), + sourceInfo: newSourceInfo, + track: this, + ); + } +} diff --git a/pubspec.lock b/pubspec.lock index b653c2fd..37aa3d54 100644 --- a/pubspec.lock +++ b/pubspec.lock @@ -245,10 +245,10 @@ packages: dependency: "direct dev" description: name: build_runner - sha256: dd09dd4e2b078992f42aac7f1a622f01882a8492fef08486b27ddde929c19f04 + sha256: "028819cfb90051c6b5440c7e574d1896f8037e3c96cf17aaeb054c9311cfbf4d" url: "https://pub.dev" source: hosted - version: "2.4.12" + version: "2.4.13" build_runner_core: dependency: transitive description: @@ -393,6 +393,14 @@ packages: url: "https://pub.dev" source: hosted version: "3.1.1" + coverage: + dependency: transitive + description: + name: coverage + sha256: c1fb2dce3c0085f39dc72668e85f8e0210ec7de05345821ff58530567df345a5 + url: "https://pub.dev" + source: hosted + version: "1.9.2" cross_file: dependency: transitive description: @@ -518,10 +526,18 @@ packages: dependency: "direct main" description: name: dio - sha256: "11e40df547d418cc0c4900a9318b26304e665da6fa4755399a9ff9efd09034b5" + sha256: "5598aa796bbf4699afd5c67c0f5f6e2ed542afc956884b9cd58c306966efc260" url: "https://pub.dev" source: hosted - version: "5.4.3+1" + version: "5.7.0" + dio_web_adapter: + dependency: transitive + description: + name: dio_web_adapter + sha256: "33259a9276d6cea88774a0000cfae0d861003497755969c92faa223108620dc8" + url: "https://pub.dev" + source: hosted + version: "2.0.0" disable_battery_optimization: dependency: "direct main" description: @@ -543,18 +559,18 @@ packages: dependency: "direct main" description: name: drift - sha256: "6acedc562ffeed308049f78fb1906abad3d65714580b6745441ee6d50ec564cd" + sha256: df027d168a2985a2e9da900adeba2ab0136f0d84436592cf3cd5135f82c8579c url: "https://pub.dev" source: hosted - version: "2.18.0" + version: "2.21.0" drift_dev: dependency: "direct dev" description: name: drift_dev - sha256: d9b020736ea85fff1568699ce18b89fabb3f0f042e8a7a05e84a3ec20d39acde + sha256: "27bab15e7869b69259663590381180117873b9b273a1ea9ebb21bb73133d1233" url: "https://pub.dev" source: hosted - version: "2.18.0" + version: "2.21.0" duration: dependency: "direct main" description: @@ -992,10 +1008,10 @@ packages: dependency: "direct main" description: name: freezed_annotation - sha256: c3fd9336eb55a38cc1bbd79ab17573113a8deccd0ecbbf926cca3c62803b5c2d + sha256: c2e2d632dd9b8a2b7751117abcfc2b4888ecfe181bd9fca7170d9ef02e595fe2 url: "https://pub.dev" source: hosted - version: "2.4.1" + version: "2.4.4" frontend_server_client: dependency: transitive description: @@ -1246,6 +1262,14 @@ packages: url: "https://pub.dev" source: hosted version: "0.19.0" + invidious: + dependency: "direct main" + description: + name: invidious + sha256: "7cb879c0b4b99aa06ec720af84f6988ff0080bb0434d041f6fb0c4add680ee36" + url: "https://pub.dev" + source: hosted + version: "0.1.0" io: dependency: "direct dev" description: @@ -1274,18 +1298,18 @@ packages: dependency: "direct main" description: name: json_annotation - sha256: b10a7b2ff83d83c777edba3c6a0f97045ddadd56c944e1a23a3fdf43a1bf4467 + sha256: "1ce844379ca14835a50d2f019a3099f419082cfdd231cd86a142af94dd5c6bb1" url: "https://pub.dev" source: hosted - version: "4.8.1" + version: "4.9.0" json_serializable: dependency: "direct dev" description: name: json_serializable - sha256: aa1f5a8912615733e0fdc7a02af03308933c93235bdc8d50d0b0c8a8ccb0b969 + sha256: ea1432d167339ea9b5bb153f0571d0039607a873d6e04e0117af043f14a1fd4b url: "https://pub.dev" source: hosted - version: "6.7.1" + version: "6.8.0" leak_tracker: dependency: transitive description: @@ -1470,6 +1494,14 @@ packages: url: "https://pub.dev" source: hosted version: "1.0.5" + node_preamble: + dependency: transitive + description: + name: node_preamble + sha256: "6e7eac89047ab8a8d26cf16127b5ed26de65209847630400f9aefd7cd5c730db" + url: "https://pub.dev" + source: hosted + version: "2.0.2" oauth2: dependency: transitive description: @@ -1887,6 +1919,14 @@ packages: url: "https://pub.dev" source: hosted version: "1.4.1" + shelf_packages_handler: + dependency: transitive + description: + name: shelf_packages_handler + sha256: "89f967eca29607c933ba9571d838be31d67f53f6e4ee15147d5dc2934fee1b1e" + url: "https://pub.dev" + source: hosted + version: "3.0.2" shelf_router: dependency: "direct main" description: @@ -1895,6 +1935,14 @@ packages: url: "https://pub.dev" source: hosted version: "1.1.4" + shelf_static: + dependency: transitive + description: + name: shelf_static + sha256: c87c3875f91262785dade62d135760c2c69cb217ac759485334c5857ad89f6e3 + url: "https://pub.dev" + source: hosted + version: "1.1.3" shelf_web_socket: dependency: "direct main" description: @@ -1972,6 +2020,22 @@ packages: url: "https://pub.dev" source: hosted version: "1.3.4" + source_map_stack_trace: + dependency: transitive + description: + name: source_map_stack_trace + sha256: c0713a43e323c3302c2abe2a1cc89aa057a387101ebd280371d6a6c9fa68516b + url: "https://pub.dev" + source: hosted + version: "2.1.2" + source_maps: + dependency: transitive + description: + name: source_maps + sha256: "708b3f6b97248e5781f493b765c3337db11c5d2c81c3094f10904bfa8004c703" + url: "https://pub.dev" + source: hosted + version: "0.10.12" source_span: dependency: transitive description: @@ -2032,10 +2096,10 @@ packages: dependency: transitive description: name: sqlparser - sha256: ade9a67fd70d0369329ed3373208de7ebd8662470e8c396fc8d0d60f9acdfc9f + sha256: c5f63dff8677407ddcddfa4744c176ea6dc44286c47ba9e69e76d8071398034d url: "https://pub.dev" source: hosted - version: "0.36.0" + version: "0.39.1" stack_trace: dependency: transitive description: @@ -2124,6 +2188,14 @@ packages: url: "https://pub.dev" source: hosted version: "1.2.1" + test: + dependency: "direct main" + description: + name: test + sha256: "7ee44229615f8f642b68120165ae4c2a75fe77ae2065b1e55ae4711f6cf0899e" + url: "https://pub.dev" + source: hosted + version: "1.25.7" test_api: dependency: transitive description: @@ -2132,6 +2204,14 @@ packages: url: "https://pub.dev" source: hosted version: "0.7.2" + test_core: + dependency: transitive + description: + name: test_core + sha256: "55ea5a652e38a1dfb32943a7973f3681a60f872f8c3a05a14664ad54ef9c6696" + url: "https://pub.dev" + source: hosted + version: "0.6.4" time: dependency: transitive description: @@ -2380,6 +2460,14 @@ packages: url: "https://pub.dev" source: hosted version: "3.0.3" + webkit_inspection_protocol: + dependency: transitive + description: + name: webkit_inspection_protocol + sha256: "87d3f2333bb240704cd3f1c6b5b7acd8a10e7f0bc28c28dcf14e782014f4a572" + url: "https://pub.dev" + source: hosted + version: "1.2.1" wikipedia_api: dependency: "direct main" description: @@ -2445,5 +2533,5 @@ packages: source: hosted version: "2.3.1" sdks: - dart: ">=3.5.0 <4.0.0" + dart: ">=3.5.3 <4.0.0" flutter: ">=3.24.0" diff --git a/pubspec.yaml b/pubspec.yaml index 3c5c5ccb..2923cc3b 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -58,6 +58,7 @@ dependencies: html: ^0.15.1 image_picker: ^1.1.0 intl: any + invidious: ^0.1.0 json_annotation: ^4.8.1 logger: ^2.0.2 media_kit: ^1.1.10+1 @@ -118,14 +119,15 @@ dependencies: tray_manager: ^0.2.2 http: ^1.2.1 riverpod: ^2.5.1 - drift: ^2.18.0 + drift: ^2.21.0 sqlite3_flutter_libs: ^0.5.23 sqlite3: ^2.4.3 encrypt: ^5.0.3 go_router: ^14.2.7 + test: ^1.25.7 dev_dependencies: - build_runner: ^2.4.9 + build_runner: ^2.4.13 crypto: ^3.0.3 envied_generator: ^0.5.4+1 flutter_gen_runner: ^5.4.0 @@ -145,7 +147,7 @@ dev_dependencies: pub_api_client: ^2.7.0 xml: ^6.5.0 io: ^1.0.4 - drift_dev: ^2.18.0 + drift_dev: ^2.21.0 dependency_overrides: web: ^1.1.0 diff --git a/test/drift/app_db/generated/schema.dart b/test/drift/app_db/generated/schema.dart new file mode 100644 index 00000000..1b2142be --- /dev/null +++ b/test/drift/app_db/generated/schema.dart @@ -0,0 +1,23 @@ +// GENERATED CODE, DO NOT EDIT BY HAND. +// ignore_for_file: type=lint +//@dart=2.12 +import 'package:drift/drift.dart'; +import 'package:drift/internal/migrations.dart'; +import 'schema_v2.dart' as v2; +import 'schema_v1.dart' as v1; + +class GeneratedHelper implements SchemaInstantiationHelper { + @override + GeneratedDatabase databaseForVersion(QueryExecutor db, int version) { + switch (version) { + case 2: + return v2.DatabaseAtV2(db); + case 1: + return v1.DatabaseAtV1(db); + default: + throw MissingSchemaException(version, versions); + } + } + + static const versions = const [1, 2]; +} diff --git a/test/drift/app_db/generated/schema_v1.dart b/test/drift/app_db/generated/schema_v1.dart new file mode 100644 index 00000000..9535d685 --- /dev/null +++ b/test/drift/app_db/generated/schema_v1.dart @@ -0,0 +1,3333 @@ +// GENERATED CODE, DO NOT EDIT BY HAND. +// ignore_for_file: type=lint +//@dart=2.12 +import 'package:drift/drift.dart'; +import 'package:flutter/material.dart' hide Table; +import 'package:spotify/spotify.dart'; +import 'package:spotube/services/sourced_track/enums.dart'; +import 'package:spotube/utils/migrations/adapters.dart'; + +class AuthenticationTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + AuthenticationTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn cookie = GeneratedColumn( + 'cookie', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn accessToken = GeneratedColumn( + 'access_token', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn expiration = GeneratedColumn( + 'expiration', aliasedName, false, + type: DriftSqlType.dateTime, requiredDuringInsert: true); + @override + List get $columns => [id, cookie, accessToken, expiration]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'authentication_table'; + @override + Set get $primaryKey => {id}; + @override + AuthenticationTableData map(Map data, + {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return AuthenticationTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + cookie: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}cookie'])!, + accessToken: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}access_token'])!, + expiration: attachedDatabase.typeMapping + .read(DriftSqlType.dateTime, data['${effectivePrefix}expiration'])!, + ); + } + + @override + AuthenticationTable createAlias(String alias) { + return AuthenticationTable(attachedDatabase, alias); + } +} + +class AuthenticationTableData extends DataClass + implements Insertable { + final int id; + final String cookie; + final String accessToken; + final DateTime expiration; + const AuthenticationTableData( + {required this.id, + required this.cookie, + required this.accessToken, + required this.expiration}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['cookie'] = Variable(cookie); + map['access_token'] = Variable(accessToken); + map['expiration'] = Variable(expiration); + return map; + } + + AuthenticationTableCompanion toCompanion(bool nullToAbsent) { + return AuthenticationTableCompanion( + id: Value(id), + cookie: Value(cookie), + accessToken: Value(accessToken), + expiration: Value(expiration), + ); + } + + factory AuthenticationTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return AuthenticationTableData( + id: serializer.fromJson(json['id']), + cookie: serializer.fromJson(json['cookie']), + accessToken: serializer.fromJson(json['accessToken']), + expiration: serializer.fromJson(json['expiration']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'cookie': serializer.toJson(cookie), + 'accessToken': serializer.toJson(accessToken), + 'expiration': serializer.toJson(expiration), + }; + } + + AuthenticationTableData copyWith( + {int? id, + String? cookie, + String? accessToken, + DateTime? expiration}) => + AuthenticationTableData( + id: id ?? this.id, + cookie: cookie ?? this.cookie, + accessToken: accessToken ?? this.accessToken, + expiration: expiration ?? this.expiration, + ); + AuthenticationTableData copyWithCompanion(AuthenticationTableCompanion data) { + return AuthenticationTableData( + id: data.id.present ? data.id.value : this.id, + cookie: data.cookie.present ? data.cookie.value : this.cookie, + accessToken: + data.accessToken.present ? data.accessToken.value : this.accessToken, + expiration: + data.expiration.present ? data.expiration.value : this.expiration, + ); + } + + @override + String toString() { + return (StringBuffer('AuthenticationTableData(') + ..write('id: $id, ') + ..write('cookie: $cookie, ') + ..write('accessToken: $accessToken, ') + ..write('expiration: $expiration') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, cookie, accessToken, expiration); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is AuthenticationTableData && + other.id == this.id && + other.cookie == this.cookie && + other.accessToken == this.accessToken && + other.expiration == this.expiration); +} + +class AuthenticationTableCompanion + extends UpdateCompanion { + final Value id; + final Value cookie; + final Value accessToken; + final Value expiration; + const AuthenticationTableCompanion({ + this.id = const Value.absent(), + this.cookie = const Value.absent(), + this.accessToken = const Value.absent(), + this.expiration = const Value.absent(), + }); + AuthenticationTableCompanion.insert({ + this.id = const Value.absent(), + required String cookie, + required String accessToken, + required DateTime expiration, + }) : cookie = Value(cookie), + accessToken = Value(accessToken), + expiration = Value(expiration); + static Insertable custom({ + Expression? id, + Expression? cookie, + Expression? accessToken, + Expression? expiration, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (cookie != null) 'cookie': cookie, + if (accessToken != null) 'access_token': accessToken, + if (expiration != null) 'expiration': expiration, + }); + } + + AuthenticationTableCompanion copyWith( + {Value? id, + Value? cookie, + Value? accessToken, + Value? expiration}) { + return AuthenticationTableCompanion( + id: id ?? this.id, + cookie: cookie ?? this.cookie, + accessToken: accessToken ?? this.accessToken, + expiration: expiration ?? this.expiration, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (cookie.present) { + map['cookie'] = Variable(cookie.value); + } + if (accessToken.present) { + map['access_token'] = Variable(accessToken.value); + } + if (expiration.present) { + map['expiration'] = Variable(expiration.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('AuthenticationTableCompanion(') + ..write('id: $id, ') + ..write('cookie: $cookie, ') + ..write('accessToken: $accessToken, ') + ..write('expiration: $expiration') + ..write(')')) + .toString(); + } +} + +class BlacklistTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + BlacklistTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn name = GeneratedColumn( + 'name', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn elementType = GeneratedColumn( + 'element_type', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn elementId = GeneratedColumn( + 'element_id', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + @override + List get $columns => [id, name, elementType, elementId]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'blacklist_table'; + @override + Set get $primaryKey => {id}; + @override + BlacklistTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return BlacklistTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + name: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}name'])!, + elementType: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}element_type'])!, + elementId: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}element_id'])!, + ); + } + + @override + BlacklistTable createAlias(String alias) { + return BlacklistTable(attachedDatabase, alias); + } +} + +class BlacklistTableData extends DataClass + implements Insertable { + final int id; + final String name; + final String elementType; + final String elementId; + const BlacklistTableData( + {required this.id, + required this.name, + required this.elementType, + required this.elementId}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['name'] = Variable(name); + map['element_type'] = Variable(elementType); + map['element_id'] = Variable(elementId); + return map; + } + + BlacklistTableCompanion toCompanion(bool nullToAbsent) { + return BlacklistTableCompanion( + id: Value(id), + name: Value(name), + elementType: Value(elementType), + elementId: Value(elementId), + ); + } + + factory BlacklistTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return BlacklistTableData( + id: serializer.fromJson(json['id']), + name: serializer.fromJson(json['name']), + elementType: serializer.fromJson(json['elementType']), + elementId: serializer.fromJson(json['elementId']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'name': serializer.toJson(name), + 'elementType': serializer.toJson(elementType), + 'elementId': serializer.toJson(elementId), + }; + } + + BlacklistTableData copyWith( + {int? id, String? name, String? elementType, String? elementId}) => + BlacklistTableData( + id: id ?? this.id, + name: name ?? this.name, + elementType: elementType ?? this.elementType, + elementId: elementId ?? this.elementId, + ); + BlacklistTableData copyWithCompanion(BlacklistTableCompanion data) { + return BlacklistTableData( + id: data.id.present ? data.id.value : this.id, + name: data.name.present ? data.name.value : this.name, + elementType: + data.elementType.present ? data.elementType.value : this.elementType, + elementId: data.elementId.present ? data.elementId.value : this.elementId, + ); + } + + @override + String toString() { + return (StringBuffer('BlacklistTableData(') + ..write('id: $id, ') + ..write('name: $name, ') + ..write('elementType: $elementType, ') + ..write('elementId: $elementId') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, name, elementType, elementId); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is BlacklistTableData && + other.id == this.id && + other.name == this.name && + other.elementType == this.elementType && + other.elementId == this.elementId); +} + +class BlacklistTableCompanion extends UpdateCompanion { + final Value id; + final Value name; + final Value elementType; + final Value elementId; + const BlacklistTableCompanion({ + this.id = const Value.absent(), + this.name = const Value.absent(), + this.elementType = const Value.absent(), + this.elementId = const Value.absent(), + }); + BlacklistTableCompanion.insert({ + this.id = const Value.absent(), + required String name, + required String elementType, + required String elementId, + }) : name = Value(name), + elementType = Value(elementType), + elementId = Value(elementId); + static Insertable custom({ + Expression? id, + Expression? name, + Expression? elementType, + Expression? elementId, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (name != null) 'name': name, + if (elementType != null) 'element_type': elementType, + if (elementId != null) 'element_id': elementId, + }); + } + + BlacklistTableCompanion copyWith( + {Value? id, + Value? name, + Value? elementType, + Value? elementId}) { + return BlacklistTableCompanion( + id: id ?? this.id, + name: name ?? this.name, + elementType: elementType ?? this.elementType, + elementId: elementId ?? this.elementId, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (name.present) { + map['name'] = Variable(name.value); + } + if (elementType.present) { + map['element_type'] = Variable(elementType.value); + } + if (elementId.present) { + map['element_id'] = Variable(elementId.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('BlacklistTableCompanion(') + ..write('id: $id, ') + ..write('name: $name, ') + ..write('elementType: $elementType, ') + ..write('elementId: $elementId') + ..write(')')) + .toString(); + } +} + +class PreferencesTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + PreferencesTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn audioQuality = GeneratedColumn( + 'audio_quality', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(SourceQualities.high.name)); + late final GeneratedColumn albumColorSync = GeneratedColumn( + 'album_color_sync', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("album_color_sync" IN (0, 1))'), + defaultValue: const Constant(true)); + late final GeneratedColumn amoledDarkTheme = GeneratedColumn( + 'amoled_dark_theme', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("amoled_dark_theme" IN (0, 1))'), + defaultValue: const Constant(false)); + late final GeneratedColumn checkUpdate = GeneratedColumn( + 'check_update', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("check_update" IN (0, 1))'), + defaultValue: const Constant(true)); + late final GeneratedColumn normalizeAudio = GeneratedColumn( + 'normalize_audio', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("normalize_audio" IN (0, 1))'), + defaultValue: const Constant(false)); + late final GeneratedColumn showSystemTrayIcon = GeneratedColumn( + 'show_system_tray_icon', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("show_system_tray_icon" IN (0, 1))'), + defaultValue: const Constant(false)); + late final GeneratedColumn systemTitleBar = GeneratedColumn( + 'system_title_bar', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("system_title_bar" IN (0, 1))'), + defaultValue: const Constant(false)); + late final GeneratedColumn skipNonMusic = GeneratedColumn( + 'skip_non_music', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("skip_non_music" IN (0, 1))'), + defaultValue: const Constant(false)); + late final GeneratedColumn closeBehavior = GeneratedColumn( + 'close_behavior', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(CloseBehavior.close.name)); + late final GeneratedColumn accentColorScheme = + GeneratedColumn('accent_color_scheme', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: const Constant("Blue:0xFF2196F3")); + late final GeneratedColumn layoutMode = GeneratedColumn( + 'layout_mode', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(LayoutMode.adaptive.name)); + late final GeneratedColumn locale = GeneratedColumn( + 'locale', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: + const Constant('{"languageCode":"system","countryCode":"system"}')); + late final GeneratedColumn market = GeneratedColumn( + 'market', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(Market.US.name)); + late final GeneratedColumn searchMode = GeneratedColumn( + 'search_mode', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(SearchMode.youtube.name)); + late final GeneratedColumn downloadLocation = GeneratedColumn( + 'download_location', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: const Constant("")); + late final GeneratedColumn localLibraryLocation = + GeneratedColumn('local_library_location', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: const Constant("")); + late final GeneratedColumn pipedInstance = GeneratedColumn( + 'piped_instance', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: const Constant("https://pipedapi.kavin.rocks")); + late final GeneratedColumn themeMode = GeneratedColumn( + 'theme_mode', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(ThemeMode.system.name)); + late final GeneratedColumn audioSource = GeneratedColumn( + 'audio_source', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(AudioSource.youtube.name)); + late final GeneratedColumn streamMusicCodec = GeneratedColumn( + 'stream_music_codec', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(SourceCodecs.weba.name)); + late final GeneratedColumn downloadMusicCodec = + GeneratedColumn('download_music_codec', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(SourceCodecs.m4a.name)); + late final GeneratedColumn discordPresence = GeneratedColumn( + 'discord_presence', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("discord_presence" IN (0, 1))'), + defaultValue: const Constant(true)); + late final GeneratedColumn endlessPlayback = GeneratedColumn( + 'endless_playback', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("endless_playback" IN (0, 1))'), + defaultValue: const Constant(true)); + late final GeneratedColumn enableConnect = GeneratedColumn( + 'enable_connect', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("enable_connect" IN (0, 1))'), + defaultValue: const Constant(false)); + @override + List get $columns => [ + id, + audioQuality, + albumColorSync, + amoledDarkTheme, + checkUpdate, + normalizeAudio, + showSystemTrayIcon, + systemTitleBar, + skipNonMusic, + closeBehavior, + accentColorScheme, + layoutMode, + locale, + market, + searchMode, + downloadLocation, + localLibraryLocation, + pipedInstance, + themeMode, + audioSource, + streamMusicCodec, + downloadMusicCodec, + discordPresence, + endlessPlayback, + enableConnect + ]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'preferences_table'; + @override + Set get $primaryKey => {id}; + @override + PreferencesTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return PreferencesTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + audioQuality: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}audio_quality'])!, + albumColorSync: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}album_color_sync'])!, + amoledDarkTheme: attachedDatabase.typeMapping.read( + DriftSqlType.bool, data['${effectivePrefix}amoled_dark_theme'])!, + checkUpdate: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}check_update'])!, + normalizeAudio: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}normalize_audio'])!, + showSystemTrayIcon: attachedDatabase.typeMapping.read( + DriftSqlType.bool, data['${effectivePrefix}show_system_tray_icon'])!, + systemTitleBar: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}system_title_bar'])!, + skipNonMusic: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}skip_non_music'])!, + closeBehavior: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}close_behavior'])!, + accentColorScheme: attachedDatabase.typeMapping.read( + DriftSqlType.string, data['${effectivePrefix}accent_color_scheme'])!, + layoutMode: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}layout_mode'])!, + locale: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}locale'])!, + market: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}market'])!, + searchMode: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}search_mode'])!, + downloadLocation: attachedDatabase.typeMapping.read( + DriftSqlType.string, data['${effectivePrefix}download_location'])!, + localLibraryLocation: attachedDatabase.typeMapping.read( + DriftSqlType.string, + data['${effectivePrefix}local_library_location'])!, + pipedInstance: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}piped_instance'])!, + themeMode: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}theme_mode'])!, + audioSource: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}audio_source'])!, + streamMusicCodec: attachedDatabase.typeMapping.read( + DriftSqlType.string, data['${effectivePrefix}stream_music_codec'])!, + downloadMusicCodec: attachedDatabase.typeMapping.read( + DriftSqlType.string, data['${effectivePrefix}download_music_codec'])!, + discordPresence: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}discord_presence'])!, + endlessPlayback: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}endless_playback'])!, + enableConnect: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}enable_connect'])!, + ); + } + + @override + PreferencesTable createAlias(String alias) { + return PreferencesTable(attachedDatabase, alias); + } +} + +class PreferencesTableData extends DataClass + implements Insertable { + final int id; + final String audioQuality; + final bool albumColorSync; + final bool amoledDarkTheme; + final bool checkUpdate; + final bool normalizeAudio; + final bool showSystemTrayIcon; + final bool systemTitleBar; + final bool skipNonMusic; + final String closeBehavior; + final String accentColorScheme; + final String layoutMode; + final String locale; + final String market; + final String searchMode; + final String downloadLocation; + final String localLibraryLocation; + final String pipedInstance; + final String themeMode; + final String audioSource; + final String streamMusicCodec; + final String downloadMusicCodec; + final bool discordPresence; + final bool endlessPlayback; + final bool enableConnect; + const PreferencesTableData( + {required this.id, + required this.audioQuality, + required this.albumColorSync, + required this.amoledDarkTheme, + required this.checkUpdate, + required this.normalizeAudio, + required this.showSystemTrayIcon, + required this.systemTitleBar, + required this.skipNonMusic, + required this.closeBehavior, + required this.accentColorScheme, + required this.layoutMode, + required this.locale, + required this.market, + required this.searchMode, + required this.downloadLocation, + required this.localLibraryLocation, + required this.pipedInstance, + required this.themeMode, + required this.audioSource, + required this.streamMusicCodec, + required this.downloadMusicCodec, + required this.discordPresence, + required this.endlessPlayback, + required this.enableConnect}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['audio_quality'] = Variable(audioQuality); + map['album_color_sync'] = Variable(albumColorSync); + map['amoled_dark_theme'] = Variable(amoledDarkTheme); + map['check_update'] = Variable(checkUpdate); + map['normalize_audio'] = Variable(normalizeAudio); + map['show_system_tray_icon'] = Variable(showSystemTrayIcon); + map['system_title_bar'] = Variable(systemTitleBar); + map['skip_non_music'] = Variable(skipNonMusic); + map['close_behavior'] = Variable(closeBehavior); + map['accent_color_scheme'] = Variable(accentColorScheme); + map['layout_mode'] = Variable(layoutMode); + map['locale'] = Variable(locale); + map['market'] = Variable(market); + map['search_mode'] = Variable(searchMode); + map['download_location'] = Variable(downloadLocation); + map['local_library_location'] = Variable(localLibraryLocation); + map['piped_instance'] = Variable(pipedInstance); + map['theme_mode'] = Variable(themeMode); + map['audio_source'] = Variable(audioSource); + map['stream_music_codec'] = Variable(streamMusicCodec); + map['download_music_codec'] = Variable(downloadMusicCodec); + map['discord_presence'] = Variable(discordPresence); + map['endless_playback'] = Variable(endlessPlayback); + map['enable_connect'] = Variable(enableConnect); + return map; + } + + PreferencesTableCompanion toCompanion(bool nullToAbsent) { + return PreferencesTableCompanion( + id: Value(id), + audioQuality: Value(audioQuality), + albumColorSync: Value(albumColorSync), + amoledDarkTheme: Value(amoledDarkTheme), + checkUpdate: Value(checkUpdate), + normalizeAudio: Value(normalizeAudio), + showSystemTrayIcon: Value(showSystemTrayIcon), + systemTitleBar: Value(systemTitleBar), + skipNonMusic: Value(skipNonMusic), + closeBehavior: Value(closeBehavior), + accentColorScheme: Value(accentColorScheme), + layoutMode: Value(layoutMode), + locale: Value(locale), + market: Value(market), + searchMode: Value(searchMode), + downloadLocation: Value(downloadLocation), + localLibraryLocation: Value(localLibraryLocation), + pipedInstance: Value(pipedInstance), + themeMode: Value(themeMode), + audioSource: Value(audioSource), + streamMusicCodec: Value(streamMusicCodec), + downloadMusicCodec: Value(downloadMusicCodec), + discordPresence: Value(discordPresence), + endlessPlayback: Value(endlessPlayback), + enableConnect: Value(enableConnect), + ); + } + + factory PreferencesTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return PreferencesTableData( + id: serializer.fromJson(json['id']), + audioQuality: serializer.fromJson(json['audioQuality']), + albumColorSync: serializer.fromJson(json['albumColorSync']), + amoledDarkTheme: serializer.fromJson(json['amoledDarkTheme']), + checkUpdate: serializer.fromJson(json['checkUpdate']), + normalizeAudio: serializer.fromJson(json['normalizeAudio']), + showSystemTrayIcon: serializer.fromJson(json['showSystemTrayIcon']), + systemTitleBar: serializer.fromJson(json['systemTitleBar']), + skipNonMusic: serializer.fromJson(json['skipNonMusic']), + closeBehavior: serializer.fromJson(json['closeBehavior']), + accentColorScheme: serializer.fromJson(json['accentColorScheme']), + layoutMode: serializer.fromJson(json['layoutMode']), + locale: serializer.fromJson(json['locale']), + market: serializer.fromJson(json['market']), + searchMode: serializer.fromJson(json['searchMode']), + downloadLocation: serializer.fromJson(json['downloadLocation']), + localLibraryLocation: + serializer.fromJson(json['localLibraryLocation']), + pipedInstance: serializer.fromJson(json['pipedInstance']), + themeMode: serializer.fromJson(json['themeMode']), + audioSource: serializer.fromJson(json['audioSource']), + streamMusicCodec: serializer.fromJson(json['streamMusicCodec']), + downloadMusicCodec: + serializer.fromJson(json['downloadMusicCodec']), + discordPresence: serializer.fromJson(json['discordPresence']), + endlessPlayback: serializer.fromJson(json['endlessPlayback']), + enableConnect: serializer.fromJson(json['enableConnect']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'audioQuality': serializer.toJson(audioQuality), + 'albumColorSync': serializer.toJson(albumColorSync), + 'amoledDarkTheme': serializer.toJson(amoledDarkTheme), + 'checkUpdate': serializer.toJson(checkUpdate), + 'normalizeAudio': serializer.toJson(normalizeAudio), + 'showSystemTrayIcon': serializer.toJson(showSystemTrayIcon), + 'systemTitleBar': serializer.toJson(systemTitleBar), + 'skipNonMusic': serializer.toJson(skipNonMusic), + 'closeBehavior': serializer.toJson(closeBehavior), + 'accentColorScheme': serializer.toJson(accentColorScheme), + 'layoutMode': serializer.toJson(layoutMode), + 'locale': serializer.toJson(locale), + 'market': serializer.toJson(market), + 'searchMode': serializer.toJson(searchMode), + 'downloadLocation': serializer.toJson(downloadLocation), + 'localLibraryLocation': serializer.toJson(localLibraryLocation), + 'pipedInstance': serializer.toJson(pipedInstance), + 'themeMode': serializer.toJson(themeMode), + 'audioSource': serializer.toJson(audioSource), + 'streamMusicCodec': serializer.toJson(streamMusicCodec), + 'downloadMusicCodec': serializer.toJson(downloadMusicCodec), + 'discordPresence': serializer.toJson(discordPresence), + 'endlessPlayback': serializer.toJson(endlessPlayback), + 'enableConnect': serializer.toJson(enableConnect), + }; + } + + PreferencesTableData copyWith( + {int? id, + String? audioQuality, + bool? albumColorSync, + bool? amoledDarkTheme, + bool? checkUpdate, + bool? normalizeAudio, + bool? showSystemTrayIcon, + bool? systemTitleBar, + bool? skipNonMusic, + String? closeBehavior, + String? accentColorScheme, + String? layoutMode, + String? locale, + String? market, + String? searchMode, + String? downloadLocation, + String? localLibraryLocation, + String? pipedInstance, + String? themeMode, + String? audioSource, + String? streamMusicCodec, + String? downloadMusicCodec, + bool? discordPresence, + bool? endlessPlayback, + bool? enableConnect}) => + PreferencesTableData( + id: id ?? this.id, + audioQuality: audioQuality ?? this.audioQuality, + albumColorSync: albumColorSync ?? this.albumColorSync, + amoledDarkTheme: amoledDarkTheme ?? this.amoledDarkTheme, + checkUpdate: checkUpdate ?? this.checkUpdate, + normalizeAudio: normalizeAudio ?? this.normalizeAudio, + showSystemTrayIcon: showSystemTrayIcon ?? this.showSystemTrayIcon, + systemTitleBar: systemTitleBar ?? this.systemTitleBar, + skipNonMusic: skipNonMusic ?? this.skipNonMusic, + closeBehavior: closeBehavior ?? this.closeBehavior, + accentColorScheme: accentColorScheme ?? this.accentColorScheme, + layoutMode: layoutMode ?? this.layoutMode, + locale: locale ?? this.locale, + market: market ?? this.market, + searchMode: searchMode ?? this.searchMode, + downloadLocation: downloadLocation ?? this.downloadLocation, + localLibraryLocation: localLibraryLocation ?? this.localLibraryLocation, + pipedInstance: pipedInstance ?? this.pipedInstance, + themeMode: themeMode ?? this.themeMode, + audioSource: audioSource ?? this.audioSource, + streamMusicCodec: streamMusicCodec ?? this.streamMusicCodec, + downloadMusicCodec: downloadMusicCodec ?? this.downloadMusicCodec, + discordPresence: discordPresence ?? this.discordPresence, + endlessPlayback: endlessPlayback ?? this.endlessPlayback, + enableConnect: enableConnect ?? this.enableConnect, + ); + PreferencesTableData copyWithCompanion(PreferencesTableCompanion data) { + return PreferencesTableData( + id: data.id.present ? data.id.value : this.id, + audioQuality: data.audioQuality.present + ? data.audioQuality.value + : this.audioQuality, + albumColorSync: data.albumColorSync.present + ? data.albumColorSync.value + : this.albumColorSync, + amoledDarkTheme: data.amoledDarkTheme.present + ? data.amoledDarkTheme.value + : this.amoledDarkTheme, + checkUpdate: + data.checkUpdate.present ? data.checkUpdate.value : this.checkUpdate, + normalizeAudio: data.normalizeAudio.present + ? data.normalizeAudio.value + : this.normalizeAudio, + showSystemTrayIcon: data.showSystemTrayIcon.present + ? data.showSystemTrayIcon.value + : this.showSystemTrayIcon, + systemTitleBar: data.systemTitleBar.present + ? data.systemTitleBar.value + : this.systemTitleBar, + skipNonMusic: data.skipNonMusic.present + ? data.skipNonMusic.value + : this.skipNonMusic, + closeBehavior: data.closeBehavior.present + ? data.closeBehavior.value + : this.closeBehavior, + accentColorScheme: data.accentColorScheme.present + ? data.accentColorScheme.value + : this.accentColorScheme, + layoutMode: + data.layoutMode.present ? data.layoutMode.value : this.layoutMode, + locale: data.locale.present ? data.locale.value : this.locale, + market: data.market.present ? data.market.value : this.market, + searchMode: + data.searchMode.present ? data.searchMode.value : this.searchMode, + downloadLocation: data.downloadLocation.present + ? data.downloadLocation.value + : this.downloadLocation, + localLibraryLocation: data.localLibraryLocation.present + ? data.localLibraryLocation.value + : this.localLibraryLocation, + pipedInstance: data.pipedInstance.present + ? data.pipedInstance.value + : this.pipedInstance, + themeMode: data.themeMode.present ? data.themeMode.value : this.themeMode, + audioSource: + data.audioSource.present ? data.audioSource.value : this.audioSource, + streamMusicCodec: data.streamMusicCodec.present + ? data.streamMusicCodec.value + : this.streamMusicCodec, + downloadMusicCodec: data.downloadMusicCodec.present + ? data.downloadMusicCodec.value + : this.downloadMusicCodec, + discordPresence: data.discordPresence.present + ? data.discordPresence.value + : this.discordPresence, + endlessPlayback: data.endlessPlayback.present + ? data.endlessPlayback.value + : this.endlessPlayback, + enableConnect: data.enableConnect.present + ? data.enableConnect.value + : this.enableConnect, + ); + } + + @override + String toString() { + return (StringBuffer('PreferencesTableData(') + ..write('id: $id, ') + ..write('audioQuality: $audioQuality, ') + ..write('albumColorSync: $albumColorSync, ') + ..write('amoledDarkTheme: $amoledDarkTheme, ') + ..write('checkUpdate: $checkUpdate, ') + ..write('normalizeAudio: $normalizeAudio, ') + ..write('showSystemTrayIcon: $showSystemTrayIcon, ') + ..write('systemTitleBar: $systemTitleBar, ') + ..write('skipNonMusic: $skipNonMusic, ') + ..write('closeBehavior: $closeBehavior, ') + ..write('accentColorScheme: $accentColorScheme, ') + ..write('layoutMode: $layoutMode, ') + ..write('locale: $locale, ') + ..write('market: $market, ') + ..write('searchMode: $searchMode, ') + ..write('downloadLocation: $downloadLocation, ') + ..write('localLibraryLocation: $localLibraryLocation, ') + ..write('pipedInstance: $pipedInstance, ') + ..write('themeMode: $themeMode, ') + ..write('audioSource: $audioSource, ') + ..write('streamMusicCodec: $streamMusicCodec, ') + ..write('downloadMusicCodec: $downloadMusicCodec, ') + ..write('discordPresence: $discordPresence, ') + ..write('endlessPlayback: $endlessPlayback, ') + ..write('enableConnect: $enableConnect') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hashAll([ + id, + audioQuality, + albumColorSync, + amoledDarkTheme, + checkUpdate, + normalizeAudio, + showSystemTrayIcon, + systemTitleBar, + skipNonMusic, + closeBehavior, + accentColorScheme, + layoutMode, + locale, + market, + searchMode, + downloadLocation, + localLibraryLocation, + pipedInstance, + themeMode, + audioSource, + streamMusicCodec, + downloadMusicCodec, + discordPresence, + endlessPlayback, + enableConnect + ]); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is PreferencesTableData && + other.id == this.id && + other.audioQuality == this.audioQuality && + other.albumColorSync == this.albumColorSync && + other.amoledDarkTheme == this.amoledDarkTheme && + other.checkUpdate == this.checkUpdate && + other.normalizeAudio == this.normalizeAudio && + other.showSystemTrayIcon == this.showSystemTrayIcon && + other.systemTitleBar == this.systemTitleBar && + other.skipNonMusic == this.skipNonMusic && + other.closeBehavior == this.closeBehavior && + other.accentColorScheme == this.accentColorScheme && + other.layoutMode == this.layoutMode && + other.locale == this.locale && + other.market == this.market && + other.searchMode == this.searchMode && + other.downloadLocation == this.downloadLocation && + other.localLibraryLocation == this.localLibraryLocation && + other.pipedInstance == this.pipedInstance && + other.themeMode == this.themeMode && + other.audioSource == this.audioSource && + other.streamMusicCodec == this.streamMusicCodec && + other.downloadMusicCodec == this.downloadMusicCodec && + other.discordPresence == this.discordPresence && + other.endlessPlayback == this.endlessPlayback && + other.enableConnect == this.enableConnect); +} + +class PreferencesTableCompanion extends UpdateCompanion { + final Value id; + final Value audioQuality; + final Value albumColorSync; + final Value amoledDarkTheme; + final Value checkUpdate; + final Value normalizeAudio; + final Value showSystemTrayIcon; + final Value systemTitleBar; + final Value skipNonMusic; + final Value closeBehavior; + final Value accentColorScheme; + final Value layoutMode; + final Value locale; + final Value market; + final Value searchMode; + final Value downloadLocation; + final Value localLibraryLocation; + final Value pipedInstance; + final Value themeMode; + final Value audioSource; + final Value streamMusicCodec; + final Value downloadMusicCodec; + final Value discordPresence; + final Value endlessPlayback; + final Value enableConnect; + const PreferencesTableCompanion({ + this.id = const Value.absent(), + this.audioQuality = const Value.absent(), + this.albumColorSync = const Value.absent(), + this.amoledDarkTheme = const Value.absent(), + this.checkUpdate = const Value.absent(), + this.normalizeAudio = const Value.absent(), + this.showSystemTrayIcon = const Value.absent(), + this.systemTitleBar = const Value.absent(), + this.skipNonMusic = const Value.absent(), + this.closeBehavior = const Value.absent(), + this.accentColorScheme = const Value.absent(), + this.layoutMode = const Value.absent(), + this.locale = const Value.absent(), + this.market = const Value.absent(), + this.searchMode = const Value.absent(), + this.downloadLocation = const Value.absent(), + this.localLibraryLocation = const Value.absent(), + this.pipedInstance = const Value.absent(), + this.themeMode = const Value.absent(), + this.audioSource = const Value.absent(), + this.streamMusicCodec = const Value.absent(), + this.downloadMusicCodec = const Value.absent(), + this.discordPresence = const Value.absent(), + this.endlessPlayback = const Value.absent(), + this.enableConnect = const Value.absent(), + }); + PreferencesTableCompanion.insert({ + this.id = const Value.absent(), + this.audioQuality = const Value.absent(), + this.albumColorSync = const Value.absent(), + this.amoledDarkTheme = const Value.absent(), + this.checkUpdate = const Value.absent(), + this.normalizeAudio = const Value.absent(), + this.showSystemTrayIcon = const Value.absent(), + this.systemTitleBar = const Value.absent(), + this.skipNonMusic = const Value.absent(), + this.closeBehavior = const Value.absent(), + this.accentColorScheme = const Value.absent(), + this.layoutMode = const Value.absent(), + this.locale = const Value.absent(), + this.market = const Value.absent(), + this.searchMode = const Value.absent(), + this.downloadLocation = const Value.absent(), + this.localLibraryLocation = const Value.absent(), + this.pipedInstance = const Value.absent(), + this.themeMode = const Value.absent(), + this.audioSource = const Value.absent(), + this.streamMusicCodec = const Value.absent(), + this.downloadMusicCodec = const Value.absent(), + this.discordPresence = const Value.absent(), + this.endlessPlayback = const Value.absent(), + this.enableConnect = const Value.absent(), + }); + static Insertable custom({ + Expression? id, + Expression? audioQuality, + Expression? albumColorSync, + Expression? amoledDarkTheme, + Expression? checkUpdate, + Expression? normalizeAudio, + Expression? showSystemTrayIcon, + Expression? systemTitleBar, + Expression? skipNonMusic, + Expression? closeBehavior, + Expression? accentColorScheme, + Expression? layoutMode, + Expression? locale, + Expression? market, + Expression? searchMode, + Expression? downloadLocation, + Expression? localLibraryLocation, + Expression? pipedInstance, + Expression? themeMode, + Expression? audioSource, + Expression? streamMusicCodec, + Expression? downloadMusicCodec, + Expression? discordPresence, + Expression? endlessPlayback, + Expression? enableConnect, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (audioQuality != null) 'audio_quality': audioQuality, + if (albumColorSync != null) 'album_color_sync': albumColorSync, + if (amoledDarkTheme != null) 'amoled_dark_theme': amoledDarkTheme, + if (checkUpdate != null) 'check_update': checkUpdate, + if (normalizeAudio != null) 'normalize_audio': normalizeAudio, + if (showSystemTrayIcon != null) + 'show_system_tray_icon': showSystemTrayIcon, + if (systemTitleBar != null) 'system_title_bar': systemTitleBar, + if (skipNonMusic != null) 'skip_non_music': skipNonMusic, + if (closeBehavior != null) 'close_behavior': closeBehavior, + if (accentColorScheme != null) 'accent_color_scheme': accentColorScheme, + if (layoutMode != null) 'layout_mode': layoutMode, + if (locale != null) 'locale': locale, + if (market != null) 'market': market, + if (searchMode != null) 'search_mode': searchMode, + if (downloadLocation != null) 'download_location': downloadLocation, + if (localLibraryLocation != null) + 'local_library_location': localLibraryLocation, + if (pipedInstance != null) 'piped_instance': pipedInstance, + if (themeMode != null) 'theme_mode': themeMode, + if (audioSource != null) 'audio_source': audioSource, + if (streamMusicCodec != null) 'stream_music_codec': streamMusicCodec, + if (downloadMusicCodec != null) + 'download_music_codec': downloadMusicCodec, + if (discordPresence != null) 'discord_presence': discordPresence, + if (endlessPlayback != null) 'endless_playback': endlessPlayback, + if (enableConnect != null) 'enable_connect': enableConnect, + }); + } + + PreferencesTableCompanion copyWith( + {Value? id, + Value? audioQuality, + Value? albumColorSync, + Value? amoledDarkTheme, + Value? checkUpdate, + Value? normalizeAudio, + Value? showSystemTrayIcon, + Value? systemTitleBar, + Value? skipNonMusic, + Value? closeBehavior, + Value? accentColorScheme, + Value? layoutMode, + Value? locale, + Value? market, + Value? searchMode, + Value? downloadLocation, + Value? localLibraryLocation, + Value? pipedInstance, + Value? themeMode, + Value? audioSource, + Value? streamMusicCodec, + Value? downloadMusicCodec, + Value? discordPresence, + Value? endlessPlayback, + Value? enableConnect}) { + return PreferencesTableCompanion( + id: id ?? this.id, + audioQuality: audioQuality ?? this.audioQuality, + albumColorSync: albumColorSync ?? this.albumColorSync, + amoledDarkTheme: amoledDarkTheme ?? this.amoledDarkTheme, + checkUpdate: checkUpdate ?? this.checkUpdate, + normalizeAudio: normalizeAudio ?? this.normalizeAudio, + showSystemTrayIcon: showSystemTrayIcon ?? this.showSystemTrayIcon, + systemTitleBar: systemTitleBar ?? this.systemTitleBar, + skipNonMusic: skipNonMusic ?? this.skipNonMusic, + closeBehavior: closeBehavior ?? this.closeBehavior, + accentColorScheme: accentColorScheme ?? this.accentColorScheme, + layoutMode: layoutMode ?? this.layoutMode, + locale: locale ?? this.locale, + market: market ?? this.market, + searchMode: searchMode ?? this.searchMode, + downloadLocation: downloadLocation ?? this.downloadLocation, + localLibraryLocation: localLibraryLocation ?? this.localLibraryLocation, + pipedInstance: pipedInstance ?? this.pipedInstance, + themeMode: themeMode ?? this.themeMode, + audioSource: audioSource ?? this.audioSource, + streamMusicCodec: streamMusicCodec ?? this.streamMusicCodec, + downloadMusicCodec: downloadMusicCodec ?? this.downloadMusicCodec, + discordPresence: discordPresence ?? this.discordPresence, + endlessPlayback: endlessPlayback ?? this.endlessPlayback, + enableConnect: enableConnect ?? this.enableConnect, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (audioQuality.present) { + map['audio_quality'] = Variable(audioQuality.value); + } + if (albumColorSync.present) { + map['album_color_sync'] = Variable(albumColorSync.value); + } + if (amoledDarkTheme.present) { + map['amoled_dark_theme'] = Variable(amoledDarkTheme.value); + } + if (checkUpdate.present) { + map['check_update'] = Variable(checkUpdate.value); + } + if (normalizeAudio.present) { + map['normalize_audio'] = Variable(normalizeAudio.value); + } + if (showSystemTrayIcon.present) { + map['show_system_tray_icon'] = Variable(showSystemTrayIcon.value); + } + if (systemTitleBar.present) { + map['system_title_bar'] = Variable(systemTitleBar.value); + } + if (skipNonMusic.present) { + map['skip_non_music'] = Variable(skipNonMusic.value); + } + if (closeBehavior.present) { + map['close_behavior'] = Variable(closeBehavior.value); + } + if (accentColorScheme.present) { + map['accent_color_scheme'] = Variable(accentColorScheme.value); + } + if (layoutMode.present) { + map['layout_mode'] = Variable(layoutMode.value); + } + if (locale.present) { + map['locale'] = Variable(locale.value); + } + if (market.present) { + map['market'] = Variable(market.value); + } + if (searchMode.present) { + map['search_mode'] = Variable(searchMode.value); + } + if (downloadLocation.present) { + map['download_location'] = Variable(downloadLocation.value); + } + if (localLibraryLocation.present) { + map['local_library_location'] = + Variable(localLibraryLocation.value); + } + if (pipedInstance.present) { + map['piped_instance'] = Variable(pipedInstance.value); + } + if (themeMode.present) { + map['theme_mode'] = Variable(themeMode.value); + } + if (audioSource.present) { + map['audio_source'] = Variable(audioSource.value); + } + if (streamMusicCodec.present) { + map['stream_music_codec'] = Variable(streamMusicCodec.value); + } + if (downloadMusicCodec.present) { + map['download_music_codec'] = Variable(downloadMusicCodec.value); + } + if (discordPresence.present) { + map['discord_presence'] = Variable(discordPresence.value); + } + if (endlessPlayback.present) { + map['endless_playback'] = Variable(endlessPlayback.value); + } + if (enableConnect.present) { + map['enable_connect'] = Variable(enableConnect.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('PreferencesTableCompanion(') + ..write('id: $id, ') + ..write('audioQuality: $audioQuality, ') + ..write('albumColorSync: $albumColorSync, ') + ..write('amoledDarkTheme: $amoledDarkTheme, ') + ..write('checkUpdate: $checkUpdate, ') + ..write('normalizeAudio: $normalizeAudio, ') + ..write('showSystemTrayIcon: $showSystemTrayIcon, ') + ..write('systemTitleBar: $systemTitleBar, ') + ..write('skipNonMusic: $skipNonMusic, ') + ..write('closeBehavior: $closeBehavior, ') + ..write('accentColorScheme: $accentColorScheme, ') + ..write('layoutMode: $layoutMode, ') + ..write('locale: $locale, ') + ..write('market: $market, ') + ..write('searchMode: $searchMode, ') + ..write('downloadLocation: $downloadLocation, ') + ..write('localLibraryLocation: $localLibraryLocation, ') + ..write('pipedInstance: $pipedInstance, ') + ..write('themeMode: $themeMode, ') + ..write('audioSource: $audioSource, ') + ..write('streamMusicCodec: $streamMusicCodec, ') + ..write('downloadMusicCodec: $downloadMusicCodec, ') + ..write('discordPresence: $discordPresence, ') + ..write('endlessPlayback: $endlessPlayback, ') + ..write('enableConnect: $enableConnect') + ..write(')')) + .toString(); + } +} + +class ScrobblerTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + ScrobblerTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn createdAt = GeneratedColumn( + 'created_at', aliasedName, false, + type: DriftSqlType.dateTime, + requiredDuringInsert: false, + defaultValue: currentDateAndTime); + late final GeneratedColumn username = GeneratedColumn( + 'username', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn passwordHash = GeneratedColumn( + 'password_hash', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + @override + List get $columns => [id, createdAt, username, passwordHash]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'scrobbler_table'; + @override + Set get $primaryKey => {id}; + @override + ScrobblerTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return ScrobblerTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + createdAt: attachedDatabase.typeMapping + .read(DriftSqlType.dateTime, data['${effectivePrefix}created_at'])!, + username: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}username'])!, + passwordHash: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}password_hash'])!, + ); + } + + @override + ScrobblerTable createAlias(String alias) { + return ScrobblerTable(attachedDatabase, alias); + } +} + +class ScrobblerTableData extends DataClass + implements Insertable { + final int id; + final DateTime createdAt; + final String username; + final String passwordHash; + const ScrobblerTableData( + {required this.id, + required this.createdAt, + required this.username, + required this.passwordHash}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['created_at'] = Variable(createdAt); + map['username'] = Variable(username); + map['password_hash'] = Variable(passwordHash); + return map; + } + + ScrobblerTableCompanion toCompanion(bool nullToAbsent) { + return ScrobblerTableCompanion( + id: Value(id), + createdAt: Value(createdAt), + username: Value(username), + passwordHash: Value(passwordHash), + ); + } + + factory ScrobblerTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return ScrobblerTableData( + id: serializer.fromJson(json['id']), + createdAt: serializer.fromJson(json['createdAt']), + username: serializer.fromJson(json['username']), + passwordHash: serializer.fromJson(json['passwordHash']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'createdAt': serializer.toJson(createdAt), + 'username': serializer.toJson(username), + 'passwordHash': serializer.toJson(passwordHash), + }; + } + + ScrobblerTableData copyWith( + {int? id, + DateTime? createdAt, + String? username, + String? passwordHash}) => + ScrobblerTableData( + id: id ?? this.id, + createdAt: createdAt ?? this.createdAt, + username: username ?? this.username, + passwordHash: passwordHash ?? this.passwordHash, + ); + ScrobblerTableData copyWithCompanion(ScrobblerTableCompanion data) { + return ScrobblerTableData( + id: data.id.present ? data.id.value : this.id, + createdAt: data.createdAt.present ? data.createdAt.value : this.createdAt, + username: data.username.present ? data.username.value : this.username, + passwordHash: data.passwordHash.present + ? data.passwordHash.value + : this.passwordHash, + ); + } + + @override + String toString() { + return (StringBuffer('ScrobblerTableData(') + ..write('id: $id, ') + ..write('createdAt: $createdAt, ') + ..write('username: $username, ') + ..write('passwordHash: $passwordHash') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, createdAt, username, passwordHash); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is ScrobblerTableData && + other.id == this.id && + other.createdAt == this.createdAt && + other.username == this.username && + other.passwordHash == this.passwordHash); +} + +class ScrobblerTableCompanion extends UpdateCompanion { + final Value id; + final Value createdAt; + final Value username; + final Value passwordHash; + const ScrobblerTableCompanion({ + this.id = const Value.absent(), + this.createdAt = const Value.absent(), + this.username = const Value.absent(), + this.passwordHash = const Value.absent(), + }); + ScrobblerTableCompanion.insert({ + this.id = const Value.absent(), + this.createdAt = const Value.absent(), + required String username, + required String passwordHash, + }) : username = Value(username), + passwordHash = Value(passwordHash); + static Insertable custom({ + Expression? id, + Expression? createdAt, + Expression? username, + Expression? passwordHash, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (createdAt != null) 'created_at': createdAt, + if (username != null) 'username': username, + if (passwordHash != null) 'password_hash': passwordHash, + }); + } + + ScrobblerTableCompanion copyWith( + {Value? id, + Value? createdAt, + Value? username, + Value? passwordHash}) { + return ScrobblerTableCompanion( + id: id ?? this.id, + createdAt: createdAt ?? this.createdAt, + username: username ?? this.username, + passwordHash: passwordHash ?? this.passwordHash, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (createdAt.present) { + map['created_at'] = Variable(createdAt.value); + } + if (username.present) { + map['username'] = Variable(username.value); + } + if (passwordHash.present) { + map['password_hash'] = Variable(passwordHash.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('ScrobblerTableCompanion(') + ..write('id: $id, ') + ..write('createdAt: $createdAt, ') + ..write('username: $username, ') + ..write('passwordHash: $passwordHash') + ..write(')')) + .toString(); + } +} + +class SkipSegmentTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + SkipSegmentTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn start = GeneratedColumn( + 'start', aliasedName, false, + type: DriftSqlType.int, requiredDuringInsert: true); + late final GeneratedColumn end = GeneratedColumn( + 'end', aliasedName, false, + type: DriftSqlType.int, requiredDuringInsert: true); + late final GeneratedColumn trackId = GeneratedColumn( + 'track_id', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn createdAt = GeneratedColumn( + 'created_at', aliasedName, false, + type: DriftSqlType.dateTime, + requiredDuringInsert: false, + defaultValue: currentDateAndTime); + @override + List get $columns => [id, start, end, trackId, createdAt]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'skip_segment_table'; + @override + Set get $primaryKey => {id}; + @override + SkipSegmentTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return SkipSegmentTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + start: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}start'])!, + end: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}end'])!, + trackId: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}track_id'])!, + createdAt: attachedDatabase.typeMapping + .read(DriftSqlType.dateTime, data['${effectivePrefix}created_at'])!, + ); + } + + @override + SkipSegmentTable createAlias(String alias) { + return SkipSegmentTable(attachedDatabase, alias); + } +} + +class SkipSegmentTableData extends DataClass + implements Insertable { + final int id; + final int start; + final int end; + final String trackId; + final DateTime createdAt; + const SkipSegmentTableData( + {required this.id, + required this.start, + required this.end, + required this.trackId, + required this.createdAt}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['start'] = Variable(start); + map['end'] = Variable(end); + map['track_id'] = Variable(trackId); + map['created_at'] = Variable(createdAt); + return map; + } + + SkipSegmentTableCompanion toCompanion(bool nullToAbsent) { + return SkipSegmentTableCompanion( + id: Value(id), + start: Value(start), + end: Value(end), + trackId: Value(trackId), + createdAt: Value(createdAt), + ); + } + + factory SkipSegmentTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return SkipSegmentTableData( + id: serializer.fromJson(json['id']), + start: serializer.fromJson(json['start']), + end: serializer.fromJson(json['end']), + trackId: serializer.fromJson(json['trackId']), + createdAt: serializer.fromJson(json['createdAt']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'start': serializer.toJson(start), + 'end': serializer.toJson(end), + 'trackId': serializer.toJson(trackId), + 'createdAt': serializer.toJson(createdAt), + }; + } + + SkipSegmentTableData copyWith( + {int? id, + int? start, + int? end, + String? trackId, + DateTime? createdAt}) => + SkipSegmentTableData( + id: id ?? this.id, + start: start ?? this.start, + end: end ?? this.end, + trackId: trackId ?? this.trackId, + createdAt: createdAt ?? this.createdAt, + ); + SkipSegmentTableData copyWithCompanion(SkipSegmentTableCompanion data) { + return SkipSegmentTableData( + id: data.id.present ? data.id.value : this.id, + start: data.start.present ? data.start.value : this.start, + end: data.end.present ? data.end.value : this.end, + trackId: data.trackId.present ? data.trackId.value : this.trackId, + createdAt: data.createdAt.present ? data.createdAt.value : this.createdAt, + ); + } + + @override + String toString() { + return (StringBuffer('SkipSegmentTableData(') + ..write('id: $id, ') + ..write('start: $start, ') + ..write('end: $end, ') + ..write('trackId: $trackId, ') + ..write('createdAt: $createdAt') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, start, end, trackId, createdAt); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is SkipSegmentTableData && + other.id == this.id && + other.start == this.start && + other.end == this.end && + other.trackId == this.trackId && + other.createdAt == this.createdAt); +} + +class SkipSegmentTableCompanion extends UpdateCompanion { + final Value id; + final Value start; + final Value end; + final Value trackId; + final Value createdAt; + const SkipSegmentTableCompanion({ + this.id = const Value.absent(), + this.start = const Value.absent(), + this.end = const Value.absent(), + this.trackId = const Value.absent(), + this.createdAt = const Value.absent(), + }); + SkipSegmentTableCompanion.insert({ + this.id = const Value.absent(), + required int start, + required int end, + required String trackId, + this.createdAt = const Value.absent(), + }) : start = Value(start), + end = Value(end), + trackId = Value(trackId); + static Insertable custom({ + Expression? id, + Expression? start, + Expression? end, + Expression? trackId, + Expression? createdAt, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (start != null) 'start': start, + if (end != null) 'end': end, + if (trackId != null) 'track_id': trackId, + if (createdAt != null) 'created_at': createdAt, + }); + } + + SkipSegmentTableCompanion copyWith( + {Value? id, + Value? start, + Value? end, + Value? trackId, + Value? createdAt}) { + return SkipSegmentTableCompanion( + id: id ?? this.id, + start: start ?? this.start, + end: end ?? this.end, + trackId: trackId ?? this.trackId, + createdAt: createdAt ?? this.createdAt, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (start.present) { + map['start'] = Variable(start.value); + } + if (end.present) { + map['end'] = Variable(end.value); + } + if (trackId.present) { + map['track_id'] = Variable(trackId.value); + } + if (createdAt.present) { + map['created_at'] = Variable(createdAt.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('SkipSegmentTableCompanion(') + ..write('id: $id, ') + ..write('start: $start, ') + ..write('end: $end, ') + ..write('trackId: $trackId, ') + ..write('createdAt: $createdAt') + ..write(')')) + .toString(); + } +} + +class SourceMatchTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + SourceMatchTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn trackId = GeneratedColumn( + 'track_id', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn sourceId = GeneratedColumn( + 'source_id', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn sourceType = GeneratedColumn( + 'source_type', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(SourceType.youtube.name)); + late final GeneratedColumn createdAt = GeneratedColumn( + 'created_at', aliasedName, false, + type: DriftSqlType.dateTime, + requiredDuringInsert: false, + defaultValue: currentDateAndTime); + @override + List get $columns => + [id, trackId, sourceId, sourceType, createdAt]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'source_match_table'; + @override + Set get $primaryKey => {id}; + @override + SourceMatchTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return SourceMatchTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + trackId: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}track_id'])!, + sourceId: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}source_id'])!, + sourceType: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}source_type'])!, + createdAt: attachedDatabase.typeMapping + .read(DriftSqlType.dateTime, data['${effectivePrefix}created_at'])!, + ); + } + + @override + SourceMatchTable createAlias(String alias) { + return SourceMatchTable(attachedDatabase, alias); + } +} + +class SourceMatchTableData extends DataClass + implements Insertable { + final int id; + final String trackId; + final String sourceId; + final String sourceType; + final DateTime createdAt; + const SourceMatchTableData( + {required this.id, + required this.trackId, + required this.sourceId, + required this.sourceType, + required this.createdAt}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['track_id'] = Variable(trackId); + map['source_id'] = Variable(sourceId); + map['source_type'] = Variable(sourceType); + map['created_at'] = Variable(createdAt); + return map; + } + + SourceMatchTableCompanion toCompanion(bool nullToAbsent) { + return SourceMatchTableCompanion( + id: Value(id), + trackId: Value(trackId), + sourceId: Value(sourceId), + sourceType: Value(sourceType), + createdAt: Value(createdAt), + ); + } + + factory SourceMatchTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return SourceMatchTableData( + id: serializer.fromJson(json['id']), + trackId: serializer.fromJson(json['trackId']), + sourceId: serializer.fromJson(json['sourceId']), + sourceType: serializer.fromJson(json['sourceType']), + createdAt: serializer.fromJson(json['createdAt']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'trackId': serializer.toJson(trackId), + 'sourceId': serializer.toJson(sourceId), + 'sourceType': serializer.toJson(sourceType), + 'createdAt': serializer.toJson(createdAt), + }; + } + + SourceMatchTableData copyWith( + {int? id, + String? trackId, + String? sourceId, + String? sourceType, + DateTime? createdAt}) => + SourceMatchTableData( + id: id ?? this.id, + trackId: trackId ?? this.trackId, + sourceId: sourceId ?? this.sourceId, + sourceType: sourceType ?? this.sourceType, + createdAt: createdAt ?? this.createdAt, + ); + SourceMatchTableData copyWithCompanion(SourceMatchTableCompanion data) { + return SourceMatchTableData( + id: data.id.present ? data.id.value : this.id, + trackId: data.trackId.present ? data.trackId.value : this.trackId, + sourceId: data.sourceId.present ? data.sourceId.value : this.sourceId, + sourceType: + data.sourceType.present ? data.sourceType.value : this.sourceType, + createdAt: data.createdAt.present ? data.createdAt.value : this.createdAt, + ); + } + + @override + String toString() { + return (StringBuffer('SourceMatchTableData(') + ..write('id: $id, ') + ..write('trackId: $trackId, ') + ..write('sourceId: $sourceId, ') + ..write('sourceType: $sourceType, ') + ..write('createdAt: $createdAt') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, trackId, sourceId, sourceType, createdAt); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is SourceMatchTableData && + other.id == this.id && + other.trackId == this.trackId && + other.sourceId == this.sourceId && + other.sourceType == this.sourceType && + other.createdAt == this.createdAt); +} + +class SourceMatchTableCompanion extends UpdateCompanion { + final Value id; + final Value trackId; + final Value sourceId; + final Value sourceType; + final Value createdAt; + const SourceMatchTableCompanion({ + this.id = const Value.absent(), + this.trackId = const Value.absent(), + this.sourceId = const Value.absent(), + this.sourceType = const Value.absent(), + this.createdAt = const Value.absent(), + }); + SourceMatchTableCompanion.insert({ + this.id = const Value.absent(), + required String trackId, + required String sourceId, + this.sourceType = const Value.absent(), + this.createdAt = const Value.absent(), + }) : trackId = Value(trackId), + sourceId = Value(sourceId); + static Insertable custom({ + Expression? id, + Expression? trackId, + Expression? sourceId, + Expression? sourceType, + Expression? createdAt, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (trackId != null) 'track_id': trackId, + if (sourceId != null) 'source_id': sourceId, + if (sourceType != null) 'source_type': sourceType, + if (createdAt != null) 'created_at': createdAt, + }); + } + + SourceMatchTableCompanion copyWith( + {Value? id, + Value? trackId, + Value? sourceId, + Value? sourceType, + Value? createdAt}) { + return SourceMatchTableCompanion( + id: id ?? this.id, + trackId: trackId ?? this.trackId, + sourceId: sourceId ?? this.sourceId, + sourceType: sourceType ?? this.sourceType, + createdAt: createdAt ?? this.createdAt, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (trackId.present) { + map['track_id'] = Variable(trackId.value); + } + if (sourceId.present) { + map['source_id'] = Variable(sourceId.value); + } + if (sourceType.present) { + map['source_type'] = Variable(sourceType.value); + } + if (createdAt.present) { + map['created_at'] = Variable(createdAt.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('SourceMatchTableCompanion(') + ..write('id: $id, ') + ..write('trackId: $trackId, ') + ..write('sourceId: $sourceId, ') + ..write('sourceType: $sourceType, ') + ..write('createdAt: $createdAt') + ..write(')')) + .toString(); + } +} + +class AudioPlayerStateTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + AudioPlayerStateTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn playing = GeneratedColumn( + 'playing', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: true, + defaultConstraints: + GeneratedColumn.constraintIsAlways('CHECK ("playing" IN (0, 1))')); + late final GeneratedColumn loopMode = GeneratedColumn( + 'loop_mode', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn shuffled = GeneratedColumn( + 'shuffled', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: true, + defaultConstraints: + GeneratedColumn.constraintIsAlways('CHECK ("shuffled" IN (0, 1))')); + late final GeneratedColumn collections = GeneratedColumn( + 'collections', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + @override + List get $columns => + [id, playing, loopMode, shuffled, collections]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'audio_player_state_table'; + @override + Set get $primaryKey => {id}; + @override + AudioPlayerStateTableData map(Map data, + {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return AudioPlayerStateTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + playing: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}playing'])!, + loopMode: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}loop_mode'])!, + shuffled: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}shuffled'])!, + collections: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}collections'])!, + ); + } + + @override + AudioPlayerStateTable createAlias(String alias) { + return AudioPlayerStateTable(attachedDatabase, alias); + } +} + +class AudioPlayerStateTableData extends DataClass + implements Insertable { + final int id; + final bool playing; + final String loopMode; + final bool shuffled; + final String collections; + const AudioPlayerStateTableData( + {required this.id, + required this.playing, + required this.loopMode, + required this.shuffled, + required this.collections}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['playing'] = Variable(playing); + map['loop_mode'] = Variable(loopMode); + map['shuffled'] = Variable(shuffled); + map['collections'] = Variable(collections); + return map; + } + + AudioPlayerStateTableCompanion toCompanion(bool nullToAbsent) { + return AudioPlayerStateTableCompanion( + id: Value(id), + playing: Value(playing), + loopMode: Value(loopMode), + shuffled: Value(shuffled), + collections: Value(collections), + ); + } + + factory AudioPlayerStateTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return AudioPlayerStateTableData( + id: serializer.fromJson(json['id']), + playing: serializer.fromJson(json['playing']), + loopMode: serializer.fromJson(json['loopMode']), + shuffled: serializer.fromJson(json['shuffled']), + collections: serializer.fromJson(json['collections']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'playing': serializer.toJson(playing), + 'loopMode': serializer.toJson(loopMode), + 'shuffled': serializer.toJson(shuffled), + 'collections': serializer.toJson(collections), + }; + } + + AudioPlayerStateTableData copyWith( + {int? id, + bool? playing, + String? loopMode, + bool? shuffled, + String? collections}) => + AudioPlayerStateTableData( + id: id ?? this.id, + playing: playing ?? this.playing, + loopMode: loopMode ?? this.loopMode, + shuffled: shuffled ?? this.shuffled, + collections: collections ?? this.collections, + ); + AudioPlayerStateTableData copyWithCompanion( + AudioPlayerStateTableCompanion data) { + return AudioPlayerStateTableData( + id: data.id.present ? data.id.value : this.id, + playing: data.playing.present ? data.playing.value : this.playing, + loopMode: data.loopMode.present ? data.loopMode.value : this.loopMode, + shuffled: data.shuffled.present ? data.shuffled.value : this.shuffled, + collections: + data.collections.present ? data.collections.value : this.collections, + ); + } + + @override + String toString() { + return (StringBuffer('AudioPlayerStateTableData(') + ..write('id: $id, ') + ..write('playing: $playing, ') + ..write('loopMode: $loopMode, ') + ..write('shuffled: $shuffled, ') + ..write('collections: $collections') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, playing, loopMode, shuffled, collections); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is AudioPlayerStateTableData && + other.id == this.id && + other.playing == this.playing && + other.loopMode == this.loopMode && + other.shuffled == this.shuffled && + other.collections == this.collections); +} + +class AudioPlayerStateTableCompanion + extends UpdateCompanion { + final Value id; + final Value playing; + final Value loopMode; + final Value shuffled; + final Value collections; + const AudioPlayerStateTableCompanion({ + this.id = const Value.absent(), + this.playing = const Value.absent(), + this.loopMode = const Value.absent(), + this.shuffled = const Value.absent(), + this.collections = const Value.absent(), + }); + AudioPlayerStateTableCompanion.insert({ + this.id = const Value.absent(), + required bool playing, + required String loopMode, + required bool shuffled, + required String collections, + }) : playing = Value(playing), + loopMode = Value(loopMode), + shuffled = Value(shuffled), + collections = Value(collections); + static Insertable custom({ + Expression? id, + Expression? playing, + Expression? loopMode, + Expression? shuffled, + Expression? collections, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (playing != null) 'playing': playing, + if (loopMode != null) 'loop_mode': loopMode, + if (shuffled != null) 'shuffled': shuffled, + if (collections != null) 'collections': collections, + }); + } + + AudioPlayerStateTableCompanion copyWith( + {Value? id, + Value? playing, + Value? loopMode, + Value? shuffled, + Value? collections}) { + return AudioPlayerStateTableCompanion( + id: id ?? this.id, + playing: playing ?? this.playing, + loopMode: loopMode ?? this.loopMode, + shuffled: shuffled ?? this.shuffled, + collections: collections ?? this.collections, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (playing.present) { + map['playing'] = Variable(playing.value); + } + if (loopMode.present) { + map['loop_mode'] = Variable(loopMode.value); + } + if (shuffled.present) { + map['shuffled'] = Variable(shuffled.value); + } + if (collections.present) { + map['collections'] = Variable(collections.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('AudioPlayerStateTableCompanion(') + ..write('id: $id, ') + ..write('playing: $playing, ') + ..write('loopMode: $loopMode, ') + ..write('shuffled: $shuffled, ') + ..write('collections: $collections') + ..write(')')) + .toString(); + } +} + +class PlaylistTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + PlaylistTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn audioPlayerStateId = GeneratedColumn( + 'audio_player_state_id', aliasedName, false, + type: DriftSqlType.int, + requiredDuringInsert: true, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'REFERENCES audio_player_state_table (id)')); + late final GeneratedColumn index = GeneratedColumn( + 'index', aliasedName, false, + type: DriftSqlType.int, requiredDuringInsert: true); + @override + List get $columns => [id, audioPlayerStateId, index]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'playlist_table'; + @override + Set get $primaryKey => {id}; + @override + PlaylistTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return PlaylistTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + audioPlayerStateId: attachedDatabase.typeMapping.read( + DriftSqlType.int, data['${effectivePrefix}audio_player_state_id'])!, + index: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}index'])!, + ); + } + + @override + PlaylistTable createAlias(String alias) { + return PlaylistTable(attachedDatabase, alias); + } +} + +class PlaylistTableData extends DataClass + implements Insertable { + final int id; + final int audioPlayerStateId; + final int index; + const PlaylistTableData( + {required this.id, + required this.audioPlayerStateId, + required this.index}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['audio_player_state_id'] = Variable(audioPlayerStateId); + map['index'] = Variable(index); + return map; + } + + PlaylistTableCompanion toCompanion(bool nullToAbsent) { + return PlaylistTableCompanion( + id: Value(id), + audioPlayerStateId: Value(audioPlayerStateId), + index: Value(index), + ); + } + + factory PlaylistTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return PlaylistTableData( + id: serializer.fromJson(json['id']), + audioPlayerStateId: serializer.fromJson(json['audioPlayerStateId']), + index: serializer.fromJson(json['index']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'audioPlayerStateId': serializer.toJson(audioPlayerStateId), + 'index': serializer.toJson(index), + }; + } + + PlaylistTableData copyWith({int? id, int? audioPlayerStateId, int? index}) => + PlaylistTableData( + id: id ?? this.id, + audioPlayerStateId: audioPlayerStateId ?? this.audioPlayerStateId, + index: index ?? this.index, + ); + PlaylistTableData copyWithCompanion(PlaylistTableCompanion data) { + return PlaylistTableData( + id: data.id.present ? data.id.value : this.id, + audioPlayerStateId: data.audioPlayerStateId.present + ? data.audioPlayerStateId.value + : this.audioPlayerStateId, + index: data.index.present ? data.index.value : this.index, + ); + } + + @override + String toString() { + return (StringBuffer('PlaylistTableData(') + ..write('id: $id, ') + ..write('audioPlayerStateId: $audioPlayerStateId, ') + ..write('index: $index') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, audioPlayerStateId, index); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is PlaylistTableData && + other.id == this.id && + other.audioPlayerStateId == this.audioPlayerStateId && + other.index == this.index); +} + +class PlaylistTableCompanion extends UpdateCompanion { + final Value id; + final Value audioPlayerStateId; + final Value index; + const PlaylistTableCompanion({ + this.id = const Value.absent(), + this.audioPlayerStateId = const Value.absent(), + this.index = const Value.absent(), + }); + PlaylistTableCompanion.insert({ + this.id = const Value.absent(), + required int audioPlayerStateId, + required int index, + }) : audioPlayerStateId = Value(audioPlayerStateId), + index = Value(index); + static Insertable custom({ + Expression? id, + Expression? audioPlayerStateId, + Expression? index, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (audioPlayerStateId != null) + 'audio_player_state_id': audioPlayerStateId, + if (index != null) 'index': index, + }); + } + + PlaylistTableCompanion copyWith( + {Value? id, Value? audioPlayerStateId, Value? index}) { + return PlaylistTableCompanion( + id: id ?? this.id, + audioPlayerStateId: audioPlayerStateId ?? this.audioPlayerStateId, + index: index ?? this.index, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (audioPlayerStateId.present) { + map['audio_player_state_id'] = Variable(audioPlayerStateId.value); + } + if (index.present) { + map['index'] = Variable(index.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('PlaylistTableCompanion(') + ..write('id: $id, ') + ..write('audioPlayerStateId: $audioPlayerStateId, ') + ..write('index: $index') + ..write(')')) + .toString(); + } +} + +class PlaylistMediaTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + PlaylistMediaTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn playlistId = GeneratedColumn( + 'playlist_id', aliasedName, false, + type: DriftSqlType.int, + requiredDuringInsert: true, + defaultConstraints: + GeneratedColumn.constraintIsAlways('REFERENCES playlist_table (id)')); + late final GeneratedColumn uri = GeneratedColumn( + 'uri', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn extras = GeneratedColumn( + 'extras', aliasedName, true, + type: DriftSqlType.string, requiredDuringInsert: false); + late final GeneratedColumn httpHeaders = GeneratedColumn( + 'http_headers', aliasedName, true, + type: DriftSqlType.string, requiredDuringInsert: false); + @override + List get $columns => + [id, playlistId, uri, extras, httpHeaders]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'playlist_media_table'; + @override + Set get $primaryKey => {id}; + @override + PlaylistMediaTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return PlaylistMediaTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + playlistId: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}playlist_id'])!, + uri: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}uri'])!, + extras: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}extras']), + httpHeaders: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}http_headers']), + ); + } + + @override + PlaylistMediaTable createAlias(String alias) { + return PlaylistMediaTable(attachedDatabase, alias); + } +} + +class PlaylistMediaTableData extends DataClass + implements Insertable { + final int id; + final int playlistId; + final String uri; + final String? extras; + final String? httpHeaders; + const PlaylistMediaTableData( + {required this.id, + required this.playlistId, + required this.uri, + this.extras, + this.httpHeaders}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['playlist_id'] = Variable(playlistId); + map['uri'] = Variable(uri); + if (!nullToAbsent || extras != null) { + map['extras'] = Variable(extras); + } + if (!nullToAbsent || httpHeaders != null) { + map['http_headers'] = Variable(httpHeaders); + } + return map; + } + + PlaylistMediaTableCompanion toCompanion(bool nullToAbsent) { + return PlaylistMediaTableCompanion( + id: Value(id), + playlistId: Value(playlistId), + uri: Value(uri), + extras: + extras == null && nullToAbsent ? const Value.absent() : Value(extras), + httpHeaders: httpHeaders == null && nullToAbsent + ? const Value.absent() + : Value(httpHeaders), + ); + } + + factory PlaylistMediaTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return PlaylistMediaTableData( + id: serializer.fromJson(json['id']), + playlistId: serializer.fromJson(json['playlistId']), + uri: serializer.fromJson(json['uri']), + extras: serializer.fromJson(json['extras']), + httpHeaders: serializer.fromJson(json['httpHeaders']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'playlistId': serializer.toJson(playlistId), + 'uri': serializer.toJson(uri), + 'extras': serializer.toJson(extras), + 'httpHeaders': serializer.toJson(httpHeaders), + }; + } + + PlaylistMediaTableData copyWith( + {int? id, + int? playlistId, + String? uri, + Value extras = const Value.absent(), + Value httpHeaders = const Value.absent()}) => + PlaylistMediaTableData( + id: id ?? this.id, + playlistId: playlistId ?? this.playlistId, + uri: uri ?? this.uri, + extras: extras.present ? extras.value : this.extras, + httpHeaders: httpHeaders.present ? httpHeaders.value : this.httpHeaders, + ); + PlaylistMediaTableData copyWithCompanion(PlaylistMediaTableCompanion data) { + return PlaylistMediaTableData( + id: data.id.present ? data.id.value : this.id, + playlistId: + data.playlistId.present ? data.playlistId.value : this.playlistId, + uri: data.uri.present ? data.uri.value : this.uri, + extras: data.extras.present ? data.extras.value : this.extras, + httpHeaders: + data.httpHeaders.present ? data.httpHeaders.value : this.httpHeaders, + ); + } + + @override + String toString() { + return (StringBuffer('PlaylistMediaTableData(') + ..write('id: $id, ') + ..write('playlistId: $playlistId, ') + ..write('uri: $uri, ') + ..write('extras: $extras, ') + ..write('httpHeaders: $httpHeaders') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, playlistId, uri, extras, httpHeaders); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is PlaylistMediaTableData && + other.id == this.id && + other.playlistId == this.playlistId && + other.uri == this.uri && + other.extras == this.extras && + other.httpHeaders == this.httpHeaders); +} + +class PlaylistMediaTableCompanion + extends UpdateCompanion { + final Value id; + final Value playlistId; + final Value uri; + final Value extras; + final Value httpHeaders; + const PlaylistMediaTableCompanion({ + this.id = const Value.absent(), + this.playlistId = const Value.absent(), + this.uri = const Value.absent(), + this.extras = const Value.absent(), + this.httpHeaders = const Value.absent(), + }); + PlaylistMediaTableCompanion.insert({ + this.id = const Value.absent(), + required int playlistId, + required String uri, + this.extras = const Value.absent(), + this.httpHeaders = const Value.absent(), + }) : playlistId = Value(playlistId), + uri = Value(uri); + static Insertable custom({ + Expression? id, + Expression? playlistId, + Expression? uri, + Expression? extras, + Expression? httpHeaders, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (playlistId != null) 'playlist_id': playlistId, + if (uri != null) 'uri': uri, + if (extras != null) 'extras': extras, + if (httpHeaders != null) 'http_headers': httpHeaders, + }); + } + + PlaylistMediaTableCompanion copyWith( + {Value? id, + Value? playlistId, + Value? uri, + Value? extras, + Value? httpHeaders}) { + return PlaylistMediaTableCompanion( + id: id ?? this.id, + playlistId: playlistId ?? this.playlistId, + uri: uri ?? this.uri, + extras: extras ?? this.extras, + httpHeaders: httpHeaders ?? this.httpHeaders, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (playlistId.present) { + map['playlist_id'] = Variable(playlistId.value); + } + if (uri.present) { + map['uri'] = Variable(uri.value); + } + if (extras.present) { + map['extras'] = Variable(extras.value); + } + if (httpHeaders.present) { + map['http_headers'] = Variable(httpHeaders.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('PlaylistMediaTableCompanion(') + ..write('id: $id, ') + ..write('playlistId: $playlistId, ') + ..write('uri: $uri, ') + ..write('extras: $extras, ') + ..write('httpHeaders: $httpHeaders') + ..write(')')) + .toString(); + } +} + +class HistoryTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + HistoryTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn createdAt = GeneratedColumn( + 'created_at', aliasedName, false, + type: DriftSqlType.dateTime, + requiredDuringInsert: false, + defaultValue: currentDateAndTime); + late final GeneratedColumn type = GeneratedColumn( + 'type', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn itemId = GeneratedColumn( + 'item_id', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn data = GeneratedColumn( + 'data', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + @override + List get $columns => [id, createdAt, type, itemId, data]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'history_table'; + @override + Set get $primaryKey => {id}; + @override + HistoryTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return HistoryTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + createdAt: attachedDatabase.typeMapping + .read(DriftSqlType.dateTime, data['${effectivePrefix}created_at'])!, + type: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}type'])!, + itemId: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}item_id'])!, + data: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}data'])!, + ); + } + + @override + HistoryTable createAlias(String alias) { + return HistoryTable(attachedDatabase, alias); + } +} + +class HistoryTableData extends DataClass + implements Insertable { + final int id; + final DateTime createdAt; + final String type; + final String itemId; + final String data; + const HistoryTableData( + {required this.id, + required this.createdAt, + required this.type, + required this.itemId, + required this.data}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['created_at'] = Variable(createdAt); + map['type'] = Variable(type); + map['item_id'] = Variable(itemId); + map['data'] = Variable(data); + return map; + } + + HistoryTableCompanion toCompanion(bool nullToAbsent) { + return HistoryTableCompanion( + id: Value(id), + createdAt: Value(createdAt), + type: Value(type), + itemId: Value(itemId), + data: Value(data), + ); + } + + factory HistoryTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return HistoryTableData( + id: serializer.fromJson(json['id']), + createdAt: serializer.fromJson(json['createdAt']), + type: serializer.fromJson(json['type']), + itemId: serializer.fromJson(json['itemId']), + data: serializer.fromJson(json['data']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'createdAt': serializer.toJson(createdAt), + 'type': serializer.toJson(type), + 'itemId': serializer.toJson(itemId), + 'data': serializer.toJson(data), + }; + } + + HistoryTableData copyWith( + {int? id, + DateTime? createdAt, + String? type, + String? itemId, + String? data}) => + HistoryTableData( + id: id ?? this.id, + createdAt: createdAt ?? this.createdAt, + type: type ?? this.type, + itemId: itemId ?? this.itemId, + data: data ?? this.data, + ); + HistoryTableData copyWithCompanion(HistoryTableCompanion data) { + return HistoryTableData( + id: data.id.present ? data.id.value : this.id, + createdAt: data.createdAt.present ? data.createdAt.value : this.createdAt, + type: data.type.present ? data.type.value : this.type, + itemId: data.itemId.present ? data.itemId.value : this.itemId, + data: data.data.present ? data.data.value : this.data, + ); + } + + @override + String toString() { + return (StringBuffer('HistoryTableData(') + ..write('id: $id, ') + ..write('createdAt: $createdAt, ') + ..write('type: $type, ') + ..write('itemId: $itemId, ') + ..write('data: $data') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, createdAt, type, itemId, data); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is HistoryTableData && + other.id == this.id && + other.createdAt == this.createdAt && + other.type == this.type && + other.itemId == this.itemId && + other.data == this.data); +} + +class HistoryTableCompanion extends UpdateCompanion { + final Value id; + final Value createdAt; + final Value type; + final Value itemId; + final Value data; + const HistoryTableCompanion({ + this.id = const Value.absent(), + this.createdAt = const Value.absent(), + this.type = const Value.absent(), + this.itemId = const Value.absent(), + this.data = const Value.absent(), + }); + HistoryTableCompanion.insert({ + this.id = const Value.absent(), + this.createdAt = const Value.absent(), + required String type, + required String itemId, + required String data, + }) : type = Value(type), + itemId = Value(itemId), + data = Value(data); + static Insertable custom({ + Expression? id, + Expression? createdAt, + Expression? type, + Expression? itemId, + Expression? data, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (createdAt != null) 'created_at': createdAt, + if (type != null) 'type': type, + if (itemId != null) 'item_id': itemId, + if (data != null) 'data': data, + }); + } + + HistoryTableCompanion copyWith( + {Value? id, + Value? createdAt, + Value? type, + Value? itemId, + Value? data}) { + return HistoryTableCompanion( + id: id ?? this.id, + createdAt: createdAt ?? this.createdAt, + type: type ?? this.type, + itemId: itemId ?? this.itemId, + data: data ?? this.data, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (createdAt.present) { + map['created_at'] = Variable(createdAt.value); + } + if (type.present) { + map['type'] = Variable(type.value); + } + if (itemId.present) { + map['item_id'] = Variable(itemId.value); + } + if (data.present) { + map['data'] = Variable(data.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('HistoryTableCompanion(') + ..write('id: $id, ') + ..write('createdAt: $createdAt, ') + ..write('type: $type, ') + ..write('itemId: $itemId, ') + ..write('data: $data') + ..write(')')) + .toString(); + } +} + +class LyricsTable extends Table with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + LyricsTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn trackId = GeneratedColumn( + 'track_id', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn data = GeneratedColumn( + 'data', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + @override + List get $columns => [id, trackId, data]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'lyrics_table'; + @override + Set get $primaryKey => {id}; + @override + LyricsTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return LyricsTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + trackId: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}track_id'])!, + data: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}data'])!, + ); + } + + @override + LyricsTable createAlias(String alias) { + return LyricsTable(attachedDatabase, alias); + } +} + +class LyricsTableData extends DataClass implements Insertable { + final int id; + final String trackId; + final String data; + const LyricsTableData( + {required this.id, required this.trackId, required this.data}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['track_id'] = Variable(trackId); + map['data'] = Variable(data); + return map; + } + + LyricsTableCompanion toCompanion(bool nullToAbsent) { + return LyricsTableCompanion( + id: Value(id), + trackId: Value(trackId), + data: Value(data), + ); + } + + factory LyricsTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return LyricsTableData( + id: serializer.fromJson(json['id']), + trackId: serializer.fromJson(json['trackId']), + data: serializer.fromJson(json['data']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'trackId': serializer.toJson(trackId), + 'data': serializer.toJson(data), + }; + } + + LyricsTableData copyWith({int? id, String? trackId, String? data}) => + LyricsTableData( + id: id ?? this.id, + trackId: trackId ?? this.trackId, + data: data ?? this.data, + ); + LyricsTableData copyWithCompanion(LyricsTableCompanion data) { + return LyricsTableData( + id: data.id.present ? data.id.value : this.id, + trackId: data.trackId.present ? data.trackId.value : this.trackId, + data: data.data.present ? data.data.value : this.data, + ); + } + + @override + String toString() { + return (StringBuffer('LyricsTableData(') + ..write('id: $id, ') + ..write('trackId: $trackId, ') + ..write('data: $data') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, trackId, data); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is LyricsTableData && + other.id == this.id && + other.trackId == this.trackId && + other.data == this.data); +} + +class LyricsTableCompanion extends UpdateCompanion { + final Value id; + final Value trackId; + final Value data; + const LyricsTableCompanion({ + this.id = const Value.absent(), + this.trackId = const Value.absent(), + this.data = const Value.absent(), + }); + LyricsTableCompanion.insert({ + this.id = const Value.absent(), + required String trackId, + required String data, + }) : trackId = Value(trackId), + data = Value(data); + static Insertable custom({ + Expression? id, + Expression? trackId, + Expression? data, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (trackId != null) 'track_id': trackId, + if (data != null) 'data': data, + }); + } + + LyricsTableCompanion copyWith( + {Value? id, Value? trackId, Value? data}) { + return LyricsTableCompanion( + id: id ?? this.id, + trackId: trackId ?? this.trackId, + data: data ?? this.data, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (trackId.present) { + map['track_id'] = Variable(trackId.value); + } + if (data.present) { + map['data'] = Variable(data.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('LyricsTableCompanion(') + ..write('id: $id, ') + ..write('trackId: $trackId, ') + ..write('data: $data') + ..write(')')) + .toString(); + } +} + +class DatabaseAtV1 extends GeneratedDatabase { + DatabaseAtV1(QueryExecutor e) : super(e); + late final AuthenticationTable authenticationTable = + AuthenticationTable(this); + late final BlacklistTable blacklistTable = BlacklistTable(this); + late final PreferencesTable preferencesTable = PreferencesTable(this); + late final ScrobblerTable scrobblerTable = ScrobblerTable(this); + late final SkipSegmentTable skipSegmentTable = SkipSegmentTable(this); + late final SourceMatchTable sourceMatchTable = SourceMatchTable(this); + late final AudioPlayerStateTable audioPlayerStateTable = + AudioPlayerStateTable(this); + late final PlaylistTable playlistTable = PlaylistTable(this); + late final PlaylistMediaTable playlistMediaTable = PlaylistMediaTable(this); + late final HistoryTable historyTable = HistoryTable(this); + late final LyricsTable lyricsTable = LyricsTable(this); + late final Index uniqueBlacklist = Index('unique_blacklist', + 'CREATE UNIQUE INDEX unique_blacklist ON blacklist_table (element_type, element_id)'); + late final Index uniqTrackMatch = Index('uniq_track_match', + 'CREATE UNIQUE INDEX uniq_track_match ON source_match_table (track_id, source_id, source_type)'); + @override + Iterable> get allTables => + allSchemaEntities.whereType>(); + @override + List get allSchemaEntities => [ + authenticationTable, + blacklistTable, + preferencesTable, + scrobblerTable, + skipSegmentTable, + sourceMatchTable, + audioPlayerStateTable, + playlistTable, + playlistMediaTable, + historyTable, + lyricsTable, + uniqueBlacklist, + uniqTrackMatch + ]; + @override + int get schemaVersion => 1; +} diff --git a/test/drift/app_db/generated/schema_v2.dart b/test/drift/app_db/generated/schema_v2.dart new file mode 100644 index 00000000..caf34ab9 --- /dev/null +++ b/test/drift/app_db/generated/schema_v2.dart @@ -0,0 +1,3366 @@ +// GENERATED CODE, DO NOT EDIT BY HAND. +// ignore_for_file: type=lint +//@dart=2.12 +import 'package:drift/drift.dart'; +import 'package:flutter/material.dart' hide Table; +import 'package:spotify/spotify.dart'; +import 'package:spotube/services/sourced_track/enums.dart'; +import 'package:spotube/utils/migrations/adapters.dart'; + +class AuthenticationTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + AuthenticationTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn cookie = GeneratedColumn( + 'cookie', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn accessToken = GeneratedColumn( + 'access_token', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn expiration = GeneratedColumn( + 'expiration', aliasedName, false, + type: DriftSqlType.dateTime, requiredDuringInsert: true); + @override + List get $columns => [id, cookie, accessToken, expiration]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'authentication_table'; + @override + Set get $primaryKey => {id}; + @override + AuthenticationTableData map(Map data, + {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return AuthenticationTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + cookie: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}cookie'])!, + accessToken: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}access_token'])!, + expiration: attachedDatabase.typeMapping + .read(DriftSqlType.dateTime, data['${effectivePrefix}expiration'])!, + ); + } + + @override + AuthenticationTable createAlias(String alias) { + return AuthenticationTable(attachedDatabase, alias); + } +} + +class AuthenticationTableData extends DataClass + implements Insertable { + final int id; + final String cookie; + final String accessToken; + final DateTime expiration; + const AuthenticationTableData( + {required this.id, + required this.cookie, + required this.accessToken, + required this.expiration}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['cookie'] = Variable(cookie); + map['access_token'] = Variable(accessToken); + map['expiration'] = Variable(expiration); + return map; + } + + AuthenticationTableCompanion toCompanion(bool nullToAbsent) { + return AuthenticationTableCompanion( + id: Value(id), + cookie: Value(cookie), + accessToken: Value(accessToken), + expiration: Value(expiration), + ); + } + + factory AuthenticationTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return AuthenticationTableData( + id: serializer.fromJson(json['id']), + cookie: serializer.fromJson(json['cookie']), + accessToken: serializer.fromJson(json['accessToken']), + expiration: serializer.fromJson(json['expiration']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'cookie': serializer.toJson(cookie), + 'accessToken': serializer.toJson(accessToken), + 'expiration': serializer.toJson(expiration), + }; + } + + AuthenticationTableData copyWith( + {int? id, + String? cookie, + String? accessToken, + DateTime? expiration}) => + AuthenticationTableData( + id: id ?? this.id, + cookie: cookie ?? this.cookie, + accessToken: accessToken ?? this.accessToken, + expiration: expiration ?? this.expiration, + ); + AuthenticationTableData copyWithCompanion(AuthenticationTableCompanion data) { + return AuthenticationTableData( + id: data.id.present ? data.id.value : this.id, + cookie: data.cookie.present ? data.cookie.value : this.cookie, + accessToken: + data.accessToken.present ? data.accessToken.value : this.accessToken, + expiration: + data.expiration.present ? data.expiration.value : this.expiration, + ); + } + + @override + String toString() { + return (StringBuffer('AuthenticationTableData(') + ..write('id: $id, ') + ..write('cookie: $cookie, ') + ..write('accessToken: $accessToken, ') + ..write('expiration: $expiration') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, cookie, accessToken, expiration); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is AuthenticationTableData && + other.id == this.id && + other.cookie == this.cookie && + other.accessToken == this.accessToken && + other.expiration == this.expiration); +} + +class AuthenticationTableCompanion + extends UpdateCompanion { + final Value id; + final Value cookie; + final Value accessToken; + final Value expiration; + const AuthenticationTableCompanion({ + this.id = const Value.absent(), + this.cookie = const Value.absent(), + this.accessToken = const Value.absent(), + this.expiration = const Value.absent(), + }); + AuthenticationTableCompanion.insert({ + this.id = const Value.absent(), + required String cookie, + required String accessToken, + required DateTime expiration, + }) : cookie = Value(cookie), + accessToken = Value(accessToken), + expiration = Value(expiration); + static Insertable custom({ + Expression? id, + Expression? cookie, + Expression? accessToken, + Expression? expiration, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (cookie != null) 'cookie': cookie, + if (accessToken != null) 'access_token': accessToken, + if (expiration != null) 'expiration': expiration, + }); + } + + AuthenticationTableCompanion copyWith( + {Value? id, + Value? cookie, + Value? accessToken, + Value? expiration}) { + return AuthenticationTableCompanion( + id: id ?? this.id, + cookie: cookie ?? this.cookie, + accessToken: accessToken ?? this.accessToken, + expiration: expiration ?? this.expiration, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (cookie.present) { + map['cookie'] = Variable(cookie.value); + } + if (accessToken.present) { + map['access_token'] = Variable(accessToken.value); + } + if (expiration.present) { + map['expiration'] = Variable(expiration.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('AuthenticationTableCompanion(') + ..write('id: $id, ') + ..write('cookie: $cookie, ') + ..write('accessToken: $accessToken, ') + ..write('expiration: $expiration') + ..write(')')) + .toString(); + } +} + +class BlacklistTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + BlacklistTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn name = GeneratedColumn( + 'name', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn elementType = GeneratedColumn( + 'element_type', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn elementId = GeneratedColumn( + 'element_id', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + @override + List get $columns => [id, name, elementType, elementId]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'blacklist_table'; + @override + Set get $primaryKey => {id}; + @override + BlacklistTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return BlacklistTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + name: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}name'])!, + elementType: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}element_type'])!, + elementId: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}element_id'])!, + ); + } + + @override + BlacklistTable createAlias(String alias) { + return BlacklistTable(attachedDatabase, alias); + } +} + +class BlacklistTableData extends DataClass + implements Insertable { + final int id; + final String name; + final String elementType; + final String elementId; + const BlacklistTableData( + {required this.id, + required this.name, + required this.elementType, + required this.elementId}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['name'] = Variable(name); + map['element_type'] = Variable(elementType); + map['element_id'] = Variable(elementId); + return map; + } + + BlacklistTableCompanion toCompanion(bool nullToAbsent) { + return BlacklistTableCompanion( + id: Value(id), + name: Value(name), + elementType: Value(elementType), + elementId: Value(elementId), + ); + } + + factory BlacklistTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return BlacklistTableData( + id: serializer.fromJson(json['id']), + name: serializer.fromJson(json['name']), + elementType: serializer.fromJson(json['elementType']), + elementId: serializer.fromJson(json['elementId']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'name': serializer.toJson(name), + 'elementType': serializer.toJson(elementType), + 'elementId': serializer.toJson(elementId), + }; + } + + BlacklistTableData copyWith( + {int? id, String? name, String? elementType, String? elementId}) => + BlacklistTableData( + id: id ?? this.id, + name: name ?? this.name, + elementType: elementType ?? this.elementType, + elementId: elementId ?? this.elementId, + ); + BlacklistTableData copyWithCompanion(BlacklistTableCompanion data) { + return BlacklistTableData( + id: data.id.present ? data.id.value : this.id, + name: data.name.present ? data.name.value : this.name, + elementType: + data.elementType.present ? data.elementType.value : this.elementType, + elementId: data.elementId.present ? data.elementId.value : this.elementId, + ); + } + + @override + String toString() { + return (StringBuffer('BlacklistTableData(') + ..write('id: $id, ') + ..write('name: $name, ') + ..write('elementType: $elementType, ') + ..write('elementId: $elementId') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, name, elementType, elementId); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is BlacklistTableData && + other.id == this.id && + other.name == this.name && + other.elementType == this.elementType && + other.elementId == this.elementId); +} + +class BlacklistTableCompanion extends UpdateCompanion { + final Value id; + final Value name; + final Value elementType; + final Value elementId; + const BlacklistTableCompanion({ + this.id = const Value.absent(), + this.name = const Value.absent(), + this.elementType = const Value.absent(), + this.elementId = const Value.absent(), + }); + BlacklistTableCompanion.insert({ + this.id = const Value.absent(), + required String name, + required String elementType, + required String elementId, + }) : name = Value(name), + elementType = Value(elementType), + elementId = Value(elementId); + static Insertable custom({ + Expression? id, + Expression? name, + Expression? elementType, + Expression? elementId, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (name != null) 'name': name, + if (elementType != null) 'element_type': elementType, + if (elementId != null) 'element_id': elementId, + }); + } + + BlacklistTableCompanion copyWith( + {Value? id, + Value? name, + Value? elementType, + Value? elementId}) { + return BlacklistTableCompanion( + id: id ?? this.id, + name: name ?? this.name, + elementType: elementType ?? this.elementType, + elementId: elementId ?? this.elementId, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (name.present) { + map['name'] = Variable(name.value); + } + if (elementType.present) { + map['element_type'] = Variable(elementType.value); + } + if (elementId.present) { + map['element_id'] = Variable(elementId.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('BlacklistTableCompanion(') + ..write('id: $id, ') + ..write('name: $name, ') + ..write('elementType: $elementType, ') + ..write('elementId: $elementId') + ..write(')')) + .toString(); + } +} + +class PreferencesTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + PreferencesTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn audioQuality = GeneratedColumn( + 'audio_quality', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(SourceQualities.high.name)); + late final GeneratedColumn albumColorSync = GeneratedColumn( + 'album_color_sync', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("album_color_sync" IN (0, 1))'), + defaultValue: const Constant(true)); + late final GeneratedColumn amoledDarkTheme = GeneratedColumn( + 'amoled_dark_theme', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("amoled_dark_theme" IN (0, 1))'), + defaultValue: const Constant(false)); + late final GeneratedColumn checkUpdate = GeneratedColumn( + 'check_update', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("check_update" IN (0, 1))'), + defaultValue: const Constant(true)); + late final GeneratedColumn normalizeAudio = GeneratedColumn( + 'normalize_audio', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("normalize_audio" IN (0, 1))'), + defaultValue: const Constant(false)); + late final GeneratedColumn showSystemTrayIcon = GeneratedColumn( + 'show_system_tray_icon', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("show_system_tray_icon" IN (0, 1))'), + defaultValue: const Constant(false)); + late final GeneratedColumn systemTitleBar = GeneratedColumn( + 'system_title_bar', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("system_title_bar" IN (0, 1))'), + defaultValue: const Constant(false)); + late final GeneratedColumn skipNonMusic = GeneratedColumn( + 'skip_non_music', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("skip_non_music" IN (0, 1))'), + defaultValue: const Constant(false)); + late final GeneratedColumn closeBehavior = GeneratedColumn( + 'close_behavior', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(CloseBehavior.close.name)); + late final GeneratedColumn accentColorScheme = + GeneratedColumn('accent_color_scheme', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: const Constant("Blue:0xFF2196F3")); + late final GeneratedColumn layoutMode = GeneratedColumn( + 'layout_mode', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(LayoutMode.adaptive.name)); + late final GeneratedColumn locale = GeneratedColumn( + 'locale', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: + const Constant('{"languageCode":"system","countryCode":"system"}')); + late final GeneratedColumn market = GeneratedColumn( + 'market', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(Market.US.name)); + late final GeneratedColumn searchMode = GeneratedColumn( + 'search_mode', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(SearchMode.youtube.name)); + late final GeneratedColumn downloadLocation = GeneratedColumn( + 'download_location', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: const Constant("")); + late final GeneratedColumn localLibraryLocation = + GeneratedColumn('local_library_location', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: const Constant("")); + late final GeneratedColumn pipedInstance = GeneratedColumn( + 'piped_instance', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: const Constant("https://pipedapi.kavin.rocks")); + late final GeneratedColumn invidiousInstance = + GeneratedColumn('invidious_instance', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: const Constant("https://inv.nadeko.net")); + late final GeneratedColumn themeMode = GeneratedColumn( + 'theme_mode', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(ThemeMode.system.name)); + late final GeneratedColumn audioSource = GeneratedColumn( + 'audio_source', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(AudioSource.youtube.name)); + late final GeneratedColumn streamMusicCodec = GeneratedColumn( + 'stream_music_codec', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(SourceCodecs.weba.name)); + late final GeneratedColumn downloadMusicCodec = + GeneratedColumn('download_music_codec', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(SourceCodecs.m4a.name)); + late final GeneratedColumn discordPresence = GeneratedColumn( + 'discord_presence', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("discord_presence" IN (0, 1))'), + defaultValue: const Constant(true)); + late final GeneratedColumn endlessPlayback = GeneratedColumn( + 'endless_playback', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("endless_playback" IN (0, 1))'), + defaultValue: const Constant(true)); + late final GeneratedColumn enableConnect = GeneratedColumn( + 'enable_connect', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: false, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'CHECK ("enable_connect" IN (0, 1))'), + defaultValue: const Constant(false)); + @override + List get $columns => [ + id, + audioQuality, + albumColorSync, + amoledDarkTheme, + checkUpdate, + normalizeAudio, + showSystemTrayIcon, + systemTitleBar, + skipNonMusic, + closeBehavior, + accentColorScheme, + layoutMode, + locale, + market, + searchMode, + downloadLocation, + localLibraryLocation, + pipedInstance, + invidiousInstance, + themeMode, + audioSource, + streamMusicCodec, + downloadMusicCodec, + discordPresence, + endlessPlayback, + enableConnect + ]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'preferences_table'; + @override + Set get $primaryKey => {id}; + @override + PreferencesTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return PreferencesTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + audioQuality: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}audio_quality'])!, + albumColorSync: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}album_color_sync'])!, + amoledDarkTheme: attachedDatabase.typeMapping.read( + DriftSqlType.bool, data['${effectivePrefix}amoled_dark_theme'])!, + checkUpdate: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}check_update'])!, + normalizeAudio: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}normalize_audio'])!, + showSystemTrayIcon: attachedDatabase.typeMapping.read( + DriftSqlType.bool, data['${effectivePrefix}show_system_tray_icon'])!, + systemTitleBar: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}system_title_bar'])!, + skipNonMusic: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}skip_non_music'])!, + closeBehavior: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}close_behavior'])!, + accentColorScheme: attachedDatabase.typeMapping.read( + DriftSqlType.string, data['${effectivePrefix}accent_color_scheme'])!, + layoutMode: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}layout_mode'])!, + locale: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}locale'])!, + market: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}market'])!, + searchMode: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}search_mode'])!, + downloadLocation: attachedDatabase.typeMapping.read( + DriftSqlType.string, data['${effectivePrefix}download_location'])!, + localLibraryLocation: attachedDatabase.typeMapping.read( + DriftSqlType.string, + data['${effectivePrefix}local_library_location'])!, + pipedInstance: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}piped_instance'])!, + invidiousInstance: attachedDatabase.typeMapping.read( + DriftSqlType.string, data['${effectivePrefix}invidious_instance'])!, + themeMode: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}theme_mode'])!, + audioSource: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}audio_source'])!, + streamMusicCodec: attachedDatabase.typeMapping.read( + DriftSqlType.string, data['${effectivePrefix}stream_music_codec'])!, + downloadMusicCodec: attachedDatabase.typeMapping.read( + DriftSqlType.string, data['${effectivePrefix}download_music_codec'])!, + discordPresence: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}discord_presence'])!, + endlessPlayback: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}endless_playback'])!, + enableConnect: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}enable_connect'])!, + ); + } + + @override + PreferencesTable createAlias(String alias) { + return PreferencesTable(attachedDatabase, alias); + } +} + +class PreferencesTableData extends DataClass + implements Insertable { + final int id; + final String audioQuality; + final bool albumColorSync; + final bool amoledDarkTheme; + final bool checkUpdate; + final bool normalizeAudio; + final bool showSystemTrayIcon; + final bool systemTitleBar; + final bool skipNonMusic; + final String closeBehavior; + final String accentColorScheme; + final String layoutMode; + final String locale; + final String market; + final String searchMode; + final String downloadLocation; + final String localLibraryLocation; + final String pipedInstance; + final String invidiousInstance; + final String themeMode; + final String audioSource; + final String streamMusicCodec; + final String downloadMusicCodec; + final bool discordPresence; + final bool endlessPlayback; + final bool enableConnect; + const PreferencesTableData( + {required this.id, + required this.audioQuality, + required this.albumColorSync, + required this.amoledDarkTheme, + required this.checkUpdate, + required this.normalizeAudio, + required this.showSystemTrayIcon, + required this.systemTitleBar, + required this.skipNonMusic, + required this.closeBehavior, + required this.accentColorScheme, + required this.layoutMode, + required this.locale, + required this.market, + required this.searchMode, + required this.downloadLocation, + required this.localLibraryLocation, + required this.pipedInstance, + required this.invidiousInstance, + required this.themeMode, + required this.audioSource, + required this.streamMusicCodec, + required this.downloadMusicCodec, + required this.discordPresence, + required this.endlessPlayback, + required this.enableConnect}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['audio_quality'] = Variable(audioQuality); + map['album_color_sync'] = Variable(albumColorSync); + map['amoled_dark_theme'] = Variable(amoledDarkTheme); + map['check_update'] = Variable(checkUpdate); + map['normalize_audio'] = Variable(normalizeAudio); + map['show_system_tray_icon'] = Variable(showSystemTrayIcon); + map['system_title_bar'] = Variable(systemTitleBar); + map['skip_non_music'] = Variable(skipNonMusic); + map['close_behavior'] = Variable(closeBehavior); + map['accent_color_scheme'] = Variable(accentColorScheme); + map['layout_mode'] = Variable(layoutMode); + map['locale'] = Variable(locale); + map['market'] = Variable(market); + map['search_mode'] = Variable(searchMode); + map['download_location'] = Variable(downloadLocation); + map['local_library_location'] = Variable(localLibraryLocation); + map['piped_instance'] = Variable(pipedInstance); + map['invidious_instance'] = Variable(invidiousInstance); + map['theme_mode'] = Variable(themeMode); + map['audio_source'] = Variable(audioSource); + map['stream_music_codec'] = Variable(streamMusicCodec); + map['download_music_codec'] = Variable(downloadMusicCodec); + map['discord_presence'] = Variable(discordPresence); + map['endless_playback'] = Variable(endlessPlayback); + map['enable_connect'] = Variable(enableConnect); + return map; + } + + PreferencesTableCompanion toCompanion(bool nullToAbsent) { + return PreferencesTableCompanion( + id: Value(id), + audioQuality: Value(audioQuality), + albumColorSync: Value(albumColorSync), + amoledDarkTheme: Value(amoledDarkTheme), + checkUpdate: Value(checkUpdate), + normalizeAudio: Value(normalizeAudio), + showSystemTrayIcon: Value(showSystemTrayIcon), + systemTitleBar: Value(systemTitleBar), + skipNonMusic: Value(skipNonMusic), + closeBehavior: Value(closeBehavior), + accentColorScheme: Value(accentColorScheme), + layoutMode: Value(layoutMode), + locale: Value(locale), + market: Value(market), + searchMode: Value(searchMode), + downloadLocation: Value(downloadLocation), + localLibraryLocation: Value(localLibraryLocation), + pipedInstance: Value(pipedInstance), + invidiousInstance: Value(invidiousInstance), + themeMode: Value(themeMode), + audioSource: Value(audioSource), + streamMusicCodec: Value(streamMusicCodec), + downloadMusicCodec: Value(downloadMusicCodec), + discordPresence: Value(discordPresence), + endlessPlayback: Value(endlessPlayback), + enableConnect: Value(enableConnect), + ); + } + + factory PreferencesTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return PreferencesTableData( + id: serializer.fromJson(json['id']), + audioQuality: serializer.fromJson(json['audioQuality']), + albumColorSync: serializer.fromJson(json['albumColorSync']), + amoledDarkTheme: serializer.fromJson(json['amoledDarkTheme']), + checkUpdate: serializer.fromJson(json['checkUpdate']), + normalizeAudio: serializer.fromJson(json['normalizeAudio']), + showSystemTrayIcon: serializer.fromJson(json['showSystemTrayIcon']), + systemTitleBar: serializer.fromJson(json['systemTitleBar']), + skipNonMusic: serializer.fromJson(json['skipNonMusic']), + closeBehavior: serializer.fromJson(json['closeBehavior']), + accentColorScheme: serializer.fromJson(json['accentColorScheme']), + layoutMode: serializer.fromJson(json['layoutMode']), + locale: serializer.fromJson(json['locale']), + market: serializer.fromJson(json['market']), + searchMode: serializer.fromJson(json['searchMode']), + downloadLocation: serializer.fromJson(json['downloadLocation']), + localLibraryLocation: + serializer.fromJson(json['localLibraryLocation']), + pipedInstance: serializer.fromJson(json['pipedInstance']), + invidiousInstance: serializer.fromJson(json['invidiousInstance']), + themeMode: serializer.fromJson(json['themeMode']), + audioSource: serializer.fromJson(json['audioSource']), + streamMusicCodec: serializer.fromJson(json['streamMusicCodec']), + downloadMusicCodec: + serializer.fromJson(json['downloadMusicCodec']), + discordPresence: serializer.fromJson(json['discordPresence']), + endlessPlayback: serializer.fromJson(json['endlessPlayback']), + enableConnect: serializer.fromJson(json['enableConnect']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'audioQuality': serializer.toJson(audioQuality), + 'albumColorSync': serializer.toJson(albumColorSync), + 'amoledDarkTheme': serializer.toJson(amoledDarkTheme), + 'checkUpdate': serializer.toJson(checkUpdate), + 'normalizeAudio': serializer.toJson(normalizeAudio), + 'showSystemTrayIcon': serializer.toJson(showSystemTrayIcon), + 'systemTitleBar': serializer.toJson(systemTitleBar), + 'skipNonMusic': serializer.toJson(skipNonMusic), + 'closeBehavior': serializer.toJson(closeBehavior), + 'accentColorScheme': serializer.toJson(accentColorScheme), + 'layoutMode': serializer.toJson(layoutMode), + 'locale': serializer.toJson(locale), + 'market': serializer.toJson(market), + 'searchMode': serializer.toJson(searchMode), + 'downloadLocation': serializer.toJson(downloadLocation), + 'localLibraryLocation': serializer.toJson(localLibraryLocation), + 'pipedInstance': serializer.toJson(pipedInstance), + 'invidiousInstance': serializer.toJson(invidiousInstance), + 'themeMode': serializer.toJson(themeMode), + 'audioSource': serializer.toJson(audioSource), + 'streamMusicCodec': serializer.toJson(streamMusicCodec), + 'downloadMusicCodec': serializer.toJson(downloadMusicCodec), + 'discordPresence': serializer.toJson(discordPresence), + 'endlessPlayback': serializer.toJson(endlessPlayback), + 'enableConnect': serializer.toJson(enableConnect), + }; + } + + PreferencesTableData copyWith( + {int? id, + String? audioQuality, + bool? albumColorSync, + bool? amoledDarkTheme, + bool? checkUpdate, + bool? normalizeAudio, + bool? showSystemTrayIcon, + bool? systemTitleBar, + bool? skipNonMusic, + String? closeBehavior, + String? accentColorScheme, + String? layoutMode, + String? locale, + String? market, + String? searchMode, + String? downloadLocation, + String? localLibraryLocation, + String? pipedInstance, + String? invidiousInstance, + String? themeMode, + String? audioSource, + String? streamMusicCodec, + String? downloadMusicCodec, + bool? discordPresence, + bool? endlessPlayback, + bool? enableConnect}) => + PreferencesTableData( + id: id ?? this.id, + audioQuality: audioQuality ?? this.audioQuality, + albumColorSync: albumColorSync ?? this.albumColorSync, + amoledDarkTheme: amoledDarkTheme ?? this.amoledDarkTheme, + checkUpdate: checkUpdate ?? this.checkUpdate, + normalizeAudio: normalizeAudio ?? this.normalizeAudio, + showSystemTrayIcon: showSystemTrayIcon ?? this.showSystemTrayIcon, + systemTitleBar: systemTitleBar ?? this.systemTitleBar, + skipNonMusic: skipNonMusic ?? this.skipNonMusic, + closeBehavior: closeBehavior ?? this.closeBehavior, + accentColorScheme: accentColorScheme ?? this.accentColorScheme, + layoutMode: layoutMode ?? this.layoutMode, + locale: locale ?? this.locale, + market: market ?? this.market, + searchMode: searchMode ?? this.searchMode, + downloadLocation: downloadLocation ?? this.downloadLocation, + localLibraryLocation: localLibraryLocation ?? this.localLibraryLocation, + pipedInstance: pipedInstance ?? this.pipedInstance, + invidiousInstance: invidiousInstance ?? this.invidiousInstance, + themeMode: themeMode ?? this.themeMode, + audioSource: audioSource ?? this.audioSource, + streamMusicCodec: streamMusicCodec ?? this.streamMusicCodec, + downloadMusicCodec: downloadMusicCodec ?? this.downloadMusicCodec, + discordPresence: discordPresence ?? this.discordPresence, + endlessPlayback: endlessPlayback ?? this.endlessPlayback, + enableConnect: enableConnect ?? this.enableConnect, + ); + PreferencesTableData copyWithCompanion(PreferencesTableCompanion data) { + return PreferencesTableData( + id: data.id.present ? data.id.value : this.id, + audioQuality: data.audioQuality.present + ? data.audioQuality.value + : this.audioQuality, + albumColorSync: data.albumColorSync.present + ? data.albumColorSync.value + : this.albumColorSync, + amoledDarkTheme: data.amoledDarkTheme.present + ? data.amoledDarkTheme.value + : this.amoledDarkTheme, + checkUpdate: + data.checkUpdate.present ? data.checkUpdate.value : this.checkUpdate, + normalizeAudio: data.normalizeAudio.present + ? data.normalizeAudio.value + : this.normalizeAudio, + showSystemTrayIcon: data.showSystemTrayIcon.present + ? data.showSystemTrayIcon.value + : this.showSystemTrayIcon, + systemTitleBar: data.systemTitleBar.present + ? data.systemTitleBar.value + : this.systemTitleBar, + skipNonMusic: data.skipNonMusic.present + ? data.skipNonMusic.value + : this.skipNonMusic, + closeBehavior: data.closeBehavior.present + ? data.closeBehavior.value + : this.closeBehavior, + accentColorScheme: data.accentColorScheme.present + ? data.accentColorScheme.value + : this.accentColorScheme, + layoutMode: + data.layoutMode.present ? data.layoutMode.value : this.layoutMode, + locale: data.locale.present ? data.locale.value : this.locale, + market: data.market.present ? data.market.value : this.market, + searchMode: + data.searchMode.present ? data.searchMode.value : this.searchMode, + downloadLocation: data.downloadLocation.present + ? data.downloadLocation.value + : this.downloadLocation, + localLibraryLocation: data.localLibraryLocation.present + ? data.localLibraryLocation.value + : this.localLibraryLocation, + pipedInstance: data.pipedInstance.present + ? data.pipedInstance.value + : this.pipedInstance, + invidiousInstance: data.invidiousInstance.present + ? data.invidiousInstance.value + : this.invidiousInstance, + themeMode: data.themeMode.present ? data.themeMode.value : this.themeMode, + audioSource: + data.audioSource.present ? data.audioSource.value : this.audioSource, + streamMusicCodec: data.streamMusicCodec.present + ? data.streamMusicCodec.value + : this.streamMusicCodec, + downloadMusicCodec: data.downloadMusicCodec.present + ? data.downloadMusicCodec.value + : this.downloadMusicCodec, + discordPresence: data.discordPresence.present + ? data.discordPresence.value + : this.discordPresence, + endlessPlayback: data.endlessPlayback.present + ? data.endlessPlayback.value + : this.endlessPlayback, + enableConnect: data.enableConnect.present + ? data.enableConnect.value + : this.enableConnect, + ); + } + + @override + String toString() { + return (StringBuffer('PreferencesTableData(') + ..write('id: $id, ') + ..write('audioQuality: $audioQuality, ') + ..write('albumColorSync: $albumColorSync, ') + ..write('amoledDarkTheme: $amoledDarkTheme, ') + ..write('checkUpdate: $checkUpdate, ') + ..write('normalizeAudio: $normalizeAudio, ') + ..write('showSystemTrayIcon: $showSystemTrayIcon, ') + ..write('systemTitleBar: $systemTitleBar, ') + ..write('skipNonMusic: $skipNonMusic, ') + ..write('closeBehavior: $closeBehavior, ') + ..write('accentColorScheme: $accentColorScheme, ') + ..write('layoutMode: $layoutMode, ') + ..write('locale: $locale, ') + ..write('market: $market, ') + ..write('searchMode: $searchMode, ') + ..write('downloadLocation: $downloadLocation, ') + ..write('localLibraryLocation: $localLibraryLocation, ') + ..write('pipedInstance: $pipedInstance, ') + ..write('invidiousInstance: $invidiousInstance, ') + ..write('themeMode: $themeMode, ') + ..write('audioSource: $audioSource, ') + ..write('streamMusicCodec: $streamMusicCodec, ') + ..write('downloadMusicCodec: $downloadMusicCodec, ') + ..write('discordPresence: $discordPresence, ') + ..write('endlessPlayback: $endlessPlayback, ') + ..write('enableConnect: $enableConnect') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hashAll([ + id, + audioQuality, + albumColorSync, + amoledDarkTheme, + checkUpdate, + normalizeAudio, + showSystemTrayIcon, + systemTitleBar, + skipNonMusic, + closeBehavior, + accentColorScheme, + layoutMode, + locale, + market, + searchMode, + downloadLocation, + localLibraryLocation, + pipedInstance, + invidiousInstance, + themeMode, + audioSource, + streamMusicCodec, + downloadMusicCodec, + discordPresence, + endlessPlayback, + enableConnect + ]); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is PreferencesTableData && + other.id == this.id && + other.audioQuality == this.audioQuality && + other.albumColorSync == this.albumColorSync && + other.amoledDarkTheme == this.amoledDarkTheme && + other.checkUpdate == this.checkUpdate && + other.normalizeAudio == this.normalizeAudio && + other.showSystemTrayIcon == this.showSystemTrayIcon && + other.systemTitleBar == this.systemTitleBar && + other.skipNonMusic == this.skipNonMusic && + other.closeBehavior == this.closeBehavior && + other.accentColorScheme == this.accentColorScheme && + other.layoutMode == this.layoutMode && + other.locale == this.locale && + other.market == this.market && + other.searchMode == this.searchMode && + other.downloadLocation == this.downloadLocation && + other.localLibraryLocation == this.localLibraryLocation && + other.pipedInstance == this.pipedInstance && + other.invidiousInstance == this.invidiousInstance && + other.themeMode == this.themeMode && + other.audioSource == this.audioSource && + other.streamMusicCodec == this.streamMusicCodec && + other.downloadMusicCodec == this.downloadMusicCodec && + other.discordPresence == this.discordPresence && + other.endlessPlayback == this.endlessPlayback && + other.enableConnect == this.enableConnect); +} + +class PreferencesTableCompanion extends UpdateCompanion { + final Value id; + final Value audioQuality; + final Value albumColorSync; + final Value amoledDarkTheme; + final Value checkUpdate; + final Value normalizeAudio; + final Value showSystemTrayIcon; + final Value systemTitleBar; + final Value skipNonMusic; + final Value closeBehavior; + final Value accentColorScheme; + final Value layoutMode; + final Value locale; + final Value market; + final Value searchMode; + final Value downloadLocation; + final Value localLibraryLocation; + final Value pipedInstance; + final Value invidiousInstance; + final Value themeMode; + final Value audioSource; + final Value streamMusicCodec; + final Value downloadMusicCodec; + final Value discordPresence; + final Value endlessPlayback; + final Value enableConnect; + const PreferencesTableCompanion({ + this.id = const Value.absent(), + this.audioQuality = const Value.absent(), + this.albumColorSync = const Value.absent(), + this.amoledDarkTheme = const Value.absent(), + this.checkUpdate = const Value.absent(), + this.normalizeAudio = const Value.absent(), + this.showSystemTrayIcon = const Value.absent(), + this.systemTitleBar = const Value.absent(), + this.skipNonMusic = const Value.absent(), + this.closeBehavior = const Value.absent(), + this.accentColorScheme = const Value.absent(), + this.layoutMode = const Value.absent(), + this.locale = const Value.absent(), + this.market = const Value.absent(), + this.searchMode = const Value.absent(), + this.downloadLocation = const Value.absent(), + this.localLibraryLocation = const Value.absent(), + this.pipedInstance = const Value.absent(), + this.invidiousInstance = const Value.absent(), + this.themeMode = const Value.absent(), + this.audioSource = const Value.absent(), + this.streamMusicCodec = const Value.absent(), + this.downloadMusicCodec = const Value.absent(), + this.discordPresence = const Value.absent(), + this.endlessPlayback = const Value.absent(), + this.enableConnect = const Value.absent(), + }); + PreferencesTableCompanion.insert({ + this.id = const Value.absent(), + this.audioQuality = const Value.absent(), + this.albumColorSync = const Value.absent(), + this.amoledDarkTheme = const Value.absent(), + this.checkUpdate = const Value.absent(), + this.normalizeAudio = const Value.absent(), + this.showSystemTrayIcon = const Value.absent(), + this.systemTitleBar = const Value.absent(), + this.skipNonMusic = const Value.absent(), + this.closeBehavior = const Value.absent(), + this.accentColorScheme = const Value.absent(), + this.layoutMode = const Value.absent(), + this.locale = const Value.absent(), + this.market = const Value.absent(), + this.searchMode = const Value.absent(), + this.downloadLocation = const Value.absent(), + this.localLibraryLocation = const Value.absent(), + this.pipedInstance = const Value.absent(), + this.invidiousInstance = const Value.absent(), + this.themeMode = const Value.absent(), + this.audioSource = const Value.absent(), + this.streamMusicCodec = const Value.absent(), + this.downloadMusicCodec = const Value.absent(), + this.discordPresence = const Value.absent(), + this.endlessPlayback = const Value.absent(), + this.enableConnect = const Value.absent(), + }); + static Insertable custom({ + Expression? id, + Expression? audioQuality, + Expression? albumColorSync, + Expression? amoledDarkTheme, + Expression? checkUpdate, + Expression? normalizeAudio, + Expression? showSystemTrayIcon, + Expression? systemTitleBar, + Expression? skipNonMusic, + Expression? closeBehavior, + Expression? accentColorScheme, + Expression? layoutMode, + Expression? locale, + Expression? market, + Expression? searchMode, + Expression? downloadLocation, + Expression? localLibraryLocation, + Expression? pipedInstance, + Expression? invidiousInstance, + Expression? themeMode, + Expression? audioSource, + Expression? streamMusicCodec, + Expression? downloadMusicCodec, + Expression? discordPresence, + Expression? endlessPlayback, + Expression? enableConnect, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (audioQuality != null) 'audio_quality': audioQuality, + if (albumColorSync != null) 'album_color_sync': albumColorSync, + if (amoledDarkTheme != null) 'amoled_dark_theme': amoledDarkTheme, + if (checkUpdate != null) 'check_update': checkUpdate, + if (normalizeAudio != null) 'normalize_audio': normalizeAudio, + if (showSystemTrayIcon != null) + 'show_system_tray_icon': showSystemTrayIcon, + if (systemTitleBar != null) 'system_title_bar': systemTitleBar, + if (skipNonMusic != null) 'skip_non_music': skipNonMusic, + if (closeBehavior != null) 'close_behavior': closeBehavior, + if (accentColorScheme != null) 'accent_color_scheme': accentColorScheme, + if (layoutMode != null) 'layout_mode': layoutMode, + if (locale != null) 'locale': locale, + if (market != null) 'market': market, + if (searchMode != null) 'search_mode': searchMode, + if (downloadLocation != null) 'download_location': downloadLocation, + if (localLibraryLocation != null) + 'local_library_location': localLibraryLocation, + if (pipedInstance != null) 'piped_instance': pipedInstance, + if (invidiousInstance != null) 'invidious_instance': invidiousInstance, + if (themeMode != null) 'theme_mode': themeMode, + if (audioSource != null) 'audio_source': audioSource, + if (streamMusicCodec != null) 'stream_music_codec': streamMusicCodec, + if (downloadMusicCodec != null) + 'download_music_codec': downloadMusicCodec, + if (discordPresence != null) 'discord_presence': discordPresence, + if (endlessPlayback != null) 'endless_playback': endlessPlayback, + if (enableConnect != null) 'enable_connect': enableConnect, + }); + } + + PreferencesTableCompanion copyWith( + {Value? id, + Value? audioQuality, + Value? albumColorSync, + Value? amoledDarkTheme, + Value? checkUpdate, + Value? normalizeAudio, + Value? showSystemTrayIcon, + Value? systemTitleBar, + Value? skipNonMusic, + Value? closeBehavior, + Value? accentColorScheme, + Value? layoutMode, + Value? locale, + Value? market, + Value? searchMode, + Value? downloadLocation, + Value? localLibraryLocation, + Value? pipedInstance, + Value? invidiousInstance, + Value? themeMode, + Value? audioSource, + Value? streamMusicCodec, + Value? downloadMusicCodec, + Value? discordPresence, + Value? endlessPlayback, + Value? enableConnect}) { + return PreferencesTableCompanion( + id: id ?? this.id, + audioQuality: audioQuality ?? this.audioQuality, + albumColorSync: albumColorSync ?? this.albumColorSync, + amoledDarkTheme: amoledDarkTheme ?? this.amoledDarkTheme, + checkUpdate: checkUpdate ?? this.checkUpdate, + normalizeAudio: normalizeAudio ?? this.normalizeAudio, + showSystemTrayIcon: showSystemTrayIcon ?? this.showSystemTrayIcon, + systemTitleBar: systemTitleBar ?? this.systemTitleBar, + skipNonMusic: skipNonMusic ?? this.skipNonMusic, + closeBehavior: closeBehavior ?? this.closeBehavior, + accentColorScheme: accentColorScheme ?? this.accentColorScheme, + layoutMode: layoutMode ?? this.layoutMode, + locale: locale ?? this.locale, + market: market ?? this.market, + searchMode: searchMode ?? this.searchMode, + downloadLocation: downloadLocation ?? this.downloadLocation, + localLibraryLocation: localLibraryLocation ?? this.localLibraryLocation, + pipedInstance: pipedInstance ?? this.pipedInstance, + invidiousInstance: invidiousInstance ?? this.invidiousInstance, + themeMode: themeMode ?? this.themeMode, + audioSource: audioSource ?? this.audioSource, + streamMusicCodec: streamMusicCodec ?? this.streamMusicCodec, + downloadMusicCodec: downloadMusicCodec ?? this.downloadMusicCodec, + discordPresence: discordPresence ?? this.discordPresence, + endlessPlayback: endlessPlayback ?? this.endlessPlayback, + enableConnect: enableConnect ?? this.enableConnect, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (audioQuality.present) { + map['audio_quality'] = Variable(audioQuality.value); + } + if (albumColorSync.present) { + map['album_color_sync'] = Variable(albumColorSync.value); + } + if (amoledDarkTheme.present) { + map['amoled_dark_theme'] = Variable(amoledDarkTheme.value); + } + if (checkUpdate.present) { + map['check_update'] = Variable(checkUpdate.value); + } + if (normalizeAudio.present) { + map['normalize_audio'] = Variable(normalizeAudio.value); + } + if (showSystemTrayIcon.present) { + map['show_system_tray_icon'] = Variable(showSystemTrayIcon.value); + } + if (systemTitleBar.present) { + map['system_title_bar'] = Variable(systemTitleBar.value); + } + if (skipNonMusic.present) { + map['skip_non_music'] = Variable(skipNonMusic.value); + } + if (closeBehavior.present) { + map['close_behavior'] = Variable(closeBehavior.value); + } + if (accentColorScheme.present) { + map['accent_color_scheme'] = Variable(accentColorScheme.value); + } + if (layoutMode.present) { + map['layout_mode'] = Variable(layoutMode.value); + } + if (locale.present) { + map['locale'] = Variable(locale.value); + } + if (market.present) { + map['market'] = Variable(market.value); + } + if (searchMode.present) { + map['search_mode'] = Variable(searchMode.value); + } + if (downloadLocation.present) { + map['download_location'] = Variable(downloadLocation.value); + } + if (localLibraryLocation.present) { + map['local_library_location'] = + Variable(localLibraryLocation.value); + } + if (pipedInstance.present) { + map['piped_instance'] = Variable(pipedInstance.value); + } + if (invidiousInstance.present) { + map['invidious_instance'] = Variable(invidiousInstance.value); + } + if (themeMode.present) { + map['theme_mode'] = Variable(themeMode.value); + } + if (audioSource.present) { + map['audio_source'] = Variable(audioSource.value); + } + if (streamMusicCodec.present) { + map['stream_music_codec'] = Variable(streamMusicCodec.value); + } + if (downloadMusicCodec.present) { + map['download_music_codec'] = Variable(downloadMusicCodec.value); + } + if (discordPresence.present) { + map['discord_presence'] = Variable(discordPresence.value); + } + if (endlessPlayback.present) { + map['endless_playback'] = Variable(endlessPlayback.value); + } + if (enableConnect.present) { + map['enable_connect'] = Variable(enableConnect.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('PreferencesTableCompanion(') + ..write('id: $id, ') + ..write('audioQuality: $audioQuality, ') + ..write('albumColorSync: $albumColorSync, ') + ..write('amoledDarkTheme: $amoledDarkTheme, ') + ..write('checkUpdate: $checkUpdate, ') + ..write('normalizeAudio: $normalizeAudio, ') + ..write('showSystemTrayIcon: $showSystemTrayIcon, ') + ..write('systemTitleBar: $systemTitleBar, ') + ..write('skipNonMusic: $skipNonMusic, ') + ..write('closeBehavior: $closeBehavior, ') + ..write('accentColorScheme: $accentColorScheme, ') + ..write('layoutMode: $layoutMode, ') + ..write('locale: $locale, ') + ..write('market: $market, ') + ..write('searchMode: $searchMode, ') + ..write('downloadLocation: $downloadLocation, ') + ..write('localLibraryLocation: $localLibraryLocation, ') + ..write('pipedInstance: $pipedInstance, ') + ..write('invidiousInstance: $invidiousInstance, ') + ..write('themeMode: $themeMode, ') + ..write('audioSource: $audioSource, ') + ..write('streamMusicCodec: $streamMusicCodec, ') + ..write('downloadMusicCodec: $downloadMusicCodec, ') + ..write('discordPresence: $discordPresence, ') + ..write('endlessPlayback: $endlessPlayback, ') + ..write('enableConnect: $enableConnect') + ..write(')')) + .toString(); + } +} + +class ScrobblerTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + ScrobblerTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn createdAt = GeneratedColumn( + 'created_at', aliasedName, false, + type: DriftSqlType.dateTime, + requiredDuringInsert: false, + defaultValue: currentDateAndTime); + late final GeneratedColumn username = GeneratedColumn( + 'username', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn passwordHash = GeneratedColumn( + 'password_hash', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + @override + List get $columns => [id, createdAt, username, passwordHash]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'scrobbler_table'; + @override + Set get $primaryKey => {id}; + @override + ScrobblerTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return ScrobblerTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + createdAt: attachedDatabase.typeMapping + .read(DriftSqlType.dateTime, data['${effectivePrefix}created_at'])!, + username: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}username'])!, + passwordHash: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}password_hash'])!, + ); + } + + @override + ScrobblerTable createAlias(String alias) { + return ScrobblerTable(attachedDatabase, alias); + } +} + +class ScrobblerTableData extends DataClass + implements Insertable { + final int id; + final DateTime createdAt; + final String username; + final String passwordHash; + const ScrobblerTableData( + {required this.id, + required this.createdAt, + required this.username, + required this.passwordHash}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['created_at'] = Variable(createdAt); + map['username'] = Variable(username); + map['password_hash'] = Variable(passwordHash); + return map; + } + + ScrobblerTableCompanion toCompanion(bool nullToAbsent) { + return ScrobblerTableCompanion( + id: Value(id), + createdAt: Value(createdAt), + username: Value(username), + passwordHash: Value(passwordHash), + ); + } + + factory ScrobblerTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return ScrobblerTableData( + id: serializer.fromJson(json['id']), + createdAt: serializer.fromJson(json['createdAt']), + username: serializer.fromJson(json['username']), + passwordHash: serializer.fromJson(json['passwordHash']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'createdAt': serializer.toJson(createdAt), + 'username': serializer.toJson(username), + 'passwordHash': serializer.toJson(passwordHash), + }; + } + + ScrobblerTableData copyWith( + {int? id, + DateTime? createdAt, + String? username, + String? passwordHash}) => + ScrobblerTableData( + id: id ?? this.id, + createdAt: createdAt ?? this.createdAt, + username: username ?? this.username, + passwordHash: passwordHash ?? this.passwordHash, + ); + ScrobblerTableData copyWithCompanion(ScrobblerTableCompanion data) { + return ScrobblerTableData( + id: data.id.present ? data.id.value : this.id, + createdAt: data.createdAt.present ? data.createdAt.value : this.createdAt, + username: data.username.present ? data.username.value : this.username, + passwordHash: data.passwordHash.present + ? data.passwordHash.value + : this.passwordHash, + ); + } + + @override + String toString() { + return (StringBuffer('ScrobblerTableData(') + ..write('id: $id, ') + ..write('createdAt: $createdAt, ') + ..write('username: $username, ') + ..write('passwordHash: $passwordHash') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, createdAt, username, passwordHash); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is ScrobblerTableData && + other.id == this.id && + other.createdAt == this.createdAt && + other.username == this.username && + other.passwordHash == this.passwordHash); +} + +class ScrobblerTableCompanion extends UpdateCompanion { + final Value id; + final Value createdAt; + final Value username; + final Value passwordHash; + const ScrobblerTableCompanion({ + this.id = const Value.absent(), + this.createdAt = const Value.absent(), + this.username = const Value.absent(), + this.passwordHash = const Value.absent(), + }); + ScrobblerTableCompanion.insert({ + this.id = const Value.absent(), + this.createdAt = const Value.absent(), + required String username, + required String passwordHash, + }) : username = Value(username), + passwordHash = Value(passwordHash); + static Insertable custom({ + Expression? id, + Expression? createdAt, + Expression? username, + Expression? passwordHash, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (createdAt != null) 'created_at': createdAt, + if (username != null) 'username': username, + if (passwordHash != null) 'password_hash': passwordHash, + }); + } + + ScrobblerTableCompanion copyWith( + {Value? id, + Value? createdAt, + Value? username, + Value? passwordHash}) { + return ScrobblerTableCompanion( + id: id ?? this.id, + createdAt: createdAt ?? this.createdAt, + username: username ?? this.username, + passwordHash: passwordHash ?? this.passwordHash, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (createdAt.present) { + map['created_at'] = Variable(createdAt.value); + } + if (username.present) { + map['username'] = Variable(username.value); + } + if (passwordHash.present) { + map['password_hash'] = Variable(passwordHash.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('ScrobblerTableCompanion(') + ..write('id: $id, ') + ..write('createdAt: $createdAt, ') + ..write('username: $username, ') + ..write('passwordHash: $passwordHash') + ..write(')')) + .toString(); + } +} + +class SkipSegmentTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + SkipSegmentTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn start = GeneratedColumn( + 'start', aliasedName, false, + type: DriftSqlType.int, requiredDuringInsert: true); + late final GeneratedColumn end = GeneratedColumn( + 'end', aliasedName, false, + type: DriftSqlType.int, requiredDuringInsert: true); + late final GeneratedColumn trackId = GeneratedColumn( + 'track_id', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn createdAt = GeneratedColumn( + 'created_at', aliasedName, false, + type: DriftSqlType.dateTime, + requiredDuringInsert: false, + defaultValue: currentDateAndTime); + @override + List get $columns => [id, start, end, trackId, createdAt]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'skip_segment_table'; + @override + Set get $primaryKey => {id}; + @override + SkipSegmentTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return SkipSegmentTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + start: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}start'])!, + end: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}end'])!, + trackId: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}track_id'])!, + createdAt: attachedDatabase.typeMapping + .read(DriftSqlType.dateTime, data['${effectivePrefix}created_at'])!, + ); + } + + @override + SkipSegmentTable createAlias(String alias) { + return SkipSegmentTable(attachedDatabase, alias); + } +} + +class SkipSegmentTableData extends DataClass + implements Insertable { + final int id; + final int start; + final int end; + final String trackId; + final DateTime createdAt; + const SkipSegmentTableData( + {required this.id, + required this.start, + required this.end, + required this.trackId, + required this.createdAt}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['start'] = Variable(start); + map['end'] = Variable(end); + map['track_id'] = Variable(trackId); + map['created_at'] = Variable(createdAt); + return map; + } + + SkipSegmentTableCompanion toCompanion(bool nullToAbsent) { + return SkipSegmentTableCompanion( + id: Value(id), + start: Value(start), + end: Value(end), + trackId: Value(trackId), + createdAt: Value(createdAt), + ); + } + + factory SkipSegmentTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return SkipSegmentTableData( + id: serializer.fromJson(json['id']), + start: serializer.fromJson(json['start']), + end: serializer.fromJson(json['end']), + trackId: serializer.fromJson(json['trackId']), + createdAt: serializer.fromJson(json['createdAt']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'start': serializer.toJson(start), + 'end': serializer.toJson(end), + 'trackId': serializer.toJson(trackId), + 'createdAt': serializer.toJson(createdAt), + }; + } + + SkipSegmentTableData copyWith( + {int? id, + int? start, + int? end, + String? trackId, + DateTime? createdAt}) => + SkipSegmentTableData( + id: id ?? this.id, + start: start ?? this.start, + end: end ?? this.end, + trackId: trackId ?? this.trackId, + createdAt: createdAt ?? this.createdAt, + ); + SkipSegmentTableData copyWithCompanion(SkipSegmentTableCompanion data) { + return SkipSegmentTableData( + id: data.id.present ? data.id.value : this.id, + start: data.start.present ? data.start.value : this.start, + end: data.end.present ? data.end.value : this.end, + trackId: data.trackId.present ? data.trackId.value : this.trackId, + createdAt: data.createdAt.present ? data.createdAt.value : this.createdAt, + ); + } + + @override + String toString() { + return (StringBuffer('SkipSegmentTableData(') + ..write('id: $id, ') + ..write('start: $start, ') + ..write('end: $end, ') + ..write('trackId: $trackId, ') + ..write('createdAt: $createdAt') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, start, end, trackId, createdAt); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is SkipSegmentTableData && + other.id == this.id && + other.start == this.start && + other.end == this.end && + other.trackId == this.trackId && + other.createdAt == this.createdAt); +} + +class SkipSegmentTableCompanion extends UpdateCompanion { + final Value id; + final Value start; + final Value end; + final Value trackId; + final Value createdAt; + const SkipSegmentTableCompanion({ + this.id = const Value.absent(), + this.start = const Value.absent(), + this.end = const Value.absent(), + this.trackId = const Value.absent(), + this.createdAt = const Value.absent(), + }); + SkipSegmentTableCompanion.insert({ + this.id = const Value.absent(), + required int start, + required int end, + required String trackId, + this.createdAt = const Value.absent(), + }) : start = Value(start), + end = Value(end), + trackId = Value(trackId); + static Insertable custom({ + Expression? id, + Expression? start, + Expression? end, + Expression? trackId, + Expression? createdAt, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (start != null) 'start': start, + if (end != null) 'end': end, + if (trackId != null) 'track_id': trackId, + if (createdAt != null) 'created_at': createdAt, + }); + } + + SkipSegmentTableCompanion copyWith( + {Value? id, + Value? start, + Value? end, + Value? trackId, + Value? createdAt}) { + return SkipSegmentTableCompanion( + id: id ?? this.id, + start: start ?? this.start, + end: end ?? this.end, + trackId: trackId ?? this.trackId, + createdAt: createdAt ?? this.createdAt, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (start.present) { + map['start'] = Variable(start.value); + } + if (end.present) { + map['end'] = Variable(end.value); + } + if (trackId.present) { + map['track_id'] = Variable(trackId.value); + } + if (createdAt.present) { + map['created_at'] = Variable(createdAt.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('SkipSegmentTableCompanion(') + ..write('id: $id, ') + ..write('start: $start, ') + ..write('end: $end, ') + ..write('trackId: $trackId, ') + ..write('createdAt: $createdAt') + ..write(')')) + .toString(); + } +} + +class SourceMatchTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + SourceMatchTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn trackId = GeneratedColumn( + 'track_id', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn sourceId = GeneratedColumn( + 'source_id', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn sourceType = GeneratedColumn( + 'source_type', aliasedName, false, + type: DriftSqlType.string, + requiredDuringInsert: false, + defaultValue: Constant(SourceType.youtube.name)); + late final GeneratedColumn createdAt = GeneratedColumn( + 'created_at', aliasedName, false, + type: DriftSqlType.dateTime, + requiredDuringInsert: false, + defaultValue: currentDateAndTime); + @override + List get $columns => + [id, trackId, sourceId, sourceType, createdAt]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'source_match_table'; + @override + Set get $primaryKey => {id}; + @override + SourceMatchTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return SourceMatchTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + trackId: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}track_id'])!, + sourceId: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}source_id'])!, + sourceType: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}source_type'])!, + createdAt: attachedDatabase.typeMapping + .read(DriftSqlType.dateTime, data['${effectivePrefix}created_at'])!, + ); + } + + @override + SourceMatchTable createAlias(String alias) { + return SourceMatchTable(attachedDatabase, alias); + } +} + +class SourceMatchTableData extends DataClass + implements Insertable { + final int id; + final String trackId; + final String sourceId; + final String sourceType; + final DateTime createdAt; + const SourceMatchTableData( + {required this.id, + required this.trackId, + required this.sourceId, + required this.sourceType, + required this.createdAt}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['track_id'] = Variable(trackId); + map['source_id'] = Variable(sourceId); + map['source_type'] = Variable(sourceType); + map['created_at'] = Variable(createdAt); + return map; + } + + SourceMatchTableCompanion toCompanion(bool nullToAbsent) { + return SourceMatchTableCompanion( + id: Value(id), + trackId: Value(trackId), + sourceId: Value(sourceId), + sourceType: Value(sourceType), + createdAt: Value(createdAt), + ); + } + + factory SourceMatchTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return SourceMatchTableData( + id: serializer.fromJson(json['id']), + trackId: serializer.fromJson(json['trackId']), + sourceId: serializer.fromJson(json['sourceId']), + sourceType: serializer.fromJson(json['sourceType']), + createdAt: serializer.fromJson(json['createdAt']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'trackId': serializer.toJson(trackId), + 'sourceId': serializer.toJson(sourceId), + 'sourceType': serializer.toJson(sourceType), + 'createdAt': serializer.toJson(createdAt), + }; + } + + SourceMatchTableData copyWith( + {int? id, + String? trackId, + String? sourceId, + String? sourceType, + DateTime? createdAt}) => + SourceMatchTableData( + id: id ?? this.id, + trackId: trackId ?? this.trackId, + sourceId: sourceId ?? this.sourceId, + sourceType: sourceType ?? this.sourceType, + createdAt: createdAt ?? this.createdAt, + ); + SourceMatchTableData copyWithCompanion(SourceMatchTableCompanion data) { + return SourceMatchTableData( + id: data.id.present ? data.id.value : this.id, + trackId: data.trackId.present ? data.trackId.value : this.trackId, + sourceId: data.sourceId.present ? data.sourceId.value : this.sourceId, + sourceType: + data.sourceType.present ? data.sourceType.value : this.sourceType, + createdAt: data.createdAt.present ? data.createdAt.value : this.createdAt, + ); + } + + @override + String toString() { + return (StringBuffer('SourceMatchTableData(') + ..write('id: $id, ') + ..write('trackId: $trackId, ') + ..write('sourceId: $sourceId, ') + ..write('sourceType: $sourceType, ') + ..write('createdAt: $createdAt') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, trackId, sourceId, sourceType, createdAt); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is SourceMatchTableData && + other.id == this.id && + other.trackId == this.trackId && + other.sourceId == this.sourceId && + other.sourceType == this.sourceType && + other.createdAt == this.createdAt); +} + +class SourceMatchTableCompanion extends UpdateCompanion { + final Value id; + final Value trackId; + final Value sourceId; + final Value sourceType; + final Value createdAt; + const SourceMatchTableCompanion({ + this.id = const Value.absent(), + this.trackId = const Value.absent(), + this.sourceId = const Value.absent(), + this.sourceType = const Value.absent(), + this.createdAt = const Value.absent(), + }); + SourceMatchTableCompanion.insert({ + this.id = const Value.absent(), + required String trackId, + required String sourceId, + this.sourceType = const Value.absent(), + this.createdAt = const Value.absent(), + }) : trackId = Value(trackId), + sourceId = Value(sourceId); + static Insertable custom({ + Expression? id, + Expression? trackId, + Expression? sourceId, + Expression? sourceType, + Expression? createdAt, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (trackId != null) 'track_id': trackId, + if (sourceId != null) 'source_id': sourceId, + if (sourceType != null) 'source_type': sourceType, + if (createdAt != null) 'created_at': createdAt, + }); + } + + SourceMatchTableCompanion copyWith( + {Value? id, + Value? trackId, + Value? sourceId, + Value? sourceType, + Value? createdAt}) { + return SourceMatchTableCompanion( + id: id ?? this.id, + trackId: trackId ?? this.trackId, + sourceId: sourceId ?? this.sourceId, + sourceType: sourceType ?? this.sourceType, + createdAt: createdAt ?? this.createdAt, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (trackId.present) { + map['track_id'] = Variable(trackId.value); + } + if (sourceId.present) { + map['source_id'] = Variable(sourceId.value); + } + if (sourceType.present) { + map['source_type'] = Variable(sourceType.value); + } + if (createdAt.present) { + map['created_at'] = Variable(createdAt.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('SourceMatchTableCompanion(') + ..write('id: $id, ') + ..write('trackId: $trackId, ') + ..write('sourceId: $sourceId, ') + ..write('sourceType: $sourceType, ') + ..write('createdAt: $createdAt') + ..write(')')) + .toString(); + } +} + +class AudioPlayerStateTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + AudioPlayerStateTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn playing = GeneratedColumn( + 'playing', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: true, + defaultConstraints: + GeneratedColumn.constraintIsAlways('CHECK ("playing" IN (0, 1))')); + late final GeneratedColumn loopMode = GeneratedColumn( + 'loop_mode', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn shuffled = GeneratedColumn( + 'shuffled', aliasedName, false, + type: DriftSqlType.bool, + requiredDuringInsert: true, + defaultConstraints: + GeneratedColumn.constraintIsAlways('CHECK ("shuffled" IN (0, 1))')); + late final GeneratedColumn collections = GeneratedColumn( + 'collections', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + @override + List get $columns => + [id, playing, loopMode, shuffled, collections]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'audio_player_state_table'; + @override + Set get $primaryKey => {id}; + @override + AudioPlayerStateTableData map(Map data, + {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return AudioPlayerStateTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + playing: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}playing'])!, + loopMode: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}loop_mode'])!, + shuffled: attachedDatabase.typeMapping + .read(DriftSqlType.bool, data['${effectivePrefix}shuffled'])!, + collections: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}collections'])!, + ); + } + + @override + AudioPlayerStateTable createAlias(String alias) { + return AudioPlayerStateTable(attachedDatabase, alias); + } +} + +class AudioPlayerStateTableData extends DataClass + implements Insertable { + final int id; + final bool playing; + final String loopMode; + final bool shuffled; + final String collections; + const AudioPlayerStateTableData( + {required this.id, + required this.playing, + required this.loopMode, + required this.shuffled, + required this.collections}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['playing'] = Variable(playing); + map['loop_mode'] = Variable(loopMode); + map['shuffled'] = Variable(shuffled); + map['collections'] = Variable(collections); + return map; + } + + AudioPlayerStateTableCompanion toCompanion(bool nullToAbsent) { + return AudioPlayerStateTableCompanion( + id: Value(id), + playing: Value(playing), + loopMode: Value(loopMode), + shuffled: Value(shuffled), + collections: Value(collections), + ); + } + + factory AudioPlayerStateTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return AudioPlayerStateTableData( + id: serializer.fromJson(json['id']), + playing: serializer.fromJson(json['playing']), + loopMode: serializer.fromJson(json['loopMode']), + shuffled: serializer.fromJson(json['shuffled']), + collections: serializer.fromJson(json['collections']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'playing': serializer.toJson(playing), + 'loopMode': serializer.toJson(loopMode), + 'shuffled': serializer.toJson(shuffled), + 'collections': serializer.toJson(collections), + }; + } + + AudioPlayerStateTableData copyWith( + {int? id, + bool? playing, + String? loopMode, + bool? shuffled, + String? collections}) => + AudioPlayerStateTableData( + id: id ?? this.id, + playing: playing ?? this.playing, + loopMode: loopMode ?? this.loopMode, + shuffled: shuffled ?? this.shuffled, + collections: collections ?? this.collections, + ); + AudioPlayerStateTableData copyWithCompanion( + AudioPlayerStateTableCompanion data) { + return AudioPlayerStateTableData( + id: data.id.present ? data.id.value : this.id, + playing: data.playing.present ? data.playing.value : this.playing, + loopMode: data.loopMode.present ? data.loopMode.value : this.loopMode, + shuffled: data.shuffled.present ? data.shuffled.value : this.shuffled, + collections: + data.collections.present ? data.collections.value : this.collections, + ); + } + + @override + String toString() { + return (StringBuffer('AudioPlayerStateTableData(') + ..write('id: $id, ') + ..write('playing: $playing, ') + ..write('loopMode: $loopMode, ') + ..write('shuffled: $shuffled, ') + ..write('collections: $collections') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, playing, loopMode, shuffled, collections); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is AudioPlayerStateTableData && + other.id == this.id && + other.playing == this.playing && + other.loopMode == this.loopMode && + other.shuffled == this.shuffled && + other.collections == this.collections); +} + +class AudioPlayerStateTableCompanion + extends UpdateCompanion { + final Value id; + final Value playing; + final Value loopMode; + final Value shuffled; + final Value collections; + const AudioPlayerStateTableCompanion({ + this.id = const Value.absent(), + this.playing = const Value.absent(), + this.loopMode = const Value.absent(), + this.shuffled = const Value.absent(), + this.collections = const Value.absent(), + }); + AudioPlayerStateTableCompanion.insert({ + this.id = const Value.absent(), + required bool playing, + required String loopMode, + required bool shuffled, + required String collections, + }) : playing = Value(playing), + loopMode = Value(loopMode), + shuffled = Value(shuffled), + collections = Value(collections); + static Insertable custom({ + Expression? id, + Expression? playing, + Expression? loopMode, + Expression? shuffled, + Expression? collections, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (playing != null) 'playing': playing, + if (loopMode != null) 'loop_mode': loopMode, + if (shuffled != null) 'shuffled': shuffled, + if (collections != null) 'collections': collections, + }); + } + + AudioPlayerStateTableCompanion copyWith( + {Value? id, + Value? playing, + Value? loopMode, + Value? shuffled, + Value? collections}) { + return AudioPlayerStateTableCompanion( + id: id ?? this.id, + playing: playing ?? this.playing, + loopMode: loopMode ?? this.loopMode, + shuffled: shuffled ?? this.shuffled, + collections: collections ?? this.collections, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (playing.present) { + map['playing'] = Variable(playing.value); + } + if (loopMode.present) { + map['loop_mode'] = Variable(loopMode.value); + } + if (shuffled.present) { + map['shuffled'] = Variable(shuffled.value); + } + if (collections.present) { + map['collections'] = Variable(collections.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('AudioPlayerStateTableCompanion(') + ..write('id: $id, ') + ..write('playing: $playing, ') + ..write('loopMode: $loopMode, ') + ..write('shuffled: $shuffled, ') + ..write('collections: $collections') + ..write(')')) + .toString(); + } +} + +class PlaylistTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + PlaylistTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn audioPlayerStateId = GeneratedColumn( + 'audio_player_state_id', aliasedName, false, + type: DriftSqlType.int, + requiredDuringInsert: true, + defaultConstraints: GeneratedColumn.constraintIsAlways( + 'REFERENCES audio_player_state_table (id)')); + late final GeneratedColumn index = GeneratedColumn( + 'index', aliasedName, false, + type: DriftSqlType.int, requiredDuringInsert: true); + @override + List get $columns => [id, audioPlayerStateId, index]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'playlist_table'; + @override + Set get $primaryKey => {id}; + @override + PlaylistTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return PlaylistTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + audioPlayerStateId: attachedDatabase.typeMapping.read( + DriftSqlType.int, data['${effectivePrefix}audio_player_state_id'])!, + index: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}index'])!, + ); + } + + @override + PlaylistTable createAlias(String alias) { + return PlaylistTable(attachedDatabase, alias); + } +} + +class PlaylistTableData extends DataClass + implements Insertable { + final int id; + final int audioPlayerStateId; + final int index; + const PlaylistTableData( + {required this.id, + required this.audioPlayerStateId, + required this.index}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['audio_player_state_id'] = Variable(audioPlayerStateId); + map['index'] = Variable(index); + return map; + } + + PlaylistTableCompanion toCompanion(bool nullToAbsent) { + return PlaylistTableCompanion( + id: Value(id), + audioPlayerStateId: Value(audioPlayerStateId), + index: Value(index), + ); + } + + factory PlaylistTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return PlaylistTableData( + id: serializer.fromJson(json['id']), + audioPlayerStateId: serializer.fromJson(json['audioPlayerStateId']), + index: serializer.fromJson(json['index']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'audioPlayerStateId': serializer.toJson(audioPlayerStateId), + 'index': serializer.toJson(index), + }; + } + + PlaylistTableData copyWith({int? id, int? audioPlayerStateId, int? index}) => + PlaylistTableData( + id: id ?? this.id, + audioPlayerStateId: audioPlayerStateId ?? this.audioPlayerStateId, + index: index ?? this.index, + ); + PlaylistTableData copyWithCompanion(PlaylistTableCompanion data) { + return PlaylistTableData( + id: data.id.present ? data.id.value : this.id, + audioPlayerStateId: data.audioPlayerStateId.present + ? data.audioPlayerStateId.value + : this.audioPlayerStateId, + index: data.index.present ? data.index.value : this.index, + ); + } + + @override + String toString() { + return (StringBuffer('PlaylistTableData(') + ..write('id: $id, ') + ..write('audioPlayerStateId: $audioPlayerStateId, ') + ..write('index: $index') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, audioPlayerStateId, index); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is PlaylistTableData && + other.id == this.id && + other.audioPlayerStateId == this.audioPlayerStateId && + other.index == this.index); +} + +class PlaylistTableCompanion extends UpdateCompanion { + final Value id; + final Value audioPlayerStateId; + final Value index; + const PlaylistTableCompanion({ + this.id = const Value.absent(), + this.audioPlayerStateId = const Value.absent(), + this.index = const Value.absent(), + }); + PlaylistTableCompanion.insert({ + this.id = const Value.absent(), + required int audioPlayerStateId, + required int index, + }) : audioPlayerStateId = Value(audioPlayerStateId), + index = Value(index); + static Insertable custom({ + Expression? id, + Expression? audioPlayerStateId, + Expression? index, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (audioPlayerStateId != null) + 'audio_player_state_id': audioPlayerStateId, + if (index != null) 'index': index, + }); + } + + PlaylistTableCompanion copyWith( + {Value? id, Value? audioPlayerStateId, Value? index}) { + return PlaylistTableCompanion( + id: id ?? this.id, + audioPlayerStateId: audioPlayerStateId ?? this.audioPlayerStateId, + index: index ?? this.index, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (audioPlayerStateId.present) { + map['audio_player_state_id'] = Variable(audioPlayerStateId.value); + } + if (index.present) { + map['index'] = Variable(index.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('PlaylistTableCompanion(') + ..write('id: $id, ') + ..write('audioPlayerStateId: $audioPlayerStateId, ') + ..write('index: $index') + ..write(')')) + .toString(); + } +} + +class PlaylistMediaTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + PlaylistMediaTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn playlistId = GeneratedColumn( + 'playlist_id', aliasedName, false, + type: DriftSqlType.int, + requiredDuringInsert: true, + defaultConstraints: + GeneratedColumn.constraintIsAlways('REFERENCES playlist_table (id)')); + late final GeneratedColumn uri = GeneratedColumn( + 'uri', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn extras = GeneratedColumn( + 'extras', aliasedName, true, + type: DriftSqlType.string, requiredDuringInsert: false); + late final GeneratedColumn httpHeaders = GeneratedColumn( + 'http_headers', aliasedName, true, + type: DriftSqlType.string, requiredDuringInsert: false); + @override + List get $columns => + [id, playlistId, uri, extras, httpHeaders]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'playlist_media_table'; + @override + Set get $primaryKey => {id}; + @override + PlaylistMediaTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return PlaylistMediaTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + playlistId: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}playlist_id'])!, + uri: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}uri'])!, + extras: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}extras']), + httpHeaders: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}http_headers']), + ); + } + + @override + PlaylistMediaTable createAlias(String alias) { + return PlaylistMediaTable(attachedDatabase, alias); + } +} + +class PlaylistMediaTableData extends DataClass + implements Insertable { + final int id; + final int playlistId; + final String uri; + final String? extras; + final String? httpHeaders; + const PlaylistMediaTableData( + {required this.id, + required this.playlistId, + required this.uri, + this.extras, + this.httpHeaders}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['playlist_id'] = Variable(playlistId); + map['uri'] = Variable(uri); + if (!nullToAbsent || extras != null) { + map['extras'] = Variable(extras); + } + if (!nullToAbsent || httpHeaders != null) { + map['http_headers'] = Variable(httpHeaders); + } + return map; + } + + PlaylistMediaTableCompanion toCompanion(bool nullToAbsent) { + return PlaylistMediaTableCompanion( + id: Value(id), + playlistId: Value(playlistId), + uri: Value(uri), + extras: + extras == null && nullToAbsent ? const Value.absent() : Value(extras), + httpHeaders: httpHeaders == null && nullToAbsent + ? const Value.absent() + : Value(httpHeaders), + ); + } + + factory PlaylistMediaTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return PlaylistMediaTableData( + id: serializer.fromJson(json['id']), + playlistId: serializer.fromJson(json['playlistId']), + uri: serializer.fromJson(json['uri']), + extras: serializer.fromJson(json['extras']), + httpHeaders: serializer.fromJson(json['httpHeaders']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'playlistId': serializer.toJson(playlistId), + 'uri': serializer.toJson(uri), + 'extras': serializer.toJson(extras), + 'httpHeaders': serializer.toJson(httpHeaders), + }; + } + + PlaylistMediaTableData copyWith( + {int? id, + int? playlistId, + String? uri, + Value extras = const Value.absent(), + Value httpHeaders = const Value.absent()}) => + PlaylistMediaTableData( + id: id ?? this.id, + playlistId: playlistId ?? this.playlistId, + uri: uri ?? this.uri, + extras: extras.present ? extras.value : this.extras, + httpHeaders: httpHeaders.present ? httpHeaders.value : this.httpHeaders, + ); + PlaylistMediaTableData copyWithCompanion(PlaylistMediaTableCompanion data) { + return PlaylistMediaTableData( + id: data.id.present ? data.id.value : this.id, + playlistId: + data.playlistId.present ? data.playlistId.value : this.playlistId, + uri: data.uri.present ? data.uri.value : this.uri, + extras: data.extras.present ? data.extras.value : this.extras, + httpHeaders: + data.httpHeaders.present ? data.httpHeaders.value : this.httpHeaders, + ); + } + + @override + String toString() { + return (StringBuffer('PlaylistMediaTableData(') + ..write('id: $id, ') + ..write('playlistId: $playlistId, ') + ..write('uri: $uri, ') + ..write('extras: $extras, ') + ..write('httpHeaders: $httpHeaders') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, playlistId, uri, extras, httpHeaders); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is PlaylistMediaTableData && + other.id == this.id && + other.playlistId == this.playlistId && + other.uri == this.uri && + other.extras == this.extras && + other.httpHeaders == this.httpHeaders); +} + +class PlaylistMediaTableCompanion + extends UpdateCompanion { + final Value id; + final Value playlistId; + final Value uri; + final Value extras; + final Value httpHeaders; + const PlaylistMediaTableCompanion({ + this.id = const Value.absent(), + this.playlistId = const Value.absent(), + this.uri = const Value.absent(), + this.extras = const Value.absent(), + this.httpHeaders = const Value.absent(), + }); + PlaylistMediaTableCompanion.insert({ + this.id = const Value.absent(), + required int playlistId, + required String uri, + this.extras = const Value.absent(), + this.httpHeaders = const Value.absent(), + }) : playlistId = Value(playlistId), + uri = Value(uri); + static Insertable custom({ + Expression? id, + Expression? playlistId, + Expression? uri, + Expression? extras, + Expression? httpHeaders, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (playlistId != null) 'playlist_id': playlistId, + if (uri != null) 'uri': uri, + if (extras != null) 'extras': extras, + if (httpHeaders != null) 'http_headers': httpHeaders, + }); + } + + PlaylistMediaTableCompanion copyWith( + {Value? id, + Value? playlistId, + Value? uri, + Value? extras, + Value? httpHeaders}) { + return PlaylistMediaTableCompanion( + id: id ?? this.id, + playlistId: playlistId ?? this.playlistId, + uri: uri ?? this.uri, + extras: extras ?? this.extras, + httpHeaders: httpHeaders ?? this.httpHeaders, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (playlistId.present) { + map['playlist_id'] = Variable(playlistId.value); + } + if (uri.present) { + map['uri'] = Variable(uri.value); + } + if (extras.present) { + map['extras'] = Variable(extras.value); + } + if (httpHeaders.present) { + map['http_headers'] = Variable(httpHeaders.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('PlaylistMediaTableCompanion(') + ..write('id: $id, ') + ..write('playlistId: $playlistId, ') + ..write('uri: $uri, ') + ..write('extras: $extras, ') + ..write('httpHeaders: $httpHeaders') + ..write(')')) + .toString(); + } +} + +class HistoryTable extends Table + with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + HistoryTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn createdAt = GeneratedColumn( + 'created_at', aliasedName, false, + type: DriftSqlType.dateTime, + requiredDuringInsert: false, + defaultValue: currentDateAndTime); + late final GeneratedColumn type = GeneratedColumn( + 'type', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn itemId = GeneratedColumn( + 'item_id', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn data = GeneratedColumn( + 'data', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + @override + List get $columns => [id, createdAt, type, itemId, data]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'history_table'; + @override + Set get $primaryKey => {id}; + @override + HistoryTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return HistoryTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + createdAt: attachedDatabase.typeMapping + .read(DriftSqlType.dateTime, data['${effectivePrefix}created_at'])!, + type: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}type'])!, + itemId: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}item_id'])!, + data: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}data'])!, + ); + } + + @override + HistoryTable createAlias(String alias) { + return HistoryTable(attachedDatabase, alias); + } +} + +class HistoryTableData extends DataClass + implements Insertable { + final int id; + final DateTime createdAt; + final String type; + final String itemId; + final String data; + const HistoryTableData( + {required this.id, + required this.createdAt, + required this.type, + required this.itemId, + required this.data}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['created_at'] = Variable(createdAt); + map['type'] = Variable(type); + map['item_id'] = Variable(itemId); + map['data'] = Variable(data); + return map; + } + + HistoryTableCompanion toCompanion(bool nullToAbsent) { + return HistoryTableCompanion( + id: Value(id), + createdAt: Value(createdAt), + type: Value(type), + itemId: Value(itemId), + data: Value(data), + ); + } + + factory HistoryTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return HistoryTableData( + id: serializer.fromJson(json['id']), + createdAt: serializer.fromJson(json['createdAt']), + type: serializer.fromJson(json['type']), + itemId: serializer.fromJson(json['itemId']), + data: serializer.fromJson(json['data']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'createdAt': serializer.toJson(createdAt), + 'type': serializer.toJson(type), + 'itemId': serializer.toJson(itemId), + 'data': serializer.toJson(data), + }; + } + + HistoryTableData copyWith( + {int? id, + DateTime? createdAt, + String? type, + String? itemId, + String? data}) => + HistoryTableData( + id: id ?? this.id, + createdAt: createdAt ?? this.createdAt, + type: type ?? this.type, + itemId: itemId ?? this.itemId, + data: data ?? this.data, + ); + HistoryTableData copyWithCompanion(HistoryTableCompanion data) { + return HistoryTableData( + id: data.id.present ? data.id.value : this.id, + createdAt: data.createdAt.present ? data.createdAt.value : this.createdAt, + type: data.type.present ? data.type.value : this.type, + itemId: data.itemId.present ? data.itemId.value : this.itemId, + data: data.data.present ? data.data.value : this.data, + ); + } + + @override + String toString() { + return (StringBuffer('HistoryTableData(') + ..write('id: $id, ') + ..write('createdAt: $createdAt, ') + ..write('type: $type, ') + ..write('itemId: $itemId, ') + ..write('data: $data') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, createdAt, type, itemId, data); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is HistoryTableData && + other.id == this.id && + other.createdAt == this.createdAt && + other.type == this.type && + other.itemId == this.itemId && + other.data == this.data); +} + +class HistoryTableCompanion extends UpdateCompanion { + final Value id; + final Value createdAt; + final Value type; + final Value itemId; + final Value data; + const HistoryTableCompanion({ + this.id = const Value.absent(), + this.createdAt = const Value.absent(), + this.type = const Value.absent(), + this.itemId = const Value.absent(), + this.data = const Value.absent(), + }); + HistoryTableCompanion.insert({ + this.id = const Value.absent(), + this.createdAt = const Value.absent(), + required String type, + required String itemId, + required String data, + }) : type = Value(type), + itemId = Value(itemId), + data = Value(data); + static Insertable custom({ + Expression? id, + Expression? createdAt, + Expression? type, + Expression? itemId, + Expression? data, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (createdAt != null) 'created_at': createdAt, + if (type != null) 'type': type, + if (itemId != null) 'item_id': itemId, + if (data != null) 'data': data, + }); + } + + HistoryTableCompanion copyWith( + {Value? id, + Value? createdAt, + Value? type, + Value? itemId, + Value? data}) { + return HistoryTableCompanion( + id: id ?? this.id, + createdAt: createdAt ?? this.createdAt, + type: type ?? this.type, + itemId: itemId ?? this.itemId, + data: data ?? this.data, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (createdAt.present) { + map['created_at'] = Variable(createdAt.value); + } + if (type.present) { + map['type'] = Variable(type.value); + } + if (itemId.present) { + map['item_id'] = Variable(itemId.value); + } + if (data.present) { + map['data'] = Variable(data.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('HistoryTableCompanion(') + ..write('id: $id, ') + ..write('createdAt: $createdAt, ') + ..write('type: $type, ') + ..write('itemId: $itemId, ') + ..write('data: $data') + ..write(')')) + .toString(); + } +} + +class LyricsTable extends Table with TableInfo { + @override + final GeneratedDatabase attachedDatabase; + final String? _alias; + LyricsTable(this.attachedDatabase, [this._alias]); + late final GeneratedColumn id = GeneratedColumn( + 'id', aliasedName, false, + hasAutoIncrement: true, + type: DriftSqlType.int, + requiredDuringInsert: false, + defaultConstraints: + GeneratedColumn.constraintIsAlways('PRIMARY KEY AUTOINCREMENT')); + late final GeneratedColumn trackId = GeneratedColumn( + 'track_id', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + late final GeneratedColumn data = GeneratedColumn( + 'data', aliasedName, false, + type: DriftSqlType.string, requiredDuringInsert: true); + @override + List get $columns => [id, trackId, data]; + @override + String get aliasedName => _alias ?? actualTableName; + @override + String get actualTableName => $name; + static const String $name = 'lyrics_table'; + @override + Set get $primaryKey => {id}; + @override + LyricsTableData map(Map data, {String? tablePrefix}) { + final effectivePrefix = tablePrefix != null ? '$tablePrefix.' : ''; + return LyricsTableData( + id: attachedDatabase.typeMapping + .read(DriftSqlType.int, data['${effectivePrefix}id'])!, + trackId: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}track_id'])!, + data: attachedDatabase.typeMapping + .read(DriftSqlType.string, data['${effectivePrefix}data'])!, + ); + } + + @override + LyricsTable createAlias(String alias) { + return LyricsTable(attachedDatabase, alias); + } +} + +class LyricsTableData extends DataClass implements Insertable { + final int id; + final String trackId; + final String data; + const LyricsTableData( + {required this.id, required this.trackId, required this.data}); + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + map['id'] = Variable(id); + map['track_id'] = Variable(trackId); + map['data'] = Variable(data); + return map; + } + + LyricsTableCompanion toCompanion(bool nullToAbsent) { + return LyricsTableCompanion( + id: Value(id), + trackId: Value(trackId), + data: Value(data), + ); + } + + factory LyricsTableData.fromJson(Map json, + {ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return LyricsTableData( + id: serializer.fromJson(json['id']), + trackId: serializer.fromJson(json['trackId']), + data: serializer.fromJson(json['data']), + ); + } + @override + Map toJson({ValueSerializer? serializer}) { + serializer ??= driftRuntimeOptions.defaultSerializer; + return { + 'id': serializer.toJson(id), + 'trackId': serializer.toJson(trackId), + 'data': serializer.toJson(data), + }; + } + + LyricsTableData copyWith({int? id, String? trackId, String? data}) => + LyricsTableData( + id: id ?? this.id, + trackId: trackId ?? this.trackId, + data: data ?? this.data, + ); + LyricsTableData copyWithCompanion(LyricsTableCompanion data) { + return LyricsTableData( + id: data.id.present ? data.id.value : this.id, + trackId: data.trackId.present ? data.trackId.value : this.trackId, + data: data.data.present ? data.data.value : this.data, + ); + } + + @override + String toString() { + return (StringBuffer('LyricsTableData(') + ..write('id: $id, ') + ..write('trackId: $trackId, ') + ..write('data: $data') + ..write(')')) + .toString(); + } + + @override + int get hashCode => Object.hash(id, trackId, data); + @override + bool operator ==(Object other) => + identical(this, other) || + (other is LyricsTableData && + other.id == this.id && + other.trackId == this.trackId && + other.data == this.data); +} + +class LyricsTableCompanion extends UpdateCompanion { + final Value id; + final Value trackId; + final Value data; + const LyricsTableCompanion({ + this.id = const Value.absent(), + this.trackId = const Value.absent(), + this.data = const Value.absent(), + }); + LyricsTableCompanion.insert({ + this.id = const Value.absent(), + required String trackId, + required String data, + }) : trackId = Value(trackId), + data = Value(data); + static Insertable custom({ + Expression? id, + Expression? trackId, + Expression? data, + }) { + return RawValuesInsertable({ + if (id != null) 'id': id, + if (trackId != null) 'track_id': trackId, + if (data != null) 'data': data, + }); + } + + LyricsTableCompanion copyWith( + {Value? id, Value? trackId, Value? data}) { + return LyricsTableCompanion( + id: id ?? this.id, + trackId: trackId ?? this.trackId, + data: data ?? this.data, + ); + } + + @override + Map toColumns(bool nullToAbsent) { + final map = {}; + if (id.present) { + map['id'] = Variable(id.value); + } + if (trackId.present) { + map['track_id'] = Variable(trackId.value); + } + if (data.present) { + map['data'] = Variable(data.value); + } + return map; + } + + @override + String toString() { + return (StringBuffer('LyricsTableCompanion(') + ..write('id: $id, ') + ..write('trackId: $trackId, ') + ..write('data: $data') + ..write(')')) + .toString(); + } +} + +class DatabaseAtV2 extends GeneratedDatabase { + DatabaseAtV2(QueryExecutor e) : super(e); + late final AuthenticationTable authenticationTable = + AuthenticationTable(this); + late final BlacklistTable blacklistTable = BlacklistTable(this); + late final PreferencesTable preferencesTable = PreferencesTable(this); + late final ScrobblerTable scrobblerTable = ScrobblerTable(this); + late final SkipSegmentTable skipSegmentTable = SkipSegmentTable(this); + late final SourceMatchTable sourceMatchTable = SourceMatchTable(this); + late final AudioPlayerStateTable audioPlayerStateTable = + AudioPlayerStateTable(this); + late final PlaylistTable playlistTable = PlaylistTable(this); + late final PlaylistMediaTable playlistMediaTable = PlaylistMediaTable(this); + late final HistoryTable historyTable = HistoryTable(this); + late final LyricsTable lyricsTable = LyricsTable(this); + late final Index uniqueBlacklist = Index('unique_blacklist', + 'CREATE UNIQUE INDEX unique_blacklist ON blacklist_table (element_type, element_id)'); + late final Index uniqTrackMatch = Index('uniq_track_match', + 'CREATE UNIQUE INDEX uniq_track_match ON source_match_table (track_id, source_id, source_type)'); + @override + Iterable> get allTables => + allSchemaEntities.whereType>(); + @override + List get allSchemaEntities => [ + authenticationTable, + blacklistTable, + preferencesTable, + scrobblerTable, + skipSegmentTable, + sourceMatchTable, + audioPlayerStateTable, + playlistTable, + playlistMediaTable, + historyTable, + lyricsTable, + uniqueBlacklist, + uniqTrackMatch + ]; + @override + int get schemaVersion => 2; +} diff --git a/test/drift/app_db/migration_test.dart b/test/drift/app_db/migration_test.dart new file mode 100644 index 00000000..cdf646e9 --- /dev/null +++ b/test/drift/app_db/migration_test.dart @@ -0,0 +1,128 @@ +// ignore_for_file: unused_local_variable, unused_import +import 'package:drift/drift.dart'; +import 'package:drift_dev/api/migrations.dart'; +import 'package:spotube/models/database/database.dart'; +import 'package:test/test.dart'; +import 'generated/schema.dart'; + +import 'generated/schema_v1.dart' as v1; +import 'generated/schema_v2.dart' as v2; + +void main() { + driftRuntimeOptions.dontWarnAboutMultipleDatabases = true; + late SchemaVerifier verifier; + + setUpAll(() { + verifier = SchemaVerifier(GeneratedHelper()); + }); + + group('simple database migrations', () { + // These simple tests verify all possible schema updates with a simple (no + // data) migration. This is a quick way to ensure that written database + // migrations properly alter the schema. + final versions = GeneratedHelper.versions; + for (final (i, fromVersion) in versions.indexed) { + group('from $fromVersion', () { + for (final toVersion in versions.skip(i + 1)) { + test('to $toVersion', () async { + final schema = await verifier.schemaAt(fromVersion); + final db = Database(schema.newConnection()); + await verifier.migrateAndValidate(db, toVersion); + await db.close(); + }); + } + }); + } + }); + + // Simple tests ensure the schema is transformed correctly, but some + // migrations benefit from a test verifying that data is transformed correctly + // too. This is particularly true for migrations that change existing columns + // (e.g. altering their type or constraints). Migrations that only add tables + // or columns typically don't need these advanced tests. + // TODO: Check whether you have migrations that could benefit from these tests + // and adapt this example to your database if necessary: + test("migration from v1 to v2 does not corrupt data", () async { + // Add data to insert into the old database, and the expected rows after the + // migration. + final oldAuthenticationTableData = []; + final expectedNewAuthenticationTableData = []; + + final oldBlacklistTableData = []; + final expectedNewBlacklistTableData = []; + + final oldPreferencesTableData = []; + final expectedNewPreferencesTableData = []; + + final oldScrobblerTableData = []; + final expectedNewScrobblerTableData = []; + + final oldSkipSegmentTableData = []; + final expectedNewSkipSegmentTableData = []; + + final oldSourceMatchTableData = []; + final expectedNewSourceMatchTableData = []; + + final oldAudioPlayerStateTableData = []; + final expectedNewAudioPlayerStateTableData = + []; + + final oldPlaylistTableData = []; + final expectedNewPlaylistTableData = []; + + final oldPlaylistMediaTableData = []; + final expectedNewPlaylistMediaTableData = []; + + final oldHistoryTableData = []; + final expectedNewHistoryTableData = []; + + final oldLyricsTableData = []; + final expectedNewLyricsTableData = []; + + await verifier.testWithDataIntegrity( + oldVersion: 1, + newVersion: 2, + createOld: v1.DatabaseAtV1.new, + createNew: v2.DatabaseAtV2.new, + openTestedDatabase: (x) => AppDatabase(), + createItems: (batch, oldDb) { + batch.insertAll(oldDb.authenticationTable, oldAuthenticationTableData); + batch.insertAll(oldDb.blacklistTable, oldBlacklistTableData); + batch.insertAll(oldDb.preferencesTable, oldPreferencesTableData); + batch.insertAll(oldDb.scrobblerTable, oldScrobblerTableData); + batch.insertAll(oldDb.skipSegmentTable, oldSkipSegmentTableData); + batch.insertAll(oldDb.sourceMatchTable, oldSourceMatchTableData); + batch.insertAll( + oldDb.audioPlayerStateTable, oldAudioPlayerStateTableData); + batch.insertAll(oldDb.playlistTable, oldPlaylistTableData); + batch.insertAll(oldDb.playlistMediaTable, oldPlaylistMediaTableData); + batch.insertAll(oldDb.historyTable, oldHistoryTableData); + batch.insertAll(oldDb.lyricsTable, oldLyricsTableData); + }, + validateItems: (newDb) async { + expect(expectedNewAuthenticationTableData, + await newDb.select(newDb.authenticationTable).get()); + expect(expectedNewBlacklistTableData, + await newDb.select(newDb.blacklistTable).get()); + expect(expectedNewPreferencesTableData, + await newDb.select(newDb.preferencesTable).get()); + expect(expectedNewScrobblerTableData, + await newDb.select(newDb.scrobblerTable).get()); + expect(expectedNewSkipSegmentTableData, + await newDb.select(newDb.skipSegmentTable).get()); + expect(expectedNewSourceMatchTableData, + await newDb.select(newDb.sourceMatchTable).get()); + expect(expectedNewAudioPlayerStateTableData, + await newDb.select(newDb.audioPlayerStateTable).get()); + expect(expectedNewPlaylistTableData, + await newDb.select(newDb.playlistTable).get()); + expect(expectedNewPlaylistMediaTableData, + await newDb.select(newDb.playlistMediaTable).get()); + expect(expectedNewHistoryTableData, + await newDb.select(newDb.historyTable).get()); + expect(expectedNewLyricsTableData, + await newDb.select(newDb.lyricsTable).get()); + }, + ); + }); +} diff --git a/untranslated_messages.json b/untranslated_messages.json index 9e26dfee..1bfd16af 100644 --- a/untranslated_messages.json +++ b/untranslated_messages.json @@ -1 +1,183 @@ -{} \ No newline at end of file +{ + "ar": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "bn": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "ca": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "cs": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "de": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "es": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "eu": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "fa": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "fi": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "fr": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "hi": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "id": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "it": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "ja": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "ka": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "ko": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "ne": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "nl": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "pl": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "pt": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "ru": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "th": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "tr": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "uk": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "vi": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ], + + "zh": [ + "invidious_instance", + "invidious_description", + "invidious_warning", + "invidious_source_description" + ] +}