aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPatrick Barron <barronpm@gmail.com>2020-06-04 14:54:43 -0400
committerPatrick Barron <barronpm@gmail.com>2020-06-04 14:54:43 -0400
commitef7bbb3b8425f4873282525c607f86e9f3fcc87a (patch)
treee9300b606e509db71f4c21b5a8e8e3d015c00f2a
parentb0281b79fd8c6e103fa7a1cb183028541d280ed4 (diff)
Use data binding instead of raw SQL
-rw-r--r--Jellyfin.Server/Migrations/Routines/MigrateActivityLogDb.cs32
1 files changed, 14 insertions, 18 deletions
diff --git a/Jellyfin.Server/Migrations/Routines/MigrateActivityLogDb.cs b/Jellyfin.Server/Migrations/Routines/MigrateActivityLogDb.cs
index 270c36f85..fb3466e13 100644
--- a/Jellyfin.Server/Migrations/Routines/MigrateActivityLogDb.cs
+++ b/Jellyfin.Server/Migrations/Routines/MigrateActivityLogDb.cs
@@ -1,7 +1,6 @@
using System;
using System.Collections.Generic;
using System.IO;
-using System.Linq;
using Emby.Server.Implementations.Data;
using Jellyfin.Data.Entities;
using Jellyfin.Server.Implementations;
@@ -68,7 +67,7 @@ namespace Jellyfin.Server.Migrations.Routines
_logger.LogWarning("Migrating the activity database may take a while, do not stop Jellyfin.");
using var dbContext = _provider.CreateContext();
- var queryResult = connection.Query("SELECT * FROM ActivityLog ORDER BY Id ASC");
+ var queryResult = connection.Query("SELECT * FROM ActivityLog ORDER BY Id");
// Make sure that the database is empty in case of failed migration due to power outages, etc.
dbContext.ActivityLogs.RemoveRange(dbContext.ActivityLogs);
@@ -86,29 +85,26 @@ namespace Jellyfin.Server.Migrations.Routines
severity = LogLevel.Trace;
}
- Guid guid;
- if (entry[6].SQLiteType == SQLiteType.Null)
- {
- guid = Guid.Empty;
- }
- else if (!Guid.TryParse(entry[6].ToString(), out guid))
+ var guid = Guid.Empty;
+ if (entry[6].SQLiteType != SQLiteType.Null && !Guid.TryParse(entry[6].ToString(), out guid))
{
// This is not a valid Guid, see if it is an internal ID from an old Emby schema
- var userEntry = userDbConnection
- .Query($"SELECT guid FROM LocalUsersv2 WHERE Id = {entry[6].ToString()}")
- .FirstOrDefault();
+ _logger.LogWarning("Invalid Guid in UserId column: ", entry[6].ToString());
+
+ using var statement = userDbConnection.PrepareStatement("SELECT guid FROM LocalUsersv2 WHERE Id=@Id");
+ statement.TryBind("@Id", entry[6].ToString());
- if (userEntry.Count == 0 || !Guid.TryParse(userEntry[0].ToString(), out guid))
+ foreach (var row in statement.Query())
{
- // Give up, just use Guid.Empty
- guid = Guid.Empty;
+ if (row.Count > 0 && Guid.TryParse(row[0].ToString(), out guid))
+ {
+ // Successfully parsed a Guid from the user table.
+ break;
+ }
}
}
- var newEntry = new ActivityLog(
- entry[1].ToString(),
- entry[4].ToString(),
- guid)
+ var newEntry = new ActivityLog(entry[1].ToString(), entry[4].ToString(), guid)
{
DateCreated = entry[7].ReadDateTime(),
LogSeverity = severity