质疑状态修改
parent
be969cd9f9
commit
16d39d9190
|
@ -20,6 +20,7 @@ using Newtonsoft.Json;
|
|||
using IRaCIS.Core.Application.Service.Inspection.Interface;
|
||||
using IRaCIS.Core.Infrastructure;
|
||||
using IRaCIS.Core.Application.Service.Inspection.DTO;
|
||||
using Nito.AsyncEx;
|
||||
|
||||
namespace IRaCIS.Core.Application.Image.QA
|
||||
{
|
||||
|
@ -35,6 +36,8 @@ namespace IRaCIS.Core.Application.Image.QA
|
|||
private readonly IInspectionService _inspectionService;
|
||||
private object _locker = new object();
|
||||
|
||||
private readonly AsyncLock _mutex = new AsyncLock();
|
||||
|
||||
public QCOperationService(DicomFileStoreHelper dicomFileStoreHelper, IRepository<SubjectVisit> subjectVisitRepository,
|
||||
IRepository<Trial> trialRepository,
|
||||
IMediator mediator,
|
||||
|
@ -85,58 +88,19 @@ namespace IRaCIS.Core.Application.Image.QA
|
|||
throw new BusinessValidationFailedException("当前访视有未关闭的 同意CRC上传的质疑,不允许再次添加质疑");
|
||||
|
||||
}
|
||||
|
||||
QCChallenge? qcChallenge = null;
|
||||
var success = false;
|
||||
lock (_locker)
|
||||
{
|
||||
var trialConfig = _repository.Where<Trial>(t => t.Id == trialId).Select(t => new { TrialId = t.Id, t.QCProcessEnum, t.IsImageConsistencyVerification }).FirstOrDefault();
|
||||
|
||||
|
||||
//获取编号
|
||||
var code = _repository.Where<QCChallenge>(t => t.TrialId == trialId).Select(t => t.ChallengeCode).DefaultIfEmpty().Max();
|
||||
if (trialConfig == null)
|
||||
{
|
||||
throw new BusinessValidationFailedException("项目不存在");
|
||||
}
|
||||
|
||||
#region 处理访视状态变更
|
||||
//var dbSubjectVisit = _subjectVisitRepository.FirstOrDefault(t => t.Id == qaQuestionCommand.SubjectVisitId);
|
||||
|
||||
//if (trialConfig.QCProcessEnum == TrialQCProcess.NotAudit)
|
||||
//{
|
||||
// return ResponseOutput.NotOk("项目配置为不审,不允许添加QA质疑 ");
|
||||
//}
|
||||
//else if (trialConfig.QCProcessEnum == TrialQCProcess.SingleAudit)
|
||||
//{
|
||||
// if ((int)dbSubjectVisit.AuditState == (int)SubjectVisitStateEnum.Submitted)
|
||||
// {
|
||||
// dbSubjectVisit.AuditState = AuditStateEnum.InPrimaryQC;
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// return ResponseOutput.NotOk($"项目配置为单审,当前审核状态不为{SubjectVisitStateEnum.Submitted},不允许添加QA质疑 ");
|
||||
// }
|
||||
//}
|
||||
//else if (trialConfig.QCProcessEnum == TrialQCProcess.DoubleAudit)
|
||||
//{
|
||||
// if ((int)dbSubjectVisit.AuditState == (int)SubjectVisitStateEnum.Submitted)
|
||||
// {
|
||||
// dbSubjectVisit.AuditState = AuditStateEnum.InPrimaryQC;
|
||||
// }
|
||||
// else if ((int)dbSubjectVisit.AuditState == (int)SubjectVisitStateEnum.PrimaryQCPassed)
|
||||
// {
|
||||
// dbSubjectVisit.AuditState = AuditStateEnum.InSecondaryQC;
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// return ResponseOutput.NotOk($"项目配置为双审,访视状态为 {SubjectVisitStateEnum.Submitted}或{SubjectVisitStateEnum.PrimaryQCPassed}才允许添加QA质疑 ");
|
||||
// }
|
||||
//}
|
||||
|
||||
#endregion
|
||||
|
||||
//获取编号
|
||||
var code = _repository.Where<QCChallenge>(t => t.TrialId == trialId).Select(t => t.ChallengeCode).DefaultIfEmpty().Max();
|
||||
|
||||
qcChallenge = _mapper.Map<QCChallenge>(qaQuestionCommand);
|
||||
using (await _mutex.LockAsync())
|
||||
{
|
||||
var qcChallenge = _mapper.Map<QCChallenge>(qaQuestionCommand);
|
||||
|
||||
qcChallenge.QCProcessEnum = trialConfig.QCProcessEnum;
|
||||
qcChallenge.CurrentQCEnum = currentQCType;
|
||||
|
@ -144,53 +108,18 @@ namespace IRaCIS.Core.Application.Image.QA
|
|||
qcChallenge.CreateUser = _userInfo.RealName;
|
||||
qcChallenge.ChallengeCode = code + 1;
|
||||
qcChallenge.UserTypeEnum = (UserTypeEnum)_userInfo.UserTypeEnumInt;
|
||||
_ = _repository.AddAsync(qcChallenge).Result;
|
||||
|
||||
success = _repository.SaveChangesAsync().Result;
|
||||
}
|
||||
|
||||
|
||||
//分开两个事务 处理访视质疑状态
|
||||
await DealChallengeState(qcChallenge.SubjectVisitId);
|
||||
qcChallenge= await _repository.AddAsync(qcChallenge,true);
|
||||
|
||||
return qcChallenge;
|
||||
|
||||
#region 添加的时候把记录给留存
|
||||
//var templateItems = _mapper.Map<List<QARecordTemplateItemDetail>>(visitQaCommand.QATrialTemplateItemList);
|
||||
//templateItems.ForEach(u =>
|
||||
//{
|
||||
// u.IQA = _userInfo.RealName;
|
||||
// u.IQACreateTime = DateTime.Now;
|
||||
// u.IQANote = visitQaCommand.QARecord.Note;
|
||||
// u.IQADeadline = visitQaCommand.QARecord.DeadlineTime;
|
||||
// u.QARecordId = qaRecord.Id;
|
||||
// qaRecord.QARecordTemplateItemDetailList.Add(u);
|
||||
//});
|
||||
|
||||
////添加了QA记录 引用了QA模板后就不允许删除和编辑,需要维护项目模板状态 传统做法
|
||||
//var qaTrailTemplate = _qaTrailTemplateRepository.FirstOrDefault(t => t.Id == visitQaCommand.QARecord.QATrialTemplateId);
|
||||
//qaTrailTemplate.Status = QATrialTemplateStatus.HasQuote;
|
||||
#endregion
|
||||
}
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
var qcChallenge = await _repository.FirstOrDefaultAsync<QCChallenge>(t => t.Id == qaQuestionCommand.Id);
|
||||
return await _repository.UpdateFromDTOAsync<QCChallenge, QCChallengeCommand>(qaQuestionCommand, true);
|
||||
|
||||
if (qcChallenge == null)
|
||||
{
|
||||
throw new BusinessValidationFailedException("QC问题不存在");
|
||||
};
|
||||
|
||||
_mapper.Map(qaQuestionCommand, qcChallenge);
|
||||
|
||||
var success = await _repository.SaveChangesAsync();
|
||||
|
||||
await DealChallengeState(qcChallenge.SubjectVisitId);
|
||||
|
||||
|
||||
return qcChallenge;
|
||||
|
||||
}
|
||||
|
||||
|
@ -237,39 +166,14 @@ namespace IRaCIS.Core.Application.Image.QA
|
|||
|
||||
var success = await _repository.SaveChangesAsync();
|
||||
|
||||
await DealChallengeState(subjectVisitId);
|
||||
|
||||
return ResponseOutput.Result(success);
|
||||
}
|
||||
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// 访视级别统计 质疑最新的状态
|
||||
/// </summary>
|
||||
/// <param name="subjectVisitId"></param>
|
||||
private async Task DealChallengeState(Guid subjectVisitId)
|
||||
{
|
||||
var sv = await _repository.FirstOrDefaultAsync<SubjectVisit>(t => t.Id == subjectVisitId);
|
||||
|
||||
|
||||
var closedStateList = await _repository.Where<QCChallenge>(t => t.SubjectVisitId == subjectVisitId).Select(t => t.IsClosed).ToListAsync();
|
||||
|
||||
if (closedStateList.Count == 0)
|
||||
{
|
||||
sv.ChallengeState = ChallengeStateEnum.No;
|
||||
}
|
||||
else if (closedStateList.All(t => t is true))
|
||||
{
|
||||
sv.ChallengeState = ChallengeStateEnum.HaveAndAllClosed;
|
||||
}
|
||||
else
|
||||
{
|
||||
sv.ChallengeState = ChallengeStateEnum.HaveAndHaveNotClosed;
|
||||
}
|
||||
await _repository.SaveChangesAsync();
|
||||
}
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// 删除QC质疑记录
|
||||
|
@ -1063,7 +967,8 @@ namespace IRaCIS.Core.Application.Image.QA
|
|||
await _dicomStudyRepository.DeleteAsync(study, true);
|
||||
var succeess2 = await _repository.BatchDeleteAsync<DicomInstance>(t => t.StudyId == id);
|
||||
|
||||
var DicomSeriess = await _repository.GetQueryable<DicomSeries>().Where(t => t.StudyId == id).Select(x => new {
|
||||
var DicomSeriess = await _repository.GetQueryable<DicomSeries>().Where(t => t.StudyId == id).Select(x => new
|
||||
{
|
||||
x.StudyId,
|
||||
x.SubjectId,
|
||||
x.SiteId,
|
||||
|
|
|
@ -55,9 +55,11 @@ namespace IRaCIS.Core.Infra.EFCore
|
|||
|
||||
Task<T> InsertOrUpdateAsync<T, TFrom>(TFrom from, bool autoSave = false, params EntityVerifyExp<T>[] verify) where T : Entity;
|
||||
|
||||
EntityEntry<T> Entry<T>(T t) where T : Entity;
|
||||
Task<T> InsertFromDTOAsync<T, TFrom>(TFrom from, bool autoSave = false, params EntityVerifyExp<T>[] verify) where T : Entity;
|
||||
|
||||
//Task<T> InsertOrUpdateAsync<T, TFrom>(this DbSet<T> dbset, TFrom from, bool autoSave = false, params EntityVerifyExp<T>[] verify) where T : Entity;
|
||||
Task<T> UpdateFromDTOAsync<T, TFrom>(TFrom from, bool autoSave = false, bool ignoreDtoNullProperty = true, params EntityVerifyExp<T>[] verify) where T : Entity;
|
||||
|
||||
EntityEntry<T> Entry<T>(T t) where T : Entity;
|
||||
|
||||
Task<bool> AnyAsync<T>(Expression<Func<T, bool>> filter, bool ignoreQueryFilters = false) where T : Entity;
|
||||
|
||||
|
@ -77,7 +79,7 @@ namespace IRaCIS.Core.Infra.EFCore
|
|||
|
||||
Task<bool> DeleteAsync<T>(T entity, bool autoSave = false) where T : Entity;
|
||||
|
||||
Task<bool> DeleteManyAsync<T>(IEnumerable<T> entities, bool autoSave = false) where T : Entity;
|
||||
//Task<bool> DeleteManyAsync<T>(IEnumerable<T> entities, bool autoSave = false) where T : Entity;
|
||||
|
||||
Task<bool> SaveChangesAsync();
|
||||
|
||||
|
@ -90,6 +92,8 @@ namespace IRaCIS.Core.Infra.EFCore
|
|||
{
|
||||
private IRaCISDBContext _dbContext { get; }
|
||||
|
||||
|
||||
|
||||
public IMapper _mapper { get; set; }
|
||||
|
||||
public IUserInfo _userInfo { get; set; }
|
||||
|
@ -130,65 +134,21 @@ namespace IRaCIS.Core.Infra.EFCore
|
|||
}
|
||||
|
||||
|
||||
|
||||
public async Task<T> InsertOrUpdateAsync<T, TFrom>(TFrom from, bool autoSave = false, params EntityVerifyExp<T>[] verify) where T : Entity
|
||||
private async Task EntityVerifyAsync<T>(bool isAdd, EntityVerifyExp<T>[] verify, Guid? entitydId = null) where T : Entity
|
||||
{
|
||||
|
||||
var entity = _mapper.Map<T>(from);
|
||||
|
||||
if (entity.Id == Guid.Empty)
|
||||
if (isAdd)
|
||||
{
|
||||
// verifyExp
|
||||
|
||||
//await verify.Where(t => t.verifyType != VerifyEnum.OnlyUpdate && t.IsVerify).ToList().ForeachAsync(async verifyItem =>
|
||||
//{
|
||||
// if (await _dbContext.Set<T>().AnyAsync(verifyItem.VerifyExp).ConfigureAwait(false))
|
||||
// {
|
||||
// throw new BusinessValidationFailedException(verifyItem.VerifyMsg);
|
||||
// }
|
||||
//});
|
||||
|
||||
foreach (var verifyItem in verify.Where(t => t.verifyType != VerifyEnum.OnlyUpdate && t.IsVerify))
|
||||
{
|
||||
if (await _dbContext.Set<T>().AnyAsync(verifyItem.VerifyExp).ConfigureAwait(false))
|
||||
if (await _dbContext.Set<T>().IgnoreQueryFilters().AnyAsync(verifyItem.VerifyExp).ConfigureAwait(false))
|
||||
{
|
||||
throw new BusinessValidationFailedException(verifyItem.VerifyMsg);
|
||||
}
|
||||
}
|
||||
|
||||
await _dbContext.Set<T>().AddAsync(entity).ConfigureAwait(false);
|
||||
|
||||
if (autoSave)
|
||||
{
|
||||
await SaveChangesAsync();
|
||||
|
||||
}
|
||||
return entity;
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
// verifyExp
|
||||
|
||||
//await verify.Where(t => t.verifyType != VerifyEnum.OnlyAdd && t.IsVerify).ToList().ForeachAsync(async verifyItem =>
|
||||
// {
|
||||
// if (verifyItem.verifyType == VerifyEnum.OnlyUpdate)
|
||||
// {
|
||||
// if (await _dbContext.Set<T>().AnyAsync(verifyItem.VerifyExp).ConfigureAwait(false))
|
||||
// {
|
||||
// throw new BusinessValidationFailedException(verifyItem.VerifyMsg);
|
||||
// }
|
||||
// }
|
||||
// else if (verifyItem.verifyType == VerifyEnum.Both)
|
||||
// {
|
||||
// if (await _dbContext.Set<T>().AnyAsync(verifyItem.VerifyExp.And(t => t.Id != entity.Id)).ConfigureAwait(false))
|
||||
// {
|
||||
// throw new BusinessValidationFailedException(verifyItem.VerifyMsg);
|
||||
// }
|
||||
// }
|
||||
|
||||
// });
|
||||
|
||||
foreach (var verifyItem in verify.Where(t => t.verifyType != VerifyEnum.OnlyAdd && t.IsVerify))
|
||||
{
|
||||
if (verifyItem.verifyType == VerifyEnum.OnlyUpdate)
|
||||
|
@ -200,25 +160,97 @@ namespace IRaCIS.Core.Infra.EFCore
|
|||
}
|
||||
else if (verifyItem.verifyType == VerifyEnum.Both)
|
||||
{
|
||||
if (await _dbContext.Set<T>().IgnoreQueryFilters().AnyAsync(verifyItem.VerifyExp.And(t => t.Id != entity.Id)).ConfigureAwait(false))
|
||||
if (await _dbContext.Set<T>().IgnoreQueryFilters().AnyAsync(verifyItem.VerifyExp.And(t => t.Id != entitydId)).ConfigureAwait(false))
|
||||
{
|
||||
throw new BusinessValidationFailedException(verifyItem.VerifyMsg);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
var dbEntity = await FirstOrDefaultAsync<T>(t => t.Id == entity.Id).ConfigureAwait(false);
|
||||
}
|
||||
|
||||
public async Task<T> InsertFromDTOAsync<T, TFrom>(TFrom from, bool autoSave = false,
|
||||
params EntityVerifyExp<T>[] verify) where T : Entity
|
||||
{
|
||||
|
||||
var entity = _mapper.Map<T>(from);
|
||||
|
||||
await EntityVerifyAsync(true, verify);
|
||||
|
||||
|
||||
entity = await AddAsync(entity, autoSave);
|
||||
|
||||
|
||||
return entity;
|
||||
}
|
||||
|
||||
public async Task<T> UpdateFromDTOAsync<T, TFrom>(TFrom from, bool autoSave = false, bool ignoreDtoNullProperty = true, params EntityVerifyExp<T>[] verify) where T : Entity
|
||||
{
|
||||
var entity = _mapper.Map<T>(from);
|
||||
|
||||
await EntityVerifyAsync(false, verify, entity.Id);
|
||||
|
||||
var dbEntity = await _dbContext.Set<T>().IgnoreQueryFilters().FirstOrDefaultAsync(t => t.Id == entity.Id).ConfigureAwait(false);
|
||||
|
||||
if (dbEntity == null)
|
||||
{
|
||||
throw new BusinessValidationFailedException(
|
||||
" Update object not exist in db,Please check if the parameter Id is passed incorrectly");
|
||||
}
|
||||
|
||||
var dbBeforEntity = dbEntity.Clone();
|
||||
|
||||
|
||||
_mapper.Map(from, dbEntity);
|
||||
|
||||
|
||||
//DTO null 属性不更新 防止意外操作,导致保存数据错误,或者 add 和update 用一个模型,更新的时候,只传递了部分字段,导致,不想更新的字段,因为没传递值,用null覆盖了
|
||||
// Guid?属性 为null 时 映射到 Guid 时 默认会变成 Guid.Empty
|
||||
if (ignoreDtoNullProperty)
|
||||
{
|
||||
var dbEntityProp = typeof(T).GetProperties();
|
||||
foreach (var propertyInfo in from.GetType().GetProperties())
|
||||
{
|
||||
if (propertyInfo.GetValue(from) == null && dbEntityProp.Any(t => t.Name == propertyInfo.Name))
|
||||
{
|
||||
_dbContext.Entry(dbEntity).Property(propertyInfo.Name).IsModified = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
await SaveChangesAsync(autoSave);
|
||||
|
||||
|
||||
return dbBeforEntity;
|
||||
}
|
||||
|
||||
|
||||
private async Task<bool> SaveChangesAsync(bool autoSave)
|
||||
{
|
||||
if (autoSave)
|
||||
{
|
||||
await SaveChangesAsync();
|
||||
return await SaveChangesAsync();
|
||||
}
|
||||
else
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return dbBeforEntity;
|
||||
|
||||
|
||||
public async Task<T> InsertOrUpdateAsync<T, TFrom>(TFrom from, bool autoSave = false, params EntityVerifyExp<T>[] verify) where T : Entity
|
||||
{
|
||||
var entity = _mapper.Map<T>(from);
|
||||
|
||||
|
||||
if (entity.Id == Guid.Empty)
|
||||
{
|
||||
return await InsertFromDTOAsync(from, autoSave, verify);
|
||||
}
|
||||
else
|
||||
{
|
||||
return await UpdateFromDTOAsync(from, autoSave, false, verify);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue