TestController.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338
  1. using System.Collections.Concurrent;
  2. using System.Data;
  3. using System.IO;
  4. using DotNetCore.CAP;
  5. using Fw.Utility.Client;
  6. using Google.Protobuf.WellKnownTypes;
  7. using Hotline.Ai.Visit;
  8. using Hotline.Application.ExportExcel;
  9. using Hotline.CallCenter.BlackLists;
  10. using Hotline.CallCenter.Devices;
  11. using Hotline.CallCenter.Ivrs;
  12. using Hotline.FlowEngine.WorkflowModules;
  13. using Hotline.Identity.Roles;
  14. using Hotline.Import;
  15. using Hotline.Orders;
  16. using Hotline.Realtimes;
  17. using Hotline.Repository.SqlSugar;
  18. using Hotline.Repository.SqlSugar.Ts;
  19. using Hotline.Settings.TimeLimits;
  20. using Hotline.Share.Dtos.FlowEngine;
  21. using Hotline.Share.Dtos.Realtime;
  22. using Hotline.Share.Enums.Settings;
  23. using Hotline.Share.Mq;
  24. using Hotline.Users;
  25. using MediatR;
  26. using Microsoft.AspNetCore.Authorization;
  27. using Microsoft.AspNetCore.Http;
  28. using Microsoft.AspNetCore.Mvc;
  29. using Microsoft.AspNetCore.Routing.Template;
  30. using Microsoft.Extensions.Options;
  31. using MiniExcelLibs;
  32. using NewRock.Sdk;
  33. using NewRock.Sdk.Security;
  34. using SqlSugar;
  35. using Tr.Sdk;
  36. using XC.RSAUtil;
  37. using XF.Domain.Authentications;
  38. using XF.Domain.Cache;
  39. using XF.Domain.Exceptions;
  40. using XF.Domain.Filters;
  41. using XF.Domain.Locks;
  42. using XF.Domain.Queues;
  43. using XF.Domain.Repository;
  44. using XF.EasyCaching;
  45. namespace Hotline.Api.Controllers;
  46. /// <summary>
  47. ///
  48. /// </summary>
  49. [AllowAnonymous]
  50. public class TestController : BaseController
  51. {
  52. private readonly ILogger<TestController> _logger;
  53. private readonly IAuthorizeGenerator _authorizeGenerator;
  54. private readonly IOptionsSnapshot<CallCenterConfiguration> _options;
  55. private readonly ISessionContext _sessionContext;
  56. private readonly IRepository<User> _userRepository;
  57. private readonly ITypedCache<User> _cache;
  58. private readonly IRealtimeService _realtimeService;
  59. private readonly IBlacklistDomainService _blacklistDomainService;
  60. private readonly IIvrDomainService _ivrDomainService;
  61. private readonly ISugarUnitOfWork<HotlineDbContext> _uow;
  62. private readonly IRepository<Role> _roleRepository;
  63. private readonly IMediator _mediator;
  64. private readonly IDistributedLock _distributedLock;
  65. private readonly IRepository<OrderUrge> _orderUrgeRepository;
  66. private readonly IRepositoryTextSearch<OrderTs> _repositoryts;
  67. private readonly ITimeLimitDomainService _timeLimitDomainService;
  68. private readonly IWfModuleDomainService _wfModuleDomainService;
  69. private readonly IDaySettingRepository _daySettingRepository;
  70. private readonly ITrClient _trClient;
  71. private readonly ICapPublisher _capPublisher;
  72. private readonly IQueue _queue;
  73. private readonly IExportApplication _exportApplication;
  74. private readonly IAiVisitService _aiVisitService;
  75. //private readonly ITypedCache<List<User>> _cache;
  76. //private readonly ICacheManager<User> _cache;
  77. public TestController(
  78. INewRockClient client,
  79. ILogger<TestController> logger,
  80. IAuthorizeGenerator authorizeGenerator,
  81. IOptionsSnapshot<CallCenterConfiguration> options,
  82. ISessionContext sessionContext,
  83. IRepository<User> userRepository,
  84. //ICacheManager<User> cache
  85. //ITypedCache<List<User>> cache
  86. ITypedCache<User> cache,
  87. IRealtimeService realtimeService,
  88. IBlacklistDomainService blacklistDomainService,
  89. IIvrDomainService ivrDomainService,
  90. ISugarUnitOfWork<HotlineDbContext> uow,
  91. IRepository<Role> roleRepository,
  92. IMediator mediator,
  93. IDistributedLock distributedLock,
  94. IRepository<OrderUrge> orderUrgeRepository,
  95. IRepositoryTextSearch<OrderTs> repositoryts,
  96. ITimeLimitDomainService timeLimitDomainService,
  97. IWfModuleDomainService wfModuleDomainService,
  98. IDaySettingRepository daySettingRepository,
  99. ITrClient trClient,
  100. ICapPublisher capPublisher,
  101. IQueue queue,
  102. IExportApplication exportApplication,
  103. IAiVisitService aiVisitService
  104. )
  105. {
  106. _logger = logger;
  107. _authorizeGenerator = authorizeGenerator;
  108. _options = options;
  109. _sessionContext = sessionContext;
  110. _userRepository = userRepository;
  111. _cache = cache;
  112. _realtimeService = realtimeService;
  113. _blacklistDomainService = blacklistDomainService;
  114. _ivrDomainService = ivrDomainService;
  115. _uow = uow;
  116. _roleRepository = roleRepository;
  117. _mediator = mediator;
  118. _distributedLock = distributedLock;
  119. _orderUrgeRepository = orderUrgeRepository;
  120. _repositoryts = repositoryts;
  121. _timeLimitDomainService = timeLimitDomainService;
  122. _wfModuleDomainService = wfModuleDomainService;
  123. _daySettingRepository = daySettingRepository;
  124. _trClient = trClient;
  125. _capPublisher = capPublisher;
  126. _queue = queue;
  127. _exportApplication = exportApplication;
  128. _aiVisitService = aiVisitService;
  129. }
  130. [HttpGet("testo")]
  131. public async Task<OpenResponse> TestOrigin()
  132. {
  133. var now = DateTime.Now.ToString();
  134. return OpenResponse.Ok(now);
  135. }
  136. [HttpPost("import")]
  137. [AllowAnonymous]
  138. public async Task<List<ExcelContent>> Import(IFormFile file)
  139. {
  140. //var FileName = file.FileName;
  141. //var fileExtension = Path.GetExtension(FileName);
  142. ////新文件名
  143. //var newFileName = DateTime.Now.ToString("yyyyMMddhhmmss");
  144. ////文件保存路径
  145. //var filePath = Path.Combine(Directory.GetCurrentDirectory(), "wwwroot", "Upload", newFileName);
  146. ////判断路径是否存在
  147. //if (!Directory.Exists(filePath))
  148. //{
  149. // //创建路径
  150. // Directory.CreateDirectory(filePath);
  151. //}
  152. //filePath = Path.Combine(filePath, newFileName+ fileExtension);
  153. using (var stream = new MemoryStream())
  154. {
  155. file.CopyTo(stream);
  156. var list = MiniExcel.Query<ExcelContent>(stream).ToList();
  157. //Directory.Delete(filePath, true);
  158. return list;
  159. }
  160. }
  161. [AllowAnonymous]
  162. [HttpGet("export")]
  163. public async Task<object> Export()
  164. {
  165. List<ExcelContent> list = new List<ExcelContent>();
  166. ExcelContent excelContent = new ExcelContent() { ExternalId = "123123" };
  167. list.Add(excelContent);
  168. return _exportApplication.ExportData<ExcelContent>(list, "demo.xlsx");
  169. }
  170. [HttpGet("time")]
  171. [AllowAnonymous]
  172. public async Task<OpenResponse> GetTime(string batchId,string taskId)
  173. {
  174. //await _repositoryts.AddVectorAsync("f595e730-909a-45e4-9138-a84bf15f4662", DateTime.Now,
  175. // new List<string> { "xx", "bb" }, HttpContext.RequestAborted);
  176. //var result = await _repositoryts.SearchAsync(new List<string> { "bb" }, HttpContext.RequestAborted);
  177. //await _repositoryts.UpdateVectorAsync("f595e730-909a-45e4-9138-a84bf15f4662",
  178. // new List<string> { "ss", "bb" }, HttpContext.RequestAborted);
  179. //_uow.Db.Ado.SqlQueryAsync<OrderUrge>("SELECT to_tsvector('fat cats ate fat rats') @@ to_tsquery('fat & rat')")
  180. //var tests = _uowWex.Db.Ado.SqlQuery<Test>("select * from view_telinfo_full where IsSynch=@IsSynch", new { IsSynch = 0 });
  181. //var a = _uowWex.Db.Ado.ExecuteCommand("update telinfo set IsSynch=1 where GUID=@CallId", new { CallId = "b1f97f3c-88b6-4f42-b8de-83ed448854b0" });
  182. //var rsp = await _wexClient.QueryTelsAsync(new QueryTelRequest { }, HttpContext.RequestAborted);
  183. //int a = _timeLimitDomainService.CalcWorkTime(DateTime.Now, DateTime.Parse("2023-09-11 16:21:00"));
  184. //int m = _timeLimitDomainService.CalcWorkTime(DateTime.Parse("2023-09-19 12:00:00"), DateTime.Parse("2023-09-20 18:00:00"), false);
  185. //var r = _timeLimitDomainService.CalcEndTime(DateTime.Parse("2024-03-07 14:09:45"), ETimeType.WorkDay,1,false,80);
  186. //var r = _timeLimitDomainService.CalcExpiredTime(DateTime.Parse("2024-02-29 10:12:33"), Share.Enums.FlowEngine.EFlowDirection.OrgToCenter, "10");
  187. //await _wfModuleDomainService.PersistenceModulesAsync(HttpContext.RequestAborted);
  188. //var rsp = await _daprClient.InvokeMethodAsync<ApiResponse<string>>(HttpMethod.Get, "identity", "api/v1/Test/time", HttpContext.RequestAborted);
  189. //var rsp1 = await _daprClient.InvokeMethodAsync<int, ApiResponse<string>>(HttpMethod.Post, "identity", "api/v1/Test/time1", 222, HttpContext.RequestAborted);
  190. //var a = await _trClient.QueryTelsAsync(new Tr.Sdk.Tels.QueryTelRequest() { }, HttpContext.RequestAborted);
  191. //await _daySettingRepository.IsWorkDay(DateTime.Now);
  192. //var r = _timeLimitDomainService.CalcWorkTime(DateTime.Parse("2024-3-22 05:00:00"), DateTime.Parse("2024-3-22 06:00:00"), false);
  193. //var r = _timeLimitDomainService.CalcWorkTime(DateTime.Parse("2024-3-24 17:20:00"), DateTime.Parse("2024-3-24 17:21:00"), false);
  194. //await _aiVisitService.QueryAiVisitTask(batchId, taskId, HttpContext.RequestAborted);
  195. var r = _timeLimitDomainService.CalcWorkTimeReduce(DateTime.Now, 5);
  196. return OpenResponse.Ok(DateTime.Now.ToString("F"));
  197. }
  198. [HttpGet("pgsql")]
  199. public async Task<string> Pgsql()
  200. {
  201. var role = new Role
  202. {
  203. Name = $"test_role_{TimeOnly.FromDateTime(DateTime.Now)}",
  204. DisplayName = "test_role_display",
  205. ClientId = "test"
  206. };
  207. var roleId = await _roleRepository.AddAsync(role, HttpContext.RequestAborted);
  208. role.Description = "Description";
  209. await _roleRepository.UpdateAsync(role, HttpContext.RequestAborted);
  210. return roleId;
  211. }
  212. [AllowAnonymous]
  213. [HttpGet("roles")]
  214. public async Task<List<Role>> GetRoles()
  215. {
  216. using var lockManager = new LockManager(_distributedLock, $"{nameof(TestController)}.{nameof(GetRoles)}");
  217. lockManager.InvokeInLock(() => { Console.WriteLine("do something"); }, TimeSpan.FromSeconds(10));
  218. await lockManager.InvokeInLockAsync(
  219. d => _roleRepository.Queryable(includeDeleted: true).ToListAsync(),
  220. TimeSpan.FromSeconds(10),
  221. HttpContext.RequestAborted);
  222. var a = await _roleRepository.Queryable()
  223. //.Where(d => !d.IsDeleted)
  224. .ToListAsync();
  225. //var a = await db.Queryable<Role>().ToListAsync();
  226. var b = await _roleRepository.Queryable(includeDeleted: true).ToListAsync();
  227. return a;
  228. }
  229. //[AllowAnonymous]
  230. [HttpGet("hash")]
  231. public async Task Hash()
  232. {
  233. var s = _sessionContext;
  234. }
  235. /// <summary>
  236. /// signalR测试(method: Ring)
  237. /// </summary>
  238. /// <returns></returns>
  239. [HttpGet("ring")]
  240. public async Task RingTest()
  241. {
  242. await _realtimeService.RingAsync(_sessionContext.RequiredUserId,
  243. new RingDto { Id = new Guid().ToString(), From = _sessionContext.Phone ?? "未知号码", To = "12345" },
  244. HttpContext.RequestAborted);
  245. }
  246. /// <summary>
  247. /// signalR测试(method: Answered)
  248. /// </summary>
  249. /// <returns></returns>
  250. [HttpGet("answered")]
  251. public async Task AnsweredTest()
  252. {
  253. await _realtimeService.AnsweredAsync(_sessionContext.RequiredUserId,
  254. new AnsweredDto() { Id = new Guid().ToString(), From = _sessionContext.Phone ?? "未知号码", To = "12345" },
  255. HttpContext.RequestAborted);
  256. }
  257. /// <summary>
  258. /// signalR测试(method: Bye)
  259. /// </summary>
  260. /// <returns></returns>
  261. [HttpGet("bye")]
  262. public async Task ByeTest()
  263. {
  264. await _realtimeService.ByeAsync(_sessionContext.RequiredUserId, new ByeDto() { Id = new Guid().ToString() },
  265. HttpContext.RequestAborted);
  266. }
  267. /// <summary>
  268. ///
  269. /// </summary>
  270. /// <returns></returns>
  271. [AllowAnonymous]
  272. [HttpGet("t2")]
  273. public async Task GetVoiceEndAnswerAsyncTest()
  274. {
  275. //var answer = await _ivrDomainService.GetVoiceEndAnswerAsync("3", HttpContext.RequestAborted);
  276. //Console.WriteLine(answer.Content);
  277. throw new UserFriendlyException(2001, "test");
  278. }
  279. [AllowAnonymous]
  280. [HttpGet("wfdefine")]
  281. public async Task GetWorkflowDefine()
  282. {
  283. }
  284. [AllowAnonymous]
  285. [HttpPost("t3")]
  286. public Task<int> TestDaprPubsub(int data)
  287. {
  288. _logger.LogDebug("receive dapr event, params: {0}", data);
  289. return Task.FromResult(data);
  290. }
  291. [HttpGet("rsa")]
  292. public async Task<string> Rsa()
  293. {
  294. var keyList = RsaKeyGenerator.Pkcs1Key(2048, true);
  295. var privateKey = keyList[0];
  296. var publicKey = keyList[1];
  297. return $"{publicKey} \r\n {privateKey}";
  298. }
  299. }