@ -139,7 +139,7 @@
// /// <returns>Task.</returns>
// /// <returns>Task.</returns>
// public async Task Initialize(SqliteUserDataRepository userDataRepo)
// public async Task Initialize(SqliteUserDataRepository userDataRepo)
// {
// {
// _connection = await CreateConnection(false).ConfigureAwait (false);
// _connection = CreateConnection(false);
// var createMediaStreamsTableCommand
// var createMediaStreamsTableCommand
// = "create table if not exists mediastreams (ItemId GUID, StreamIndex INT, StreamType TEXT, Codec TEXT, Language TEXT, ChannelLayout TEXT, Profile TEXT, AspectRatio TEXT, Path TEXT, IsInterlaced BIT, BitRate INT NULL, Channels INT NULL, SampleRate INT NULL, IsDefault BIT, IsForced BIT, IsExternal BIT, Height INT NULL, Width INT NULL, AverageFrameRate FLOAT NULL, RealFrameRate FLOAT NULL, Level FLOAT NULL, PixelFormat TEXT, BitDepth INT NULL, IsAnamorphic BIT NULL, RefFrames INT NULL, CodecTag TEXT NULL, Comment TEXT NULL, NalLengthSize TEXT NULL, IsAvc BIT NULL, Title TEXT NULL, TimeBase TEXT NULL, CodecTimeBase TEXT NULL, PRIMARY KEY (ItemId, StreamIndex))";
// = "create table if not exists mediastreams (ItemId GUID, StreamIndex INT, StreamType TEXT, Codec TEXT, Language TEXT, ChannelLayout TEXT, Profile TEXT, AspectRatio TEXT, Path TEXT, IsInterlaced BIT, BitRate INT NULL, Channels INT NULL, SampleRate INT NULL, IsDefault BIT, IsForced BIT, IsExternal BIT, Height INT NULL, Width INT NULL, AverageFrameRate FLOAT NULL, RealFrameRate FLOAT NULL, Level FLOAT NULL, PixelFormat TEXT, BitDepth INT NULL, IsAnamorphic BIT NULL, RefFrames INT NULL, CodecTag TEXT NULL, Comment TEXT NULL, NalLengthSize TEXT NULL, IsAvc BIT NULL, Title TEXT NULL, TimeBase TEXT NULL, CodecTimeBase TEXT NULL, PRIMARY KEY (ItemId, StreamIndex))";
@ -168,109 +168,131 @@
// };
// };
// _connection.RunQueries(queries, Logger);
// _connection.RunQueries(queries);
// _connection.AddColumn(Logger, "AncestorIds", "AncestorIdText", "Text");
// _connection.RunInTransaction(db =>
// {
// _connection.AddColumn(Logger, "TypedBaseItems", "Path", "Text");
// var existingColumnNames = GetColumnNames(db, "AncestorIds");
// _connection.AddColumn(Logger, "TypedBaseItems", "StartDate", "DATETIME");
// AddColumn(db, "AncestorIds", "AncestorIdText", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "EndDate", "DATETIME");
// _connection.AddColumn(Logger, "TypedBaseItems", "ChannelId", "Text");
// existingColumnNames = GetColumnNames(db, "TypedBaseItems");
// _connection.AddColumn(Logger, "TypedBaseItems", "IsMovie", "BIT");
// _connection.AddColumn(Logger, "TypedBaseItems", "IsSports", "BIT");
// AddColumn(db, "TypedBaseItems", "Path", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "IsKids", "BIT");
// AddColumn(db, "TypedBaseItems", "StartDate", "DATETIME", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "CommunityRating", "Float");
// AddColumn(db, "TypedBaseItems", "EndDate", "DATETIME", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "CustomRating", "Text");
// AddColumn(db, "TypedBaseItems", "ChannelId", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "IndexNumber", "INT");
// AddColumn(db, "TypedBaseItems", "IsMovie", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "IsLocked", "BIT");
// AddColumn(db, "TypedBaseItems", "IsSports", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "Name", "Text");
// AddColumn(db, "TypedBaseItems", "IsKids", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "OfficialRating", "Text");
// AddColumn(db, "TypedBaseItems", "CommunityRating", "Float", existingColumnNames);
// AddColumn(db, "TypedBaseItems", "CustomRating", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "MediaType", "Text");
// AddColumn(db, "TypedBaseItems", "IndexNumber", "INT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "Overview", "Text");
// AddColumn(db, "TypedBaseItems", "IsLocked", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "ParentIndexNumber", "INT");
// AddColumn(db, "TypedBaseItems", "Name", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "PremiereDate", "DATETIME");
// AddColumn(db, "TypedBaseItems", "OfficialRating", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "ProductionYear", "INT");
// _connection.AddColumn(Logger, "TypedBaseItems", "ParentId", "GUID");
// AddColumn(db, "TypedBaseItems", "MediaType", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "Genres", "Text");
// AddColumn(db, "TypedBaseItems", "Overview", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "SchemaVersion", "INT");
// AddColumn(db, "TypedBaseItems", "ParentIndexNumber", "INT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "SortName", "Text");
// AddColumn(db, "TypedBaseItems", "PremiereDate", "DATETIME", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "RunTimeTicks", "BIGINT");
// AddColumn(db, "TypedBaseItems", "ProductionYear", "INT", existingColumnNames);
// AddColumn(db, "TypedBaseItems", "ParentId", "GUID", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "OfficialRatingDescription", "Text");
// AddColumn(db, "TypedBaseItems", "Genres", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "HomePageUrl", "Text");
// AddColumn(db, "TypedBaseItems", "SchemaVersion", "INT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "VoteCount", "INT");
// AddColumn(db, "TypedBaseItems", "SortName", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "DisplayMediaType", "Text");
// AddColumn(db, "TypedBaseItems", "RunTimeTicks", "BIGINT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "DateCreated", "DATETIME");
// _connection.AddColumn(Logger, "TypedBaseItems", "DateModified", "DATETIME");
// AddColumn(db, "TypedBaseItems", "OfficialRatingDescription", "Text", existingColumnNames);
// AddColumn(db, "TypedBaseItems", "HomePageUrl", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "ForcedSortName", "Text");
// AddColumn(db, "TypedBaseItems", "VoteCount", "INT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "IsOffline", "BIT");
// AddColumn(db, "TypedBaseItems", "DisplayMediaType", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "LocationType", "Text");
// AddColumn(db, "TypedBaseItems", "DateCreated", "DATETIME", existingColumnNames);
// AddColumn(db, "TypedBaseItems", "DateModified", "DATETIME", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "IsSeries", "BIT");
// _connection.AddColumn(Logger, "TypedBaseItems", "IsLive", "BIT");
// AddColumn(db, "TypedBaseItems", "ForcedSortName", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "IsNews", "BIT");
// AddColumn(db, "TypedBaseItems", "IsOffline", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "IsPremiere", "BIT");
// AddColumn(db, "TypedBaseItems", "LocationType", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "EpisodeTitle", "Text");
// AddColumn(db, "TypedBaseItems", "IsSeries", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "IsRepeat", "BIT");
// AddColumn(db, "TypedBaseItems", "IsLive", "BIT", existingColumnNames);
// AddColumn(db, "TypedBaseItems", "IsNews", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "PreferredMetadataLanguage", "Text");
// AddColumn(db, "TypedBaseItems", "IsPremiere", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "PreferredMetadataCountryCode", "Text");
// _connection.AddColumn(Logger, "TypedBaseItems", "IsHD", "BIT");
// AddColumn(db, "TypedBaseItems", "EpisodeTitle", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "ExternalEtag", "Text");
// AddColumn(db, "TypedBaseItems", "IsRepeat", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "DateLastRefreshed", "DATETIME");
// AddColumn(db, "TypedBaseItems", "PreferredMetadataLanguage", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "DateLastSaved", "DATETIME");
// AddColumn(db, "TypedBaseItems", "PreferredMetadataCountryCode", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "IsInMixedFolder", "BIT");
// AddColumn(db, "TypedBaseItems", "IsHD", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "LockedFields", "Text");
// AddColumn(db, "TypedBaseItems", "ExternalEtag", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "Studios", "Text");
// AddColumn(db, "TypedBaseItems", "DateLastRefreshed", "DATETIME", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "Audio", "Text");
// _connection.AddColumn(Logger, "TypedBaseItems", "ExternalServiceId", "Text");
// AddColumn(db, "TypedBaseItems", "DateLastSaved", "DATETIME", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "Tags", "Text");
// AddColumn(db, "TypedBaseItems", "IsInMixedFolder", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "IsFolder", "BIT");
// AddColumn(db, "TypedBaseItems", "LockedFields", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "InheritedParentalRatingValue", "INT");
// AddColumn(db, "TypedBaseItems", "Studios", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "UnratedType", "Text");
// AddColumn(db, "TypedBaseItems", "Audio", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "TopParentId", "Text");
// AddColumn(db, "TypedBaseItems", "ExternalServiceId", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "IsItemByName", "BIT");
// AddColumn(db, "TypedBaseItems", "Tags", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "SourceType", "Text");
// AddColumn(db, "TypedBaseItems", "IsFolder", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "TrailerTypes", "Text");
// AddColumn(db, "TypedBaseItems", "InheritedParentalRatingValue", "INT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "CriticRating", "Float");
// AddColumn(db, "TypedBaseItems", "UnratedType", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "CriticRatingSummary", "Text");
// AddColumn(db, "TypedBaseItems", "TopParentId", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "InheritedTags", "Text");
// AddColumn(db, "TypedBaseItems", "IsItemByName", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "CleanName", "Text");
// AddColumn(db, "TypedBaseItems", "SourceType", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "PresentationUniqueKey", "Text");
// AddColumn(db, "TypedBaseItems", "TrailerTypes", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "SlugName", "Text");
// AddColumn(db, "TypedBaseItems", "CriticRating", "Float", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "OriginalTitle", "Text");
// AddColumn(db, "TypedBaseItems", "CriticRatingSummary", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "PrimaryVersionId", "Text");
// AddColumn(db, "TypedBaseItems", "InheritedTags", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "DateLastMediaAdded", "DATETIME");
// AddColumn(db, "TypedBaseItems", "CleanName", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "Album", "Text");
// AddColumn(db, "TypedBaseItems", "PresentationUniqueKey", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "IsVirtualItem", "BIT");
// AddColumn(db, "TypedBaseItems", "SlugName", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "SeriesName", "Text");
// AddColumn(db, "TypedBaseItems", "OriginalTitle", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "UserDataKey", "Text");
// AddColumn(db, "TypedBaseItems", "PrimaryVersionId", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "SeasonName", "Text");
// AddColumn(db, "TypedBaseItems", "DateLastMediaAdded", "DATETIME", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "SeasonId", "GUID");
// AddColumn(db, "TypedBaseItems", "Album", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "SeriesId", "GUID");
// AddColumn(db, "TypedBaseItems", "IsVirtualItem", "BIT", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "SeriesSortName", "Text");
// AddColumn(db, "TypedBaseItems", "SeriesName", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "ExternalSeriesId", "Text");
// AddColumn(db, "TypedBaseItems", "UserDataKey", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "ShortOverview", "Text");
// AddColumn(db, "TypedBaseItems", "SeasonName", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "Tagline", "Text");
// AddColumn(db, "TypedBaseItems", "SeasonId", "GUID", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "Keywords", "Text");
// AddColumn(db, "TypedBaseItems", "SeriesId", "GUID", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "ProviderIds", "Text");
// AddColumn(db, "TypedBaseItems", "SeriesSortName", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "Images", "Text");
// AddColumn(db, "TypedBaseItems", "ExternalSeriesId", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "ProductionLocations", "Text");
// AddColumn(db, "TypedBaseItems", "ShortOverview", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "ThemeSongIds", "Text");
// AddColumn(db, "TypedBaseItems", "Tagline", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "ThemeVideoIds", "Text");
// AddColumn(db, "TypedBaseItems", "Keywords", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "TotalBitrate", "INT");
// AddColumn(db, "TypedBaseItems", "ProviderIds", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "ExtraType", "Text");
// AddColumn(db, "TypedBaseItems", "Images", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "Artists", "Text");
// AddColumn(db, "TypedBaseItems", "ProductionLocations", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "AlbumArtists", "Text");
// AddColumn(db, "TypedBaseItems", "ThemeSongIds", "Text", existingColumnNames);
// _connection.AddColumn(Logger, "TypedBaseItems", "ExternalId", "Text");
// AddColumn(db, "TypedBaseItems", "ThemeVideoIds", "Text", existingColumnNames);
// AddColumn(db, "TypedBaseItems", "TotalBitrate", "INT", existingColumnNames);
// _connection.AddColumn(Logger, "ItemValues", "CleanValue", "Text");
// AddColumn(db, "TypedBaseItems", "ExtraType", "Text", existingColumnNames);
// AddColumn(db, "TypedBaseItems", "Artists", "Text", existingColumnNames);
// _connection.AddColumn(Logger, ChaptersTableName, "ImageDateModified", "DATETIME");
// AddColumn(db, "TypedBaseItems", "AlbumArtists", "Text", existingColumnNames);
// AddColumn(db, "TypedBaseItems", "ExternalId", "Text", existingColumnNames);
// existingColumnNames = GetColumnNames(db, "ItemValues");
// AddColumn(db, "ItemValues", "CleanValue", "Text", existingColumnNames);
// existingColumnNames = GetColumnNames(db, ChaptersTableName);
// AddColumn(db, ChaptersTableName, "ImageDateModified", "DATETIME", existingColumnNames);
// existingColumnNames = GetColumnNames(db, "MediaStreams");
// AddColumn(db, "MediaStreams", "IsAvc", "BIT", existingColumnNames);
// AddColumn(db, "MediaStreams", "TimeBase", "TEXT", existingColumnNames);
// AddColumn(db, "MediaStreams", "CodecTimeBase", "TEXT", existingColumnNames);
// AddColumn(db, "MediaStreams", "Title", "TEXT", existingColumnNames);
// AddColumn(db, "MediaStreams", "NalLengthSize", "TEXT", existingColumnNames);
// AddColumn(db, "MediaStreams", "Comment", "TEXT", existingColumnNames);
// AddColumn(db, "MediaStreams", "CodecTag", "TEXT", existingColumnNames);
// AddColumn(db, "MediaStreams", "PixelFormat", "TEXT", existingColumnNames);
// AddColumn(db, "MediaStreams", "BitDepth", "INT", existingColumnNames);
// AddColumn(db, "MediaStreams", "RefFrames", "INT", existingColumnNames);
// AddColumn(db, "MediaStreams", "KeyFrames", "TEXT", existingColumnNames);
// AddColumn(db, "MediaStreams", "IsAnamorphic", "BIT", existingColumnNames);
// });
// string[] postQueries =
// string[] postQueries =
@ -334,14 +356,12 @@
// "create index if not exists idx_ItemValues7 on ItemValues(Type,CleanValue,ItemId)"
// "create index if not exists idx_ItemValues7 on ItemValues(Type,CleanValue,ItemId)"
// };
// };
// _connection.RunQueries(postQueries , Logger );
// _connection.RunQueries(postQueries );
// PrepareStatements();
// PrepareStatements();
// new MediaStreamColumns(_connection, Logger).AddColumns();
// SqliteExtensions.Attach(_connection, Path.Combine(_config.ApplicationPaths.DataPath, "userdata_v2.db"), "UserDataDb");
// userDataRepo.Initialize(_connection, WriteLock);
// DataExtensions.Attach(_connection, Path.Combine(_config.ApplicationPaths.DataPath, "userdata_v2.db"), "UserDataDb");
// await userDataRepo.Initialize(_connection, WriteLock).ConfigureAwait(false);
// //await Vacuum(_connection).ConfigureAwait(false);
// //await Vacuum(_connection).ConfigureAwait(false);
// }
// }