TaskController.cs 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel.DataAnnotations;
  4. using System.Data.SqlClient;
  5. using System.IO;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. using DW5S.DTO;
  10. using DW5S.Entity;
  11. using DW5S.Repostory;
  12. using System.Threading;
  13. using DW5S.WebApi;
  14. using Microsoft.AspNetCore.Mvc;
  15. using Serilog;
  16. using Serilog.Core;
  17. using DW5S.Service;
  18. using Newtonsoft.Json;
  19. using System.Security.Policy;
  20. namespace DW5S.Controllers
  21. {
  22. /// <summary>
  23. /// 任务相关接口
  24. /// </summary>
  25. public class TaskController : BaseController
  26. {
  27. ILogger logger { get; set; }
  28. IUnitOfWork unitOfWork { get; set; }
  29. [Autowired]
  30. HttpClient client { get; set; }
  31. [HttpGet]
  32. public AjaxResult<string> Test()
  33. {
  34. return Success("1");
  35. }
  36. /// <summary>
  37. /// 获取客户端IP地址
  38. /// </summary>
  39. /// <returns></returns>
  40. [HttpGet]
  41. public AjaxResult<string> GetClientIP()
  42. {
  43. try
  44. {
  45. while (true)
  46. {
  47. var factory = IocContainer.GetService<IHttpClientFactory>();
  48. var client1 = factory.CreateClient("");
  49. var response = client1.GetAsync("http://192.168.1.7:8090/api/task/test").Result;
  50. response.EnsureSuccessStatusCode();
  51. var result = response.Content.ReadAsStringAsync().Result;
  52. };
  53. var ip = RemoteIp;
  54. return Success(ip);
  55. }
  56. catch (Exception ex)
  57. {
  58. string error = "获取客户端IP出错";
  59. logger.Error(ex, error);
  60. return Error<string>(error);
  61. }
  62. }
  63. /// <summary>
  64. /// 停止任务
  65. /// </summary>
  66. /// <param name="dto">任务停止参数</param>
  67. /// <returns></returns>
  68. [HttpPost]
  69. public async Task<AjaxResult> StopAsync(TaskStopHandleDto dto)
  70. {
  71. try
  72. {
  73. var repsTask = unitOfWork.Of<TaskInfo>();
  74. var item = await repsTask.GetByIdAsync(dto.ID);
  75. if (item == null)
  76. {
  77. return Error($"任务停止失败,找不到ID={dto.ID}的任务");
  78. }
  79. if (item.TaskState == EnumTaskState.Stopped)
  80. Thread.Sleep(2000);
  81. item.TaskState = EnumTaskState.Stopped;
  82. await repsTask.AddOrUpdateAsync(item);
  83. await unitOfWork.SaveAsync();
  84. Messenger.Defalut.Pub("任务状态改变", dto.ID);
  85. if (dto.StopType == EnumTaskStopType.Properly)
  86. logger.Information($"任务停止完成,ID={dto.ID},停止原因={dto.StopReason}");
  87. else
  88. logger.Error($"任务停止完成,ID={dto.ID},停止原因={dto.StopReason}");
  89. return Success();
  90. }
  91. catch (Exception ex)
  92. {
  93. string msg = $"任务停止异常.ID={dto.ID}";
  94. logger.Error(ex, msg);
  95. return Error(msg);
  96. }
  97. }
  98. }
  99. }