sunpengfei
2025-08-12 157e63d5bae9121307a6d0cfab36b1a5df3cd5ea
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
using FlexJobApi.Core;
using Furion.DatabaseAccessor;
using Furion.FriendlyException;
using MediatR;
using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace FlexJobApi.FlexJobServer.Application
{
    /// <summary>
    /// 报名任务
    /// </summary>
    public class ApplyTaskCommandHandler(
            IRepository<TaskInfoUser> repTaskInfoUser,
            IRepository<User> repUser,
            IRepository<TaskInfo> repTaskInfo,
            IRepository<EnterpriseEmployee> repEnterpriseEmployee
        ) :
        IRequestHandler<ApplyTaskCommand, int>
 
    {
        private readonly IRepository<TaskInfoUser> repTaskInfoUser = repTaskInfoUser;
        private readonly IRepository<User> repUser = repUser;
        private readonly IRepository<TaskInfo> repTaskInfo = repTaskInfo;
        private readonly IRepository<EnterpriseEmployee> repEnterpriseEmployee = repEnterpriseEmployee;
 
        /// <summary>
        /// 报名任务
        /// </summary>
        /// <param name="request"></param>
        /// <param name="cancellationToken"></param>
        /// <returns></returns>
        public async Task<int> Handle(ApplyTaskCommand request, CancellationToken cancellationToken)
        {
            var logier = JwtUtils.GetCurrentLogier();
            var applyTaskIds = await repTaskInfoUser.AsQueryable().AsNoTracking()
                .Include(it => it.TaskInfo)
                .Where(it => request.Ids.Contains(it.TaskInfoId) && it.EnterpriseEmployee.UserId == logier.Id)
                .Select(it => it.TaskInfoId)
                .ToListAsync(cancellationToken);
            var taskIds = request.Ids.Where(it => !applyTaskIds.Contains(it)).ToList();
            if (taskIds.IsNotNull())
            {
                var user = await repUser.AsQueryable().AsNoTracking()
                    .Include(it => it.UserAuth)
                    .Where(it => it.Id == logier.Id)
                    .Select(it => new
                    {
                        it.Name,
                        it.Identity,
                        it.ContactPhoneNumber,
                        it.Gender,
                        it.Age,
                        it.UserAuth.IdentityImg,
                        it.UserAuth.IdentityBackImg
                    })
                    .FirstOrDefaultAsync(cancellationToken);
                if (user == null) throw Oops.Oh(EnumErrorCodeType.s404, "该账号");
                var tasks = await repTaskInfo.AsQueryable().AsNoTracking()
                    .Where(it => taskIds.Contains(it.Id))
                    .Select(it => new
                    {
                        it.Id,
                        it.EnterpriseId
                    })
                    .ToListAsync(cancellationToken);
                var enterpriseIds = tasks.DistinctSelect(it => it.EnterpriseId);
                var employees = await repEnterpriseEmployee.AsQueryable()
                    .Where(it =>
                        enterpriseIds.Contains(it.EnterpriseId)
                        && (it.UserId == logier.Id
                        || it.Name == user.Name
                        && it.Identity == user.Identity))
                    .ToListAsync();
                foreach (var taskId in taskIds)
                {
                    var task = tasks.FirstOrDefault(it => it.Id == taskId);
                    if (task == null) throw Oops.Oh(EnumErrorCodeType.s404, "该任务");
                    var employee = employees.FirstOrDefault(it => it.EnterpriseId == task.EnterpriseId && it.UserId == logier.Id);
                    if (employee == null)
                    {
                        employee = employees.FirstOrDefault(it => it.EnterpriseId == task.EnterpriseId && it.Name == user.Name && it.Identity == user.Name);
                    }
                    if (employee == null)
                    {
                        employee = new EnterpriseEmployee
                        {
                            EnterpriseId = task.EnterpriseId,
                            UserId = logier.Id,
                            Name = user.Name,
                            Identity = user.Identity,
                            ContactPhoneNumber = user.ContactPhoneNumber,
                            Gender = user.Gender,
                            Age = user.Age,
                            IdentityImg = user.IdentityImg,
                            IdentityBackImg = user.IdentityBackImg,
                            HireStatus = EnumTaskUserHireStatus.Wait,
                        };
                        await repEnterpriseEmployee.InsertAsync(employee);
                    }
                    else
                    {
                        employee.UserId = logier.Id;
                        await repEnterpriseEmployee.InsertAsync(employee);
                    }
                    var entity = new TaskInfoUser
                    {
                        TaskInfoId = taskId,
                        EnterpriseEmployeeId = employee.Id,
                    };
                    await repTaskInfoUser.InsertAsync(entity);
                }
            }
            return taskIds.Count;
        }
    }
}