|
|
@@ -0,0 +1,163 @@
|
|
|
+using Quartz;
|
|
|
+using OASystem.API.OAMethodLib.QiYeWeChatAPI;
|
|
|
+using OASystem.Domain.ViewModels.QiYeWeChat;
|
|
|
+
|
|
|
+namespace OASystem.API.OAMethodLib.Quartz.Jobs
|
|
|
+{
|
|
|
+ /// <summary>
|
|
|
+ /// 每周五下午4点执行的定时任务
|
|
|
+ /// </summary>
|
|
|
+ public class WeeklyFridayJob : IJob
|
|
|
+ {
|
|
|
+ private readonly ILogger<WeeklyFridayJob> _logger;
|
|
|
+ private readonly SqlSugarClient _sqlSugar;
|
|
|
+ private readonly IQiYeWeChatApiService _qiYeWeChatApiService;
|
|
|
+ private readonly HttpClient _httpClient;
|
|
|
+
|
|
|
+ public WeeklyFridayJob(ILogger<WeeklyFridayJob> logger, SqlSugarClient sqlSugar
|
|
|
+ , IHttpClientFactory httpClientFactory, IQiYeWeChatApiService qiYeWeChatApiService)
|
|
|
+ {
|
|
|
+ _logger = logger;
|
|
|
+ _sqlSugar = sqlSugar;
|
|
|
+ _httpClient = httpClientFactory.CreateClient();
|
|
|
+ _qiYeWeChatApiService = qiYeWeChatApiService;
|
|
|
+ }
|
|
|
+
|
|
|
+ public async Task Execute(IJobExecutionContext context)
|
|
|
+ {
|
|
|
+ var jobName = context.JobDetail.Key.Name;
|
|
|
+ _logger.LogInformation($"开始执行任务 {jobName},时间:{DateTime.Now:yyyy-MM-dd HH:mm:ss}");
|
|
|
+
|
|
|
+ try
|
|
|
+ {
|
|
|
+ var startDate = DateTime.Today.AddDays(-4);
|
|
|
+ var endDate = DateTime.Today.AddDays(1);
|
|
|
+ string baseUrl = "http://localhost:5256";
|
|
|
+ var createUserId = 4;
|
|
|
+
|
|
|
+ var sqSetting = _sqlSugar.Queryable<Sys_SetData>().First(x => x.Id == 1417);
|
|
|
+ if (sqSetting != null)
|
|
|
+ {
|
|
|
+ Dictionary<int, List<int>> result = JsonConvert.DeserializeObject<Dictionary<int, List<int>>>(sqSetting.Remark);
|
|
|
+
|
|
|
+ result = new Dictionary<int, List<int>> { { 235, new List<int> { 258 } } };
|
|
|
+
|
|
|
+ foreach (var item in result.Keys)
|
|
|
+ {
|
|
|
+ var keyUser = await _sqlSugar.Queryable<Sys_Users>()
|
|
|
+ .FirstAsync(x => x.Id == item);
|
|
|
+ var users = await _sqlSugar.Queryable<Sys_Users>()
|
|
|
+ .LeftJoin<Sys_Department>((u, d) => u.DepId == d.Id)
|
|
|
+ .LeftJoin<Sys_JobPost>((u, d, jp) => u.JobPostId == jp.Id)
|
|
|
+ .Where((u, d, jp) => u.IsDel == 0 && result[item].Contains(u.Id) && u.Id != item)
|
|
|
+ .Select((u, d, jp) => new { u.Id, u.CnName, DepName = d.DepName ?? "", JobName = jp.JobName ?? "" })
|
|
|
+ .ToListAsync();
|
|
|
+
|
|
|
+ foreach (var user in users)
|
|
|
+ {
|
|
|
+ // 构建API URL
|
|
|
+ string apiUrl = $"{baseUrl}/api/PersonnelModule/AiPerformanceAnalysis_AllDepartment";
|
|
|
+
|
|
|
+ // 构建查询参数
|
|
|
+ var queryParams = new Dictionary<string, string>
|
|
|
+ {
|
|
|
+ { "userId", user.Id.ToString() },
|
|
|
+ { "start", startDate.ToString("yyyy-MM-dd HH:mm:ss") },
|
|
|
+ { "end", endDate.ToString("yyyy-MM-dd HH:mm:ss") },
|
|
|
+ { "createUserId", createUserId.ToString() },
|
|
|
+ { "isMonthData", "true" }
|
|
|
+ };
|
|
|
+
|
|
|
+ // 构建完整URL
|
|
|
+ var queryString = string.Join("&", queryParams.Select(kvp => $"{kvp.Key}={Uri.EscapeDataString(kvp.Value)}"));
|
|
|
+ string fullUrl = $"{apiUrl}?{queryString}";
|
|
|
+
|
|
|
+ _logger.LogInformation($"正在为用户 {user.CnName}(ID:{user.Id}, 部门:{user.DepName}) 生成绩效数据...");
|
|
|
+ _logger.LogInformation($"API URL: {fullUrl}");
|
|
|
+
|
|
|
+ // 发送HTTP GET请求
|
|
|
+ var response = await _httpClient.GetAsync(fullUrl);
|
|
|
+ var responseContent = await response.Content.ReadAsStringAsync();
|
|
|
+
|
|
|
+ if (response.IsSuccessStatusCode)
|
|
|
+ {
|
|
|
+ // 尝试解析响应结果
|
|
|
+ try
|
|
|
+ {
|
|
|
+ var resultJson = JsonConvert.DeserializeObject<JsonView>(responseContent);
|
|
|
+ if (resultJson != null && resultJson.Code == 200)
|
|
|
+ {
|
|
|
+ _logger.LogInformation($"用户 {user.CnName}(ID:{user.Id}, 部门:{user.DepName}) 绩效数据生成成功");
|
|
|
+ //生成PDF
|
|
|
+ var url = $"{baseUrl}/api/PersonnelModule/AiPerformanceAnalysis_JobMarketingFileDown";
|
|
|
+ //构建PDF查询参数
|
|
|
+ var queryParamsPdf = new Dictionary<string, string>
|
|
|
+ {
|
|
|
+ { "userId", user.Id.ToString() },
|
|
|
+ { "start", startDate.ToString("yyyy-MM-dd") },
|
|
|
+ { "end", endDate.ToString("yyyy-MM-dd") },
|
|
|
+ };
|
|
|
+
|
|
|
+ var queryStringPdf = string.Join("&", queryParamsPdf.Select(kvp => $"{kvp.Key}={Uri.EscapeDataString(kvp.Value)}"));
|
|
|
+ url = $"{url}?{queryStringPdf}";
|
|
|
+
|
|
|
+ _logger.LogInformation($"用户 {user.CnName}(ID:{user.Id}, 部门:{user.DepName}) 开始生成PDF:{url}");
|
|
|
+
|
|
|
+ var pdfUrl = await _httpClient.PostAsync(url, new StringContent(queryStringPdf));
|
|
|
+
|
|
|
+ if (pdfUrl.IsSuccessStatusCode)
|
|
|
+ {
|
|
|
+ _logger.LogInformation($"用户 {user.CnName}(ID:{user.Id}, 部门:{user.DepName}) 开始生成PDF:{pdfUrl.StatusCode}");
|
|
|
+ var pdfContent = await pdfUrl.Content.ReadAsStringAsync();
|
|
|
+ _logger.LogInformation($"用户 {user.CnName}(ID:{user.Id}, 部门:{user.DepName}) 绩效数据生成PDF成功:{pdfContent}");
|
|
|
+ var pdfContentJson = JObject.Parse(pdfContent);
|
|
|
+ var pdfUrlString = pdfContentJson["data"]["url"].ToString();
|
|
|
+ var pdfUrlSeed = new Uri(pdfUrlString);
|
|
|
+ var pdfBytes = await _httpClient.GetByteArrayAsync(pdfUrlSeed);
|
|
|
+ var pdfFile = new FormFile(new MemoryStream(pdfBytes), 0, pdfBytes.Length, "pdf", "pdf");
|
|
|
+
|
|
|
+
|
|
|
+ await _qiYeWeChatApiService.EmailSendAsync(new EmailRequestDto
|
|
|
+ {
|
|
|
+ ToEmails = new List<string> { keyUser.Email },
|
|
|
+ Subject = $"用户 {user.CnName}(部门:{user.DepName} 日期区间:{startDate.ToString("yyyy-MM-dd")} 至 {endDate.ToString("yyyy-MM-dd")}) 绩效数据",
|
|
|
+ Body = "员工绩效推送,请查看附件。",
|
|
|
+ Files = new[] { pdfFile }
|
|
|
+ });
|
|
|
+ }
|
|
|
+ else
|
|
|
+ {
|
|
|
+
|
|
|
+ _logger.LogWarning($"用户 {user.CnName}(ID:{user.Id}, 部门:{user.DepName}) 生成PDF失败:{pdfUrl.StatusCode}");
|
|
|
+ _logger.LogWarning($"用户 {user.CnName}(ID:{user.Id}, 部门:{user.DepName}) 生成PDF失败:{pdfUrl.Content.ReadAsStringAsync()}");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ else
|
|
|
+ {
|
|
|
+ _logger.LogWarning($"用户 {user.CnName}(ID:{user.Id}, 部门:{user.DepName}) 绩效数据生成失败:{resultJson?.Msg ?? "未知错误"}");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ catch (Exception ex)
|
|
|
+ {
|
|
|
+ _logger.LogError(ex, $"解析用户 {user.CnName}(ID:{user.Id}, 部门:{user.DepName}) 的API响应失败");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ else
|
|
|
+ {
|
|
|
+ _logger.LogError($"用户 {user.CnName}(ID:{user.Id}, 部门:{user.DepName}) 绩效数据生成API调用失败,状态码: {response.StatusCode}, 响应内容: {responseContent}");
|
|
|
+ }
|
|
|
+
|
|
|
+ // 添加延迟,避免请求过于频繁
|
|
|
+ await Task.Delay(3000); // 延迟3秒
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+ catch (Exception ex)
|
|
|
+ {
|
|
|
+ _logger.LogError(ex, $"任务 {jobName} 执行失败");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|