aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCody Robibero <cody@robibe.ro>2022-03-05 13:36:40 -0700
committerGitHub <noreply@github.com>2022-03-05 13:36:40 -0700
commitbc3cb04c0bf8569916f4a9265788b01db5d7fe83 (patch)
treeab9466027e434ee83939948fd21d049b05074336
parent2579b2db561566df9c171d714446d40f1b0bf23d (diff)
parentb705ace262de83867d4d0a04df285d0cc90dd378 (diff)
Merge pull request #7240 from jaysonsantos/add-readonly-connection
-rw-r--r--Emby.Server.Implementations/Data/BaseSqliteRepository.cs8
-rw-r--r--Emby.Server.Implementations/Data/ManagedConnection.cs8
2 files changed, 12 insertions, 4 deletions
diff --git a/Emby.Server.Implementations/Data/BaseSqliteRepository.cs b/Emby.Server.Implementations/Data/BaseSqliteRepository.cs
index 450688491..b86511482 100644
--- a/Emby.Server.Implementations/Data/BaseSqliteRepository.cs
+++ b/Emby.Server.Implementations/Data/BaseSqliteRepository.cs
@@ -98,8 +98,16 @@ namespace Emby.Server.Implementations.Data
/// <value>The write connection.</value>
protected SQLiteDatabaseConnection WriteConnection { get; set; }
+ protected SQLiteDatabaseConnection ReadConnection { get; set; }
+
protected ManagedConnection GetConnection(bool readOnly = false)
{
+ if (readOnly)
+ {
+ ReadConnection ??= SQLite3.Open(DbFilePath, ConnectionFlags.ReadOnly, null);
+ return new ManagedConnection(ReadConnection, null);
+ }
+
WriteLock.Wait();
if (WriteConnection != null)
{
diff --git a/Emby.Server.Implementations/Data/ManagedConnection.cs b/Emby.Server.Implementations/Data/ManagedConnection.cs
index 11e33278d..fe09bdc2a 100644
--- a/Emby.Server.Implementations/Data/ManagedConnection.cs
+++ b/Emby.Server.Implementations/Data/ManagedConnection.cs
@@ -9,13 +9,13 @@ namespace Emby.Server.Implementations.Data
{
public sealed class ManagedConnection : IDisposable
{
- private readonly SemaphoreSlim _writeLock;
+ private readonly SemaphoreSlim? _writeLock;
private SQLiteDatabaseConnection? _db;
- private bool _disposed = false;
+ private bool _disposed;
- public ManagedConnection(SQLiteDatabaseConnection db, SemaphoreSlim writeLock)
+ public ManagedConnection(SQLiteDatabaseConnection db, SemaphoreSlim? writeLock)
{
_db = db;
_writeLock = writeLock;
@@ -73,7 +73,7 @@ namespace Emby.Server.Implementations.Data
return;
}
- _writeLock.Release();
+ _writeLock?.Release();
_db = null; // Don't dispose it
_disposed = true;