From 4d17fa724871eed6a4185b23a689fc7b94556b1f Mon Sep 17 00:00:00 2001
From: 移动系统liao <liaoxujun@qq.com>
Date: 星期三, 25 九月 2024 13:24:15 +0800
Subject: [PATCH] no message

---
 cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs |   71 ++++++++++++++++++++++++++++-------
 1 files changed, 57 insertions(+), 14 deletions(-)

diff --git a/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs b/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs
index 74c4038..76f27a1 100644
--- a/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs
+++ b/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs
@@ -3,9 +3,11 @@
 using cylsg.Core;
 using cylsg.Model.OrderModel;
 using cylsg.Model.UserModel;
+using EzTencentCloud;
 using Furion.LinqBuilder;
 using MapsterMapper;
 using Org.BouncyCastle.Asn1.X509;
+using SqlSugar.Extensions;
 using System;
 using System.Collections.Generic;
 using System.Linq;
@@ -26,11 +28,13 @@
         private readonly ISystemService _systemService;
         private ISqlSugarClient _sqlSugarClient;
         private IMapper _mapper;
-        public OrderWorkerAppService(ISystemService systemService, ISqlSugarClient sqlSugarClient, IMapper mapper)
+        private readonly ITencentCloudService _tencentCloudService;
+        public OrderWorkerAppService(ISystemService systemService, ISqlSugarClient sqlSugarClient, IMapper mapper,ITencentCloudService tencentCloudService)
         {
             _systemService = systemService;
             _sqlSugarClient = sqlSugarClient;
             _mapper = mapper;
+            _tencentCloudService = tencentCloudService;
         }
 
 
@@ -176,6 +180,7 @@
 
             return result;
         }
+
 
 
 
@@ -354,6 +359,7 @@
             var orderRes = new BaseRepository<Order>();
             var orderBiddingDetailRes = new BaseRepository<OrderBiddingDetail>();
             var OrderBiddingDetailCheckRes = new BaseRepository<OrderBiddingDetailCheck>();
+            var userWorkerRes = new BaseRepository<UserWorker>();
             var order = await orderRes.GetByIdAsync(baoMingDto.OrderId);
             if (order == null || order.OrderStatus > 1)
             {
@@ -373,6 +379,11 @@
                     throw Oops.Oh("褰撳ぉ鐨勬墦鍗″凡缁忔彁浜わ紝涓嶈兘鎵撳崱锛�");
                 }
                 orderBiddingDetailDto = _mapper.Map<OrderBiddingDetailDto>(orderBiddingDetail);
+                orderBiddingDetailDto.WorkerUserId = orderBidding.WorkerUserId;
+                var worker  = await  userWorkerRes.GetFirstAsync(x => x.UserId == orderBidding.WorkerUserId);
+                if(worker != null)
+                    orderBiddingDetailDto.WorkerName = worker.name;
+
                 var orderBiddingDetailChecks = await OrderBiddingDetailCheckRes.GetListAsync(x => x.OrderBiddingDetailId == orderBiddingDetail.Id  && x.IsDeleted == false && x.IsEn == true);
                 orderBiddingDetailDto.orderBiddingDetailCheck = _mapper.Map<List<OrderBiddingDetailCheckDto>>(orderBiddingDetailChecks); 
             }
@@ -402,24 +413,54 @@
             var orderBiddingDetailRes = new BaseRepository<OrderBiddingDetail>();
             var OrderBiddingDetailCheckRes = new BaseRepository<OrderBiddingDetailCheck>();
 
-            var orderBidding = await orderBiddingRes.GetByIdAsync(dakaDto.OrderBiddingId);
+            var order = await orderRes.GetByIdAsync(dakaDto.OrderId);
+            if (order == null || order.OrderStatus > 1)
+            {
+                throw Oops.Oh("璇ユ嫑宸ョ姸鎬佸凡鏃犳硶鎵撳崱锛�");
+            }
+
+            var orderBidding = await orderBiddingRes.GetFirstAsync(x => x.OrderId == dakaDto.OrderId && x.WorkerUserId == userid && x.IsSelected == true && x.IsEn == true && x.IsDeleted == false );//GetByIdAsync(dakaDto.OrderBiddingId);
             if (orderBidding == null || orderBidding.IsDeleted ==true || orderBidding.IsEn == false || orderBidding.IsSelected !=true )
             {
                 throw Oops.Oh("璇ユ姇閫掔姸鎬佹棤娉曟墦鍗★紒");
             }
 
-            var order = await orderRes.GetByIdAsync(orderBidding.OrderId);
-            if (order == null || order.OrderStatus > 1)
-            {
-                throw Oops.Oh("璇ユ嫑宸ョ姸鎬佸凡鏃犳硶鎵撳崱锛�");
-            }
+           
             bool res;
             var dateTime = DateTime.Now.Date;
+            if ( dateTime < order.WordStartTime.Value && dateTime > order.WordEndTime.Value )
+            {
+                throw Oops.Oh("涓嶅湪鍏佽鎵撳崱鐨勬椂闂磋寖鍥达紒");
+            }
             var orderBiddingDetail = await orderBiddingDetailRes.GetFirstAsync(x => x.OrderBiddingId == orderBidding.Id && x.WorkDate == dateTime && x.IsDeleted == false && x.IsEn == true);
             if (orderBiddingDetail!=null && orderBiddingDetail.IsShenPi>0)
             {
                 throw Oops.Oh("璇ユ墦鍗¤褰曞凡缁忓鎵癸紝涓嶈兘鎵撳崱锛�");
             }
+            //浜鸿劯璇嗗埆
+            if (App.Configuration["VerifyFace:Enable"].ObjToBool())
+            {
+                if (string.IsNullOrWhiteSpace(dakaDto.FaceImg))
+                {
+                    throw Oops.Oh("鏈瘑鍒汉鑴�");
+                }
+
+                var UserWorkRes = await new BaseRepository<UserWorker>().GetFirstAsync(x => x.UserId == userid);
+                if (UserWorkRes == null)
+                {
+                    throw Oops.Oh("鍛樺伐鏈敞鍐屾垚宸ヤ汉");
+                }
+                var faseres =  _tencentCloudService.VerifyFace(dakaDto.FaceImg, UserWorkRes.IdCode);
+
+                if (faseres.IsMatch != true)
+                {
+                    throw Oops.Oh("涓嶆槸鏈汉");
+                }
+            }
+
+
+
+
             if(orderBiddingDetail == null)
             {
                 orderBiddingDetail = new OrderBiddingDetail();
@@ -711,21 +752,23 @@
             //var OrderBiddingDetailCheckRes = new BaseRepository<OrderBiddingDetailCheck>();
 
             var orderBiddingDetail = await orderBiddingDetailRes.GetByIdAsync(dakaDto.OrderBiddingDetailId);
+            if (orderBiddingDetail == null || orderBiddingDetail.IsShenPi > 1 || orderBiddingDetail.IsDeleted == true || orderBiddingDetail.IsEn == false)
+            {
+                throw Oops.Oh("璇ユ墦鍗$姸鎬佸凡鏃犳硶鎵撳崱纭锛�");
+            }
             var orderBidding = await orderBiddingRes.GetByIdAsync(orderBiddingDetail.OrderBiddingId);
-            var order = await orderRes.GetByIdAsync(orderBidding.OrderId);
-
             if (orderBidding == null || orderBidding.IsDeleted == true || orderBidding.IsEn == false || orderBidding.IsSelected != true)
             {
                 throw Oops.Oh("璇ユ姇閫掔姸鎬佹棤娉曟墦鍗$‘璁わ紒");
             }
-            if (order == null || order.OrderStatus > 1)
+            var order = await orderRes.GetByIdAsync(orderBidding.OrderId);
+
+            
+            if (order == null || order.OrderStatus > 1 || order.IsDeleted == true || order.IsEn == false )
             {
                 throw Oops.Oh("璇ユ嫑宸ョ姸鎬佸凡鏃犳硶鎵撳崱纭锛�");
             }
-            if (orderBiddingDetail == null || orderBiddingDetail.IsShenPi > 1)
-            {
-                throw Oops.Oh("璇ユ墦鍗$姸鎬佸凡鏃犳硶鎵撳崱纭锛�");
-            }
+            
 
 
             orderBiddingDetail.WorkTime = dakaDto.WorkTime;

--
Gitblit v1.9.1