BaseSqliteRepository.cs 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. using MediaBrowser.Model.Logging;
  2. using System;
  3. using System.Data;
  4. using System.Threading;
  5. using System.Threading.Tasks;
  6. namespace MediaBrowser.Server.Implementations.Persistence
  7. {
  8. public abstract class BaseSqliteRepository : IDisposable
  9. {
  10. protected readonly IDbConnector DbConnector;
  11. protected ILogger Logger;
  12. protected string DbFilePath { get; set; }
  13. protected BaseSqliteRepository(ILogManager logManager, IDbConnector dbConnector)
  14. {
  15. DbConnector = dbConnector;
  16. Logger = logManager.GetLogger(GetType().Name);
  17. }
  18. protected virtual async Task<IDbConnection> CreateConnection(bool isReadOnly = false)
  19. {
  20. var connection = await DbConnector.Connect(DbFilePath, false, true).ConfigureAwait(false);
  21. connection.RunQueries(new []
  22. {
  23. "pragma temp_store = memory"
  24. }, Logger);
  25. return connection;
  26. }
  27. private bool _disposed;
  28. protected void CheckDisposed()
  29. {
  30. if (_disposed)
  31. {
  32. throw new ObjectDisposedException(GetType().Name + " has been disposed and cannot be accessed.");
  33. }
  34. }
  35. public void Dispose()
  36. {
  37. _disposed = true;
  38. Dispose(true);
  39. }
  40. protected async Task Vacuum(IDbConnection connection)
  41. {
  42. CheckDisposed();
  43. try
  44. {
  45. using (var cmd = connection.CreateCommand())
  46. {
  47. cmd.CommandText = "vacuum";
  48. cmd.ExecuteNonQuery();
  49. }
  50. }
  51. catch (Exception e)
  52. {
  53. Logger.ErrorException("Failed to vacuum:", e);
  54. throw;
  55. }
  56. }
  57. /// <summary>
  58. /// Releases unmanaged and - optionally - managed resources.
  59. /// </summary>
  60. /// <param name="dispose"><c>true</c> to release both managed and unmanaged resources; <c>false</c> to release only unmanaged resources.</param>
  61. protected virtual void Dispose(bool dispose)
  62. {
  63. }
  64. }
  65. }