MeetingOrderRepository.cs 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Threading.Tasks;
  4. using Datory;
  5. using GxPress.Common.AppOptions;
  6. using GxPress.Common.Tools;
  7. using GxPress.Entity.WorkMeeting;
  8. using GxPress.Repository.Interface.WorkMeeting;
  9. using Microsoft.Extensions.Caching.Distributed;
  10. using Microsoft.Extensions.Options;
  11. using SqlKata;
  12. namespace GxPress.Repository.Implement.WorkMeeting
  13. {
  14. public class MeetingOrderRepository : IMeetingOrderRepository
  15. {
  16. private readonly Repository<MeetingOrder> _repository;
  17. public MeetingOrderRepository(IOptionsMonitor<DatabaseOptions> dbOptionsAccessor, IDistributedCache cache)
  18. {
  19. var databaseType = StringUtils.ToEnum<DatabaseType>(dbOptionsAccessor.CurrentValue.DatabaseType, DatabaseType.MySql);
  20. var database = new Database(databaseType, dbOptionsAccessor.CurrentValue.ConnectionString);
  21. _repository = new Repository<MeetingOrder>(database, cache);
  22. }
  23. public IDatabase Database => _repository.Database;
  24. public string TableName => _repository.TableName;
  25. public List<TableColumn> TableColumns => _repository.TableColumns;
  26. public async Task<int> InsertAsync(MeetingOrder item)
  27. {
  28. return await _repository.InsertAsync(item);
  29. }
  30. public async Task<IEnumerable<MeetingOrder>> GetListAsync(int roomId)
  31. {
  32. return await _repository.GetAllAsync(Q.Where(nameof(MeetingOrder.RoomId), roomId));
  33. }
  34. public async Task<IEnumerable<MeetingOrder>> GetListByMeetingIdAsync(int meetingId)
  35. {
  36. return await _repository.GetAllAsync(Q.Where(nameof(MeetingOrder.MeetingId), meetingId).OrderByDesc(nameof(MeetingOrder.Date)));
  37. }
  38. public async Task<IEnumerable<MeetingOrder>> GetListAsyncSinceNow(int roomId)
  39. {
  40. return await _repository.GetAllAsync(Q
  41. .Where(nameof(MeetingOrder.Date), ">=",
  42. StringUtils.GetDate(DateTime.Now)).Where(nameof(MeetingOrder.RoomId), roomId)
  43. );
  44. }
  45. public async Task<bool> DeleteAsync(int orderId)
  46. {
  47. return await _repository.DeleteAsync(orderId);
  48. }
  49. public async Task DeleteByRoomIdAsync(int roomId)
  50. {
  51. await _repository.DeleteAsync(Q.Where(nameof(MeetingOrder.RoomId), roomId));
  52. }
  53. public async Task DeleteByMeetingIdAsync(int meetingId)
  54. {
  55. await _repository.DeleteAsync(Q.Where(nameof(MeetingOrder.MeetingId), meetingId));
  56. }
  57. public async Task<bool> DeleteAsync(Query query)
  58. {
  59. return await _repository.DeleteAsync(query) > 0;
  60. }
  61. }
  62. }