SharingRepository.cs 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. using System;
  2. using System.Data;
  3. using System.IO;
  4. using System.Threading;
  5. using System.Threading.Tasks;
  6. using Emby.Server.Core.Data;
  7. using MediaBrowser.Common.Configuration;
  8. using MediaBrowser.Model.Logging;
  9. using MediaBrowser.Model.Social;
  10. namespace Emby.Server.Core.Social
  11. {
  12. public class SharingRepository : BaseSqliteRepository, ISharingRepository
  13. {
  14. public SharingRepository(ILogManager logManager, IApplicationPaths appPaths, IDbConnector dbConnector)
  15. : base(logManager, dbConnector)
  16. {
  17. DbFilePath = Path.Combine(appPaths.DataPath, "shares.db");
  18. }
  19. /// <summary>
  20. /// Opens the connection to the database
  21. /// </summary>
  22. /// <returns>Task.</returns>
  23. public async Task Initialize()
  24. {
  25. using (var connection = await CreateConnection().ConfigureAwait(false))
  26. {
  27. string[] queries = {
  28. "create table if not exists Shares (Id GUID, ItemId TEXT, UserId TEXT, ExpirationDate DateTime, PRIMARY KEY (Id))",
  29. "create index if not exists idx_Shares on Shares(Id)",
  30. "pragma shrink_memory"
  31. };
  32. connection.RunQueries(queries, Logger);
  33. }
  34. }
  35. public async Task CreateShare(SocialShareInfo info)
  36. {
  37. if (info == null)
  38. {
  39. throw new ArgumentNullException("info");
  40. }
  41. if (string.IsNullOrWhiteSpace(info.Id))
  42. {
  43. throw new ArgumentNullException("info.Id");
  44. }
  45. var cancellationToken = CancellationToken.None;
  46. cancellationToken.ThrowIfCancellationRequested();
  47. using (var connection = await CreateConnection().ConfigureAwait(false))
  48. {
  49. using (var saveShareCommand = connection.CreateCommand())
  50. {
  51. saveShareCommand.CommandText = "replace into Shares (Id, ItemId, UserId, ExpirationDate) values (@Id, @ItemId, @UserId, @ExpirationDate)";
  52. saveShareCommand.Parameters.Add(saveShareCommand, "@Id");
  53. saveShareCommand.Parameters.Add(saveShareCommand, "@ItemId");
  54. saveShareCommand.Parameters.Add(saveShareCommand, "@UserId");
  55. saveShareCommand.Parameters.Add(saveShareCommand, "@ExpirationDate");
  56. IDbTransaction transaction = null;
  57. try
  58. {
  59. transaction = connection.BeginTransaction();
  60. saveShareCommand.GetParameter(0).Value = new Guid(info.Id);
  61. saveShareCommand.GetParameter(1).Value = info.ItemId;
  62. saveShareCommand.GetParameter(2).Value = info.UserId;
  63. saveShareCommand.GetParameter(3).Value = info.ExpirationDate;
  64. saveShareCommand.Transaction = transaction;
  65. saveShareCommand.ExecuteNonQuery();
  66. transaction.Commit();
  67. }
  68. catch (OperationCanceledException)
  69. {
  70. if (transaction != null)
  71. {
  72. transaction.Rollback();
  73. }
  74. throw;
  75. }
  76. catch (Exception e)
  77. {
  78. Logger.ErrorException("Failed to save share:", e);
  79. if (transaction != null)
  80. {
  81. transaction.Rollback();
  82. }
  83. throw;
  84. }
  85. finally
  86. {
  87. if (transaction != null)
  88. {
  89. transaction.Dispose();
  90. }
  91. }
  92. }
  93. }
  94. }
  95. public SocialShareInfo GetShareInfo(string id)
  96. {
  97. if (string.IsNullOrWhiteSpace(id))
  98. {
  99. throw new ArgumentNullException("id");
  100. }
  101. using (var connection = CreateConnection(true).Result)
  102. {
  103. var cmd = connection.CreateCommand();
  104. cmd.CommandText = "select Id, ItemId, UserId, ExpirationDate from Shares where id = @id";
  105. cmd.Parameters.Add(cmd, "@id", DbType.Guid).Value = new Guid(id);
  106. using (var reader = cmd.ExecuteReader(CommandBehavior.SequentialAccess | CommandBehavior.SingleResult | CommandBehavior.SingleRow))
  107. {
  108. if (reader.Read())
  109. {
  110. return GetSocialShareInfo(reader);
  111. }
  112. }
  113. return null;
  114. }
  115. }
  116. private SocialShareInfo GetSocialShareInfo(IDataReader reader)
  117. {
  118. var info = new SocialShareInfo();
  119. info.Id = reader.GetGuid(0).ToString("N");
  120. info.ItemId = reader.GetString(1);
  121. info.UserId = reader.GetString(2);
  122. info.ExpirationDate = reader.GetDateTime(3).ToUniversalTime();
  123. return info;
  124. }
  125. public async Task DeleteShare(string id)
  126. {
  127. }
  128. }
  129. }