123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019 |
- using DataSharing.Province.SendTask.SubmitCaseInfo;
- using DataSharing.RawData;
- using DataSharing.SendTask;
- using DataSharing.Share.Consts;
- using DataSharing.Share.Dtos;
- using DataSharing.Share.Dtos.HotlineWeb;
- using DataSharing.Share.Dtos.Province;
- using DataSharing.Share.Dtos.Province.Extend;
- using DataSharing.Share.Dtos.Province.HuiJu;
- using DataSharing.Share.Dtos.Province.XieTong.Knowledge;
- using DataSharing.Share.Dtos.Province.XieTong.Receive;
- using DataSharing.Share.Dtos.Province.XieTong.Send;
- using DataSharing.Share.Enums;
- using DataSharing.Validators.HuiJu;
- using DataSharing.Validators.XieTong;
- using DotNetCore.CAP;
- using Hotline.Share.Dtos.Knowledge;
- using Hotline.Share.Dtos.Order;
- using Hotline.Share.Dtos.TrCallCenter;
- using Hotline.Share.Enums.CallCenter;
- using Hotline.Share.Enums.FlowEngine;
- using Hotline.Share.Enums.Order;
- using MapsterMapper;
- using Microsoft.Extensions.Logging;
- using System.Text.Json;
- using XF.Domain.Cache;
- using XF.Domain.Dependency;
- using XF.Domain.Exceptions;
- using XF.Domain.Repository;
- namespace DataSharing.Province
- {
- /// <summary>
- /// 省推送数据
- /// </summary>
- public class ProvinceService : IProvinceService, IScopeDependency
- {
- #region 注入
- private readonly IMapper _mapper;
- private readonly ILogger<ProvinceService> _logger;
- private readonly IRepository<DsOrder> _dsOrderRepository;
- private readonly IRepository<DsOrderWorkFlow> _dataOrderWorkFlowRepository;
- private readonly IRepository<DsKnowledgeRawData> _knowledgeRawDataRepository;
- private readonly IChannelConfigurationManager _channelConfigurationManager;
- private readonly IRepository<DsSendCaseInfo> _sendCaseInfoRepository;
- private readonly ITypedCache<MissedCallModelDto> _missedCallModelCache;
- private readonly string MissedCallKey = "missedCallKey_";
- private readonly IRepository<DsOrderVisit> _dsOrderVisitRepository;
- private readonly IRepository<DsGetCaseBackApply> _getCaseBackApplyRepository;
- private readonly ICapPublisher _capPublisher;
- private readonly IRepository<DsTelCall> _dsTelCallRepository;
- private readonly ITypedCache<ConfigurationInformationDto> _configurationInformationCache;
- private readonly IRepository<DsOrderVisitSend> _dsOrderVisitSendRepository;
- private readonly ISharingConfigurationManager _sharingConfigurationManager;
- private readonly IInitPushDataService _initPushDataService;
- private readonly IRepository<DsGetCaseMaterialInfo> _getCaseMaterialInfoRepository;
- private readonly IRepository<DsSendTaskSubmitCaseInfo> _dsSendTaskSubmitCaseInfoRepository;
- /// <summary>
- ///
- /// </summary>
- /// <param name="mapper"></param>
- /// <param name="logger"></param>
- /// <param name="dsOrderRepository"></param>
- /// <param name="dataOrderWorkFlowRepository"></param>
- /// <param name="knowledgeRawDataRepository"></param>
- /// <param name="channelConfigurationManager"></param>
- /// <param name="sendCaseInfoRepository"></param>
- /// <param name="missedCallModelCache"></param>
- /// <param name="dsOrderVisitRepository"></param>
- /// <param name="getCaseBackApplyRepository"></param>
- /// <param name="capPublisher"></param>
- /// <param name="dsTelCallRepository"></param>
- /// <param name="configurationInformationCache"></param>
- /// <param name="dsOrderVisitSendRepository"></param>
- /// <param name="sharingConfigurationManager"></param>
- /// <param name="initPushDataService"></param>
- /// <param name="getCaseMaterialInfoRepository"></param>
- public ProvinceService(IMapper mapper,
- ILogger<ProvinceService> logger,
- IRepository<DsOrder> dsOrderRepository,
- IRepository<DsOrderWorkFlow> dataOrderWorkFlowRepository,
- IRepository<DsKnowledgeRawData> knowledgeRawDataRepository,
- IChannelConfigurationManager channelConfigurationManager,
- IRepository<DsSendCaseInfo> sendCaseInfoRepository,
- ITypedCache<MissedCallModelDto> missedCallModelCache,
- IRepository<DsOrderVisit> dsOrderVisitRepository,
- IRepository<DsGetCaseBackApply> getCaseBackApplyRepository,
- ICapPublisher capPublisher,
- IRepository<DsTelCall> dsTelCallRepository,
- ITypedCache<ConfigurationInformationDto> configurationInformationCache,
- IRepository<DsOrderVisitSend> dsOrderVisitSendRepository,
- ISharingConfigurationManager sharingConfigurationManager,
- IInitPushDataService initPushDataService,
- IRepository<DsGetCaseMaterialInfo> getCaseMaterialInfoRepository,
- IRepository<DsSendTaskSubmitCaseInfo> dsSendTaskSubmitCaseInfoRepository)
- {
- _mapper = mapper;
- _logger = logger;
- _dsOrderRepository = dsOrderRepository;
- _dataOrderWorkFlowRepository = dataOrderWorkFlowRepository;
- _knowledgeRawDataRepository = knowledgeRawDataRepository;
- _channelConfigurationManager = channelConfigurationManager;
- _sendCaseInfoRepository = sendCaseInfoRepository;
- _missedCallModelCache = missedCallModelCache;
- _dsOrderVisitRepository = dsOrderVisitRepository;
- _getCaseBackApplyRepository = getCaseBackApplyRepository;
- _capPublisher = capPublisher;
- _dsTelCallRepository = dsTelCallRepository;
- _configurationInformationCache = configurationInformationCache;
- _dsOrderVisitSendRepository = dsOrderVisitSendRepository;
- _sharingConfigurationManager = sharingConfigurationManager;
- _initPushDataService = initPushDataService;
- _getCaseMaterialInfoRepository = getCaseMaterialInfoRepository;
- _dsSendTaskSubmitCaseInfoRepository = dsSendTaskSubmitCaseInfoRepository;
- }
- #endregion
- #region 协同-第一批次---已处理
- /// <summary>
- /// 退回申请
- /// </summary>
- /// <param name="dtos"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task GetCaseBackApplyAsync(PublishOrderSendBackDto dtos, CancellationToken cancellationToken)
- {
- //验证数据
- foreach (var dto in dtos.SendDatas)
- {
- var validator = new GetCaseBackApplyValidator();
- var validResult = await validator.ValidateAsync(dto, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- }
- foreach (var dto in dtos.SendDatas)
- {
- if (string.IsNullOrEmpty(dto.Order.AreaCode) || dto.Order.Source == ESource.ProvinceStraight || dto.Order.AreaCode.Contains("519"))
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- //处理省上的退回申请
- if (dto.Order.Source == ESource.ProvinceStraight)
- {
- var data = _mapper.Map<GetCaseBackApplyInfo>(dto);
- data.CliengGuid = dto.SendBack.Id;
- var tempData = _mapper.Map<DsGetCaseBackApply>(data);
- tempData.OrderSendBackId = dto.SendBack.Id;
- var backId = await _getCaseBackApplyRepository.AddAsync(tempData, cancellationToken);
- if (!string.IsNullOrEmpty(backId))
- {
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<GetCaseBackApplyInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(data);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("GetCaseBackApply", "get_case_back_apply", data.CaseSerial,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.XieTong, generationTime: dto.Order.StartTime, cancellationToken: cancellationToken);
- //处理附件
- await FileDataAsync(dto.SendBack.FileJson, dto.Order.ProvinceNo, data.CliengGuid, EMaterialType.Process, dto.Order.AreaCode, cancellationToken: cancellationToken);
- }
- }
- }
- }
- /// <summary>
- /// 服务工单督办过程
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task SendSuperviseProcessInfoAsync(PublishSuperviseDto dto, CancellationToken cancellationToken)
- {
- if (string.IsNullOrEmpty(dto.Order.AreaCode) || dto.Order.Source == ESource.ProvinceStraight || dto.Order.AreaCode.Contains("519"))
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- var validator = new SendSuperviseProcessInfoValidator();
- var validResult = await validator.ValidateAsync(dto, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- var data = _mapper.Map<SendSuperviseProcessInfo>(dto);
- data.ReplyOpinion = "已签收";
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<SendSuperviseProcessInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(data);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("SendSuperviseProcessInfo", "send_supervise_process_info", dto.Order.ProvinceNo,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.XieTong,
- generationTime: dto.Order.StartTime, cancellationToken: cancellationToken);
- }
- /// <summary>
- /// 服务工单督办结果
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task SendSuperviseResultInfoAsync(PublishSuperviseDto dto, CancellationToken cancellationToken)
- {
- if (string.IsNullOrEmpty(dto.Order.AreaCode) || dto.Order.Source == ESource.ProvinceStraight || dto.Order.AreaCode.Contains("519"))
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- var validator = new SendSuperviseResultInfoValidator();
- var validResult = await validator.ValidateAsync(dto, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- var data = _mapper.Map<SendSuperviseResultInfo>(dto);
- data.CliengGuid = dto.Supervise.Id;
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<SendSuperviseResultInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(data);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("SendSuperviseResultInfo", "send_supervise_result_info", dto.Order.ProvinceNo,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.XieTong,
- generationTime: dto.Order.StartTime, cancellationToken: cancellationToken);
- //处理附件
- await FileDataAsync(dto.Supervise.FileJson, dto.Order.ProvinceNo, data.CliengGuid, EMaterialType.Supervise, dto.Order.AreaCode, cancellationToken);
- }
- /// <summary>
- /// 工单发起甄别
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task ScreenCaseInfoSendAsync(PublishScreenDto dto, CancellationToken cancellationToken)
- {
- if (string.IsNullOrEmpty(dto.Order.AreaCode) || dto.Order.Source == ESource.ProvinceStraight || dto.Order.AreaCode.Contains("519"))
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- var validator = new ScreenCaseInfoSendInfoValidator();
- var validResult = await validator.ValidateAsync(dto, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- var data = _mapper.Map<ScreenCaseInfoSendInfo>(dto);
- data.CliengGuid = dto.Screen.Id;
- data.ApplyType = dto.Screen.TypeDicName switch
- {
- "违反法律法规" => "10",
- "按正常流程处理" => "20",
- _ => "30",
- };
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<ScreenCaseInfoSendInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(data);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("ScreenCaseInfoSend", "screen_case_info_send", data.CaseSerial,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.XieTong,
- generationTime: dto.Order.StartTime, cancellationToken: cancellationToken);
- //处理附件
- await FileDataAsync(dto.Screen.FileJson, dto.Order.ProvinceNo, data.CliengGuid, EMaterialType.Process, dto.Order.AreaCode, cancellationToken: cancellationToken);
- }
- /// <summary>
- /// 服务工单申请延时
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task DelayCaseInfoSendAsync(PublishOrderDelayDto dto, CancellationToken cancellationToken)
- {
- if (string.IsNullOrEmpty(dto.Order.AreaCode) || dto.Order.Source == ESource.ProvinceStraight || dto.Order.AreaCode.Contains("519"))
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- var validator = new DelayCaseInfoSendInfoValidator();
- var validResult = await validator.ValidateAsync(dto, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- var data = _mapper.Map<DelayCaseInfoSendInfo>(dto);
- data.CliengGuid = dto.Id;
- data.ApplyType = "1";
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<DelayCaseInfoSendInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(data);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("DelayCaseInfoSend", "delay_case_info_send", data.CaseSerial,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.XieTong,
- generationTime: dto.Order.StartTime, cancellationToken: cancellationToken);
- //处理附件
- await FileDataAsync(dto.FileJson, data.CaseSerial, data.CliengGuid, EMaterialType.Process, data.AreaCode, cancellationToken);
- }
- #endregion
- #region 汇聚-第二批次
- /// <summary>
- /// 热线工单流程开启
- /// </summary>
- /// <param name="pushdto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task OrderFlowStartedAsync(PublishCallRecrodDto pushdto, CancellationToken cancellationToken)
- {
- if (string.IsNullOrEmpty(pushdto.Order.AreaCode) || pushdto.Order.AreaCode.Contains("519"))
- pushdto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- var dto = pushdto.Order;
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- //如果不是省上派下来的工单,需要汇聚到省上
- if (dto is not null && !dto.IsProvince)
- {
- var data = InitDataAsync(dto);
- var validator = new SubmitCaseInfoValidator();
- var validResult = await validator.ValidateAsync(data, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- #region 处理请求参数
- var request = new ProvinceListRequest<SubmitCaseInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(new List<SubmitCaseInfo>() { data });
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskSubmitCaseInfo(data.CaseSerial, jsonData, data, pushdto.Order.StartTime, cancellationToken);
- //处理附件
- await FileDataAsync(dto.FileJson, dto.ProvinceNo, data.CliengGuid, EMaterialType.Acceptance, data.AreaCode, cancellationToken);
- }
- //推送当前办理信息
- await SubmitCaseProcessFlowAsync(new OrderFlowDto { Order = pushdto.Order, WorkflowTrace = pushdto.WorkflowTrace, ExpiredTimeChanged = false }, true, cancellationToken);
- //再次推送通话记录
- if (pushdto.TrCallRecordDto is not null)
- {
- //如果推送工单的时候判断通话记录是否是未接,并且是否已经上传,如果没有咋补再次推送通话记录
- var tellCall = await _dsTelCallRepository.AnyAsync(p => p.CallId == pushdto.TrCallRecordDto.OtherAccept, cancellationToken);
- if (pushdto.TrCallRecordDto.OnState == EOnState.NoOn && !tellCall)
- return;
- var dataCall = _mapper.Map<SubmitCaseRecordInfo>(pushdto.TrCallRecordDto);
- dataCall.AreaCode = dto.AreaCode.Length > 6 ? dto.AreaCode.Substring(0, 6) : dto.AreaCode;
- dataCall.CaseSerial = dto.ProvinceNo;
- if (string.IsNullOrEmpty(dataCall.AccordUrl))
- dataCall.AccordUrl = "";
- //处理通话记录时间
- SetCallTime(dataCall);
- var validator = new SubmitCaseRecordInfoValidator();
- var validResult = await validator.ValidateAsync(dataCall, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- #region 处理请求参数
- var requestCall = new ProvinceListRequest<SubmitCaseRecordInfo>(configProvince.ClientId, configProvince.ClientSecret);
- requestCall.SetData(new List<SubmitCaseRecordInfo>() { dataCall });
- var jsonDataCall = requestCall.ToString();
- jsonDataCall = jsonDataCall.Replace("0001-01-01 00:00:00", "");
- //将待推送数据写入待推送表
- var taskId = await _initPushDataService.InitDsSendTaskSubmitCaseRecord(dataCall.CaseSerial, jsonDataCall, dataCall, pushdto.Order.StartTime, cancellationToken);
- //本地保存通话记录数据
- await InitTelCallData(pushdto.TrCallRecordDto, dto.ProvinceNo, taskId, cancellationToken);
- #endregion
- }
- }
- /// <summary>
- /// 热线工单期满时间变更--推送服务工单受理
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task HotlineOrderFlowRecalledAsync(OrderDto dto, CancellationToken cancellationToken)
- {
- if (string.IsNullOrEmpty(dto.AreaCode) || dto.AreaCode.Contains("519"))
- dto.AreaCode = _sharingConfigurationManager.GetCityCode();
- //如果不是省上派下来的工单,需要汇聚到省上
- if (!dto.IsProvince)
- {
- if (!await _dsSendTaskSubmitCaseInfoRepository.AnyAsync(p => p.ProvinceNo == dto.ProvinceNo && p.IsSuccess == ESendTaskState.PushSuccess, cancellationToken: cancellationToken))
- return;
- var data = InitDataAsync(dto);
- var validator = new SubmitCaseInfoValidator();
- var validResult = await validator.ValidateAsync(data, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceListRequest<SubmitCaseInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(new List<SubmitCaseInfo>() { data });
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskSubmitCaseInfo(data.CaseSerial, jsonData, data, dto.StartTime, cancellationToken);
- }
- }
- /// <summary>
- /// 热线工单办理---服务工单处理/服务工单交办处理过程
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task SubmitCaseProcessAsync(OrderFlowDto dto, CancellationToken cancellationToken)
- {
- if (string.IsNullOrEmpty(dto.Order.AreaCode) || dto.Order.AreaCode.Contains("519"))
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- if (string.IsNullOrEmpty(dto.WorkflowTrace.HandlerOrgAreaCode))
- {
- dto.WorkflowTrace.HandlerOrgAreaCode = dto.Order.AreaCode;
- if (dto.WorkflowTrace.HandlerOrgAreaCode.Length > 6)
- dto.WorkflowTrace.HandlerOrgAreaCode = dto.WorkflowTrace.HandlerOrgAreaCode.Substring(0, 6);
- }
- var ispush = await _dsSendTaskSubmitCaseInfoRepository.AnyAsync(p => p.ProvinceNo == dto.Order.ProvinceNo && p.IsSuccess == ESendTaskState.PushSuccess, cancellationToken: cancellationToken);
- await SubmitCaseProcessFlowAsync(dto, ispush, cancellationToken);
- //期满时间变更或者办理节点为话务部,重新推送数据
- if ((dto.ExpiredTimeChanged || dto.Order.ActualHandleStepName == "话务部") && !dto.Order.IsProvince)
- {
- if (!ispush) return;
- var submitCaseInfo = InitDataAsync(dto.Order);
- var validator = new SubmitCaseInfoValidator();
- var validResult = await validator.ValidateAsync(submitCaseInfo, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var requestSubmitCaseInfo = new ProvinceListRequest<SubmitCaseInfo>(configProvince.ClientId, configProvince.ClientSecret);
- requestSubmitCaseInfo.SetData(new List<SubmitCaseInfo>() { submitCaseInfo });
- var jsonDataSubmitCaseInfo = requestSubmitCaseInfo.ToString();
- var urlSubmitCaseInfo = configProvince.HuiJu + "submit_case_info";
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskSubmitCaseInfo(submitCaseInfo.CaseSerial, jsonDataSubmitCaseInfo, submitCaseInfo, dto.Order.StartTime, cancellationToken);
- //如果话务部派出去,再次上传附件
- if (dto.Order.ActualHandleStepName == "话务部")
- {
- //处理附件
- await FileDataAsync(dto.Order.FileJson, dto.Order.ProvinceNo, submitCaseInfo.CliengGuid, EMaterialType.Acceptance, submitCaseInfo.AreaCode, cancellationToken);
- }
- }
- }
- /// <summary>
- /// 服务工单回访评价/服务工单交办评价
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task SubmitVisitInfoDataAsync(PublishVisitDto dto, CancellationToken cancellationToken)
- {
- if (string.IsNullOrEmpty(dto.Order.AreaCode) || dto.Order.AreaCode.Contains("519"))
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- dto.AreaCode = dto.Order.AreaCode.Length > 6 ? dto.Order.AreaCode.Substring(0, 6) : dto.Order.AreaCode;
- //存在更新,不存在新增
- var visitData = await _dsOrderVisitSendRepository.GetAsync(p => p.OrderId == dto.Order.Id, cancellationToken);
- if (visitData != null)
- {
- visitData.VisitType = dto.VisitType.ToString();
- visitData.VisitName = dto.VisitName;
- visitData.VisitTime = dto.VisitTime;
- visitData.VisitRemark = dto.VisitRemark;
- visitData.SubjectResultSatifyCode = dto.SubjectResultSatifyCode;
- await _dsOrderVisitSendRepository.UpdateAsync(visitData, cancellationToken);
- }
- else
- {
- ///写入推送数据表,用于统计满意度
- visitData = new()
- {
- OrderId = dto.Order.Id,
- OrderNo = dto.No,
- ProvinceNo = dto.Order.ProvinceNo,
- VisitType = dto.VisitType.ToString(),
- VisitName = dto.VisitName,
- VisitTime = dto.VisitTime,
- VisitRemark = dto.VisitRemark,
- SubjectResultSatifyCode = dto.SubjectResultSatifyCode,
- IsProvince = dto.Order.IsProvince,
- Source = dto.Order.Source.ToString()
- };
- await _dsOrderVisitSendRepository.AddAsync(visitData, cancellationToken);
- }
- var visitType = dto.VisitType switch
- {
- EVisitType.ArtificialVisit => "DH",
- EVisitType.SmsVisit => "DX",
- EVisitType.WebVisit => "WZ",
- EVisitType.WeChatVisit => "WX",
- EVisitType.AppVisit => "AP",
- _ => "DH",
- };
- //将未接通未做评价的默认为满意
- switch (dto.SubjectResultSatifyCode)
- {
- case "5":
- case "4":
- case "2":
- break;
- case "-1":
- case "0":
- dto.SubjectResultSatifyCode = "4";
- break;
- case "6":
- case "7":
- dto.SubjectResultSatifyCode = "3";
- break;
- default:
- dto.SubjectResultSatifyCode = "3";
- break;
- }
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- //如果省上下来的工单走服务工单交办评价接口,不是省上派下来的工单,走服务工单评价接口
- if (dto.Order.IsProvince && dto.Order.Source == ESource.ProvinceStraight)
- {
- var data = _mapper.Map<GetVisitInfoReceiveInfo>(dto);
- data.VisitType = visitType;
- data.CliengGuid = Guid.NewGuid().ToString();
- var validator = new GetVisitInfoReceiveInfoValidator();
- var validResult = await validator.ValidateAsync(data, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- #region 处理请求参数
- var request = new ProvinceRequest<GetVisitInfoReceiveInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(data);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("GetVisitInfoReceive", "get_visit_info_receive", data.CaseSerial,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.XieTong,
- generationTime: dto.Order.StartTime, cancellationToken: cancellationToken);
- //处理附件
- await FileDataAsync(null, data.CaseSerial, data.CliengGuid, EMaterialType.Visit, data.AreaCode, cancellationToken);
- }
- else
- {
- if (!await _dsSendTaskSubmitCaseInfoRepository.AnyAsync(p => p.ProvinceNo == dto.Order.ProvinceNo && p.IsSuccess == ESendTaskState.PushSuccess, cancellationToken: cancellationToken))
- return;
- var data = _mapper.Map<SubmitVisitInfo>(dto);
- data.VisitType = visitType;
- data.CliengGuid = Guid.NewGuid().ToString();
- var validator = new SubmitVisitInfoValidator();
- var validResult = await validator.ValidateAsync(data, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- #region 处理请求参数
- var request = new ProvinceListRequest<SubmitVisitInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(new List<SubmitVisitInfo>() { data });
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("SubmitVisitInfo", "submit_visit_info", data.CaseSerial,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.HuiJu,
- generationTime: dto.Order.StartTime, cancellationToken: cancellationToken);
- //处理附件
- await FileDataAsync(null, data.CaseSerial, data.CliengGuid, EMaterialType.Visit, data.AreaCode, cancellationToken);
- }
- }
- /// <summary>
- /// 热线工单归档---服务工单结果/服务工单交办处理结果
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task OrderFiledAsync(OrderFlowDto dto, CancellationToken cancellationToken)
- {
- if (string.IsNullOrEmpty(dto.Order.AreaCode) || dto.Order.AreaCode.Contains("519"))
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- if (string.IsNullOrEmpty(dto.Order.ActualHandleOrgAreaCode))
- {
- dto.Order.ActualHandleOrgAreaCode = dto.Order.AreaCode;
- if (dto.Order.ActualHandleOrgAreaCode.Length > 6)
- dto.Order.ActualHandleOrgAreaCode = dto.Order.ActualHandleOrgAreaCode.Substring(0, 6);
- }
- //先看看需要处理工单数据不
- SubmitCaseInfo data = new();
- if (dto != null && dto.Order != null && !dto.Order.IsProvince)
- {
- data = InitDataAsync(dto.Order);
- var validator = new SubmitCaseInfoValidator();
- var validResult = await validator.ValidateAsync(data, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- }
- //推送办理记录
- dto.ExpiredTimeChanged = false;
- var ispush = await _dsSendTaskSubmitCaseInfoRepository.AnyAsync(p => p.ProvinceNo == dto.Order.ProvinceNo && p.IsSuccess == ESendTaskState.PushSuccess, cancellationToken: cancellationToken);
- //推送办理过程
- await SubmitCaseProcessFlowAsync(dto, ispush, cancellationToken);
- if (!ispush)
- return;
- //判断是否是热线中心
- if (!string.IsNullOrEmpty(dto.Order.ActualHandleOrgCode) && dto.Order.ActualHandleOrgCode == "001")
- dto.Order.ActualHandleOrgName = "热线中心";
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- //IsProvince 如果是false 则推送服务工单受理
- if (dto != null && dto.Order != null && !dto.Order.IsProvince)
- {
- #region 处理请求参数--推送工单数据
- var request = new ProvinceListRequest<SubmitCaseInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(new List<SubmitCaseInfo>() { data });
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskSubmitCaseInfo(data.CaseSerial, jsonData, data, dto.Order.StartTime, cancellationToken);
- //推送服务工单结果信息
- await SubmitCaseResultAsync(dto, cancellationToken);
- }
- //再次推送通话记录
- if (dto.TrCallRecordDto is not null)
- {
- //如果推送工单的时候判断通话记录是否是未接,并且是否已经上传,如果没有咋补再次推送通话记录
- var tellCall = await _dsTelCallRepository.AnyAsync(p => p.CallId == dto.TrCallRecordDto.OtherAccept, cancellationToken);
- if (dto.TrCallRecordDto.OnState == EOnState.NoOn && !tellCall)
- return;
- var dataCall = _mapper.Map<SubmitCaseRecordInfo>(dto.TrCallRecordDto);
- dataCall.AreaCode = dto.Order.AreaCode.Length > 6 ? dto.Order.AreaCode.Substring(0, 6) : dto.Order.AreaCode;
- dataCall.CaseSerial = dto.Order.ProvinceNo;
- if (string.IsNullOrEmpty(dataCall.AccordUrl))
- dataCall.AccordUrl = "";
- //处理通话记录时间
- SetCallTime(dataCall);
- var validator = new SubmitCaseRecordInfoValidator();
- var validResult = await validator.ValidateAsync(dataCall, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- #region 处理请求参数
- var requestCall = new ProvinceListRequest<SubmitCaseRecordInfo>(configProvince.ClientId, configProvince.ClientSecret);
- requestCall.SetData(new List<SubmitCaseRecordInfo>() { dataCall });
- var jsonDataCall = requestCall.ToString();
- jsonDataCall = jsonDataCall.Replace("0001-01-01 00:00:00", "");
- //将待推送数据写入待推送表
- var taskId = await _initPushDataService.InitDsSendTaskSubmitCaseRecord(dataCall.CaseSerial, jsonDataCall, dataCall, dto.Order.StartTime, cancellationToken);
- //本地保存通话记录数据
- await InitTelCallData(dto.TrCallRecordDto, dto.Order.ProvinceNo, taskId, cancellationToken);
- #endregion
- }
- }
- /// <summary>
- /// 挂电话推送----电话记录
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task SubmitCaseRecordAsync(PublishCallRecrodDto dto, CancellationToken cancellationToken)
- {
- //验证是否需要推送未接数据
- if (dto != null && dto.TrCallRecordDto != null && dto.TrCallRecordDto.OnState == EOnState.NoOn && dto.Order == null)
- {
- if (!await IsPublishMissedCall(dto.TrCallRecordDto, cancellationToken))
- return;
- }
- var data = _mapper.Map<SubmitCaseRecordInfo>(dto.TrCallRecordDto);
- if (dto.Order != null)
- {
- if (string.IsNullOrEmpty(dto.Order.AreaCode))
- data.AreaCode = _sharingConfigurationManager.GetCityCode();
- else
- data.AreaCode = dto.Order.AreaCode;
- if (!string.IsNullOrEmpty(dto.Order.ProvinceNo))
- data.CaseSerial = dto.Order.ProvinceNo;
- }
- else
- data.AreaCode = _sharingConfigurationManager.GetCityCode();
- if (data.AreaCode.Contains("519"))
- data.AreaCode = _sharingConfigurationManager.GetCityCode();
- if (data.AreaCode.Length > 6)
- data.AreaCode = data.AreaCode.Substring(0, 6);
- if (string.IsNullOrEmpty(data.CaseSerial))
- data.CaseSerial = "";
- if (string.IsNullOrEmpty(data.AccordUrl))
- data.AccordUrl = "";
- //处理通话记录时间
- SetCallTime(data);
- var validator = new SubmitCaseRecordInfoValidator();
- var validResult = await validator.ValidateAsync(data, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceListRequest<SubmitCaseRecordInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(new List<SubmitCaseRecordInfo>() { data });
- var jsonData = request.ToString();
- jsonData = jsonData.Replace("0001-01-01 00:00:00", "");
- #endregion
- var startTime = dto.Order == null ? dto.TrCallRecordDto.BeginIvrTime : dto.Order.StartTime;
- //将待推送数据写入待推送表
- var taskId = await _initPushDataService.InitDsSendTaskSubmitCaseRecord(data.CaseSerial, jsonData, data, startTime, cancellationToken);
- //本地保存通话记录数据
- await InitTelCallData(dto.TrCallRecordDto, data.CaseSerial, taskId, cancellationToken);
- }
- /// <summary>
- /// 关联工单了推送----电话记录
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task SubmitCaseRecordOrderAsync(PublishCallRecrodDto dto, CancellationToken cancellationToken)
- {
- //如果推送工单的时候判断通话记录是否是未接,并且是否已经上传,如果没有咋补再次推送通话记录
- var tellCall = await _dsTelCallRepository.AnyAsync(p => p.CallId == dto.TrCallRecordDto.OtherAccept, cancellationToken);
- if (dto.TrCallRecordDto.OnState == EOnState.NoOn && !tellCall)
- return;
- var data = _mapper.Map<SubmitCaseRecordInfo>(dto.TrCallRecordDto);
- if (dto.Order != null)
- {
- if (string.IsNullOrEmpty(dto.Order.AreaCode))
- data.AreaCode = _sharingConfigurationManager.GetCityCode();
- else
- data.AreaCode = dto.Order.AreaCode;
- if (!string.IsNullOrEmpty(dto.Order.ProvinceNo))
- data.CaseSerial = dto.Order.ProvinceNo;
- }
- else
- data.AreaCode = _sharingConfigurationManager.GetCityCode();
- if (data.AreaCode.Contains("519"))
- data.AreaCode = _sharingConfigurationManager.GetCityCode();
- if (data.AreaCode.Length > 6)
- data.AreaCode = data.AreaCode.Substring(0, 6);
- if (string.IsNullOrEmpty(data.CaseSerial))
- data.CaseSerial = "";
- if (string.IsNullOrEmpty(data.AccordUrl))
- data.AccordUrl = "";
- //处理通话记录时间
- SetCallTime(data);
- var validator = new SubmitCaseRecordInfoValidator();
- var validResult = await validator.ValidateAsync(data, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceListRequest<SubmitCaseRecordInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(new List<SubmitCaseRecordInfo>() { data });
- var jsonData = request.ToString();
- jsonData = jsonData.Replace("0001-01-01 00:00:00", "");
- #endregion
- var startTime = dto.Order == null ? dto.TrCallRecordDto.BeginIvrTime : dto.Order.StartTime;
- //将待推送数据写入待推送表
- var taskId = await _initPushDataService.InitDsSendTaskSubmitCaseRecord(data.CaseSerial, jsonData, data, startTime, cancellationToken);
- //本地保存通话记录数据
- await InitTelCallData(dto.TrCallRecordDto, data.CaseSerial, taskId, cancellationToken);
- }
- /// <summary>
- /// 统计数据
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task SubmitCaseTotalAsync(SubmitCaseTotalInfo dto, CancellationToken cancellationToken)
- {
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceListRequest<SubmitCaseTotalInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(new List<SubmitCaseTotalInfo>() { dto });
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("SubmitCaseTotal", "submit_case_total", "",
- jsonData, JsonSerializer.Serialize(dto, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.HuiJu,
- cancellationToken: cancellationToken);
- }
- #endregion
- #region 协同-第三批次
- /// <summary>
- /// 上报补充诉求
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- public async Task SupplyCaseInfoSendAsync(SupplyCaseInfoSendInfo dto, CancellationToken cancellationToken)
- {
- dto.AreaCode = _sharingConfigurationManager.GetCityCode();
- dto.CliengGuid = Guid.NewGuid().ToString();
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<SupplyCaseInfoSendInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(dto);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("SupplyCaseInfoSend", "supply_case_info_send", dto.CaseSerial, jsonData,
- JsonSerializer.Serialize(dto, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.XieTong, cancellationToken: cancellationToken);
- //处理附件
- await FileDataAsync(null, dto.CaseSerial, dto.CliengGuid, EMaterialType.Process, dto.AreaCode, cancellationToken);
- }
- /// <summary>
- /// 撤单
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task RevokeOrderAsync(PublishSpecialDto dto, CancellationToken cancellationToken)
- {
- if (string.IsNullOrEmpty(dto.Order.AreaCode) || dto.Order.AreaCode.Contains("519"))
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- var validator = new RevokeCaseInfoModelValidator();
- var validResult = await validator.ValidateAsync(dto, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- RevokeCaseInfoModel dsRevoke = new()
- {
- CaseSerial = dto.Order.ProvinceNo,
- AreaCode = dto.Order.AreaCode,
- RevokeTime = dto.Special.CreationTime.ToString("yyyy-MM-dd HH:mm:ss"),
- RevokeName = dto.Special.CreatorName,
- RevokeReasion = dto.Special.Reason,
- CliengGuid = dto.Special.Id
- };
- if (string.IsNullOrEmpty(dto.Special.Cause))
- dsRevoke.RevokeType = "other";
- else if (dto.Special.Cause.Contains("内容错误"))
- dsRevoke.RevokeType = "2";
- else if (dto.Special.Cause == "撤销工单")
- dsRevoke.RevokeType = "1";
- else
- dsRevoke.RevokeType = "other";
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<RevokeCaseInfoModel>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(dsRevoke);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("SendRevokeCaseInfo", "revoke_case_info", dsRevoke.CaseSerial,
- jsonData, JsonSerializer.Serialize(dsRevoke, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.XieTong,
- generationTime: dto.Order.StartTime, cancellationToken: cancellationToken);
- await FileDataAsync(dto.Special.FileJson, dto.Order.ProvinceNo, dsRevoke.CliengGuid, EMaterialType.Process, dto.Order.AreaCode, cancellationToken);
- }
- /// <summary>
- /// 服务工单催单
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task SendRemindCaseInfoAsync(PublishUrgeDto dto, CancellationToken cancellationToken)
- {
- if (string.IsNullOrEmpty(dto.Order.AreaCode) || dto.Order.AreaCode.Contains("519"))
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- var validator = new RemindCaseInfoValidator();
- var validResult = await validator.ValidateAsync(dto, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- var data = _mapper.Map<RemindCaseInfoModel>(dto);
- data.CliengGuid = dto.Urge.Id;
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<RemindCaseInfoModel>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(data);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("SendRemindCaseInfo", "remind_case_info", data.CaseSerial,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.XieTong,
- generationTime: dto.Order.StartTime, cancellationToken: cancellationToken);
- //处理附件
- await FileDataAsync(dto.Urge.FileJson, dto.Order.ProvinceNo, data.CliengGuid, EMaterialType.Process, dto.Order.AreaCode, cancellationToken);
- }
- /// <summary>
- /// 接收发布数据----推送服务工单交办结果
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task PublishOrderAsync(PublishPublishOrderDto dto, CancellationToken cancellationToken)
- {
- if (string.IsNullOrEmpty(dto.Order.AreaCode) || dto.Order.Source == ESource.ProvinceStraight || dto.Order.AreaCode.Contains("519"))
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- //推省上的交办结果
- if (dto.Order.IsProvince && dto.Order.Source == ESource.ProvinceStraight)
- {
- if (dto.Order.RealCommunicationMode == null)
- dto.Order.RealCommunicationMode = ERealCommunicationMode.Phone;
- var validator = new CaseResultReceiveValidator();
- var validResult = await validator.ValidateAsync(dto, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- #region 服务工单交办处理结果
- //判断是否是热线中心
- if (!string.IsNullOrEmpty(dto.Order.ActualHandleOrgCode) && dto.Order.ActualHandleOrgCode == "001")
- dto.Order.ActualHandleOrgName = "热线中心";
- ///如果是省上派下来的,直接将区域设置为系统市州
- if (dto.Order.Source == ESource.ProvinceStraight)
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- var data = _mapper.Map<GetCaseResultReceiveInfo>(dto.Order);
- data.ConcactType = "40";
- data.FinishType = "1";
- data.HandleTimeLong = (decimal)dto.Order.AllDuration;
- data.EndAreaName = string.IsNullOrEmpty(dto.Order.ActualHandleOrgAreaName) == false ? dto.Order.ActualHandleOrgAreaName : _sharingConfigurationManager.GetCityName();
- data.ConcactType = dto.Order.RealCommunicationMode switch
- {
- ERealCommunicationMode.Phone => "10",
- ERealCommunicationMode.Locale => "20",
- _ => "40",
- };
- data.CliengGuid = dto.Id;
- //中国政府网的数据处理
- if (dto.Order.ProvinceNo.Contains("ZGZFW"))
- {
- data.Notes = dto.Remark;
- data.MsgOpenByArea = dto.ProPublishState == true ? "1" : "0";
- data.AreaNotPublicReason = dto.NoPubReason;
- data.FeedBackAnswerContent = dto.ArrangeOpinion;
- data.FeedBackTel = dto.FeedBackPhone;
- data.EventType = "";
- data.Eventname = "";
- data.ContactFlag = dto.IsContact == true ? "1" : "0";
- data.AssessFlag = dto.IsVisited == true ? "1" : "0";
- data.AssessContent = dto.EvaluateContent;
- if (dto.NetizenEvaluate != null)
- {
- data.AssessOpinion = dto.NetizenEvaluate.Value;
- }
- }
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<GetCaseResultReceiveInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(data);
- var jsonData = request.ToString();
- #endregion
- await _initPushDataService.InitDsSendTaskProvinceOther("GetCaseResultReceive", "get_case_result_receive", data.CaseSerial,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.XieTong,
- generationTime: dto.Order.StartTime, cancellationToken: cancellationToken);
- //处理附件
- await FileDataAsync(dto.FileJsons, dto.Order.ProvinceNo, data.CliengGuid, EMaterialType.Result, dto.Order.AreaCode, cancellationToken);
- #endregion
- }
- }
- /// <summary>
- /// 政民互动公开
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task PublicOrderProvinceZmhd(PublicOrderProvinceZmhdDto dto, CancellationToken cancellationToken)
- {
- //政民互动提交公开数据验证
- var validator = new ZmhdCaseInfoPublicInfoValidator();
- var validResult = await validator.ValidateAsync(dto, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- //政民互动提交公开
- var data = _mapper.Map<ZmhdCaseInfoPublicInfo>(dto);
- data.AreaCode = _sharingConfigurationManager.GetCityCode();
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<ZmhdCaseInfoPublicInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(data);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("ZmhdCaseInfoPublic", "zmhd_case_info_public", data.CaseSerial,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.XieTong,
- generationTime: dto.PublishDate, cancellationToken: cancellationToken);
- }
- /// <summary>
- /// 接收发布的时候生成的待回访部门数据
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- public async Task PublishVisitAllAsync(PublishVisitAllDto dto, CancellationToken cancellationToken)
- {
- if (dto != null)
- {
- List<DsOrderVisit> orderVisits = new List<DsOrderVisit>();
- //1、待回访和已回访要将接收的数据写入库
- //2、其他状态的时候需要将工单的回访状态改成不能回访
- //处理待回访和已回访的数据
- if (dto.VisitState == EVisitState.WaitForVisit || dto.VisitState == EVisitState.Visited)
- {
- if (dto.OrderVisitDetails != null && dto.OrderVisitDetails.Count > 0)
- {
- //组装回访数据
- foreach (var item in dto.OrderVisitDetails)
- {
- DsOrderVisit dsOrderVisit = new()
- {
- OrderId = dto.Order.Id,
- VisitDetailId = item.Id,
- VisitId = item.VisitId,
- VoiceEvaluate = item.VoiceEvaluate.ToString(),
- SeatEvaluate = item.SeatEvaluate.ToString(),
- OrgProcessingResults = _mapper.Map<Kv>(item.OrgProcessingResults),
- OrgNoSatisfiedReason = _mapper.Map<List<Kv>>(item.OrgNoSatisfiedReason),
- OrgHandledAttitude = _mapper.Map<Kv>(item.OrgHandledAttitude),
- VisitContent = item.VisitContent,
- VisitOrgName = item.VisitOrgName,
- VisitOrgCode = item.VisitOrgCode,
- VisitTarget = item.VisitTarget.ToString(),
- VisitType = dto.VisitType.ToString(),
- VisitTime = dto.VisitTime,
- IsEffective = true
- };
- orderVisits.Add(dsOrderVisit);
- }
- //// 方式一: 保留数据
- //var tempList = await _dsOrderVisitRepository.Queryable().Where(p => p.OrderId == dto.Order.Id && p.IsEffective == true).ToListAsync();
- //foreach (var item in tempList)
- //{
- // item.IsEffective = false;
- // await _dsOrderVisitRepository.UpdateAsync(item, cancellationToken);
- //}
- //方式二:直接删除原始数据
- await _dsOrderVisitRepository.RemoveAsync(p => p.OrderId == dto.Order.Id);
- //写入新数据
- await _dsOrderVisitRepository.AddRangeAsync(orderVisits, cancellationToken);
- }
- }
- //处理是否可以评价,如果是
- var orderData = await _dsOrderRepository.GetAsync(p => p.OrderId == dto.Order.Id);
- if (orderData is not null)
- {
- var tempState = orderData.VisitTypeState;
- switch (dto.VisitState)
- {
- case EVisitState.WaitForVisit:
- orderData.VisitTypeState = DataSharing.Share.Enums.EVisitTypeState.Visit;
- break;
- case EVisitState.Visited:
- orderData.VisitTypeState = DataSharing.Share.Enums.EVisitTypeState.Reviewed;
- break;
- case EVisitState.Visiting:
- case EVisitState.NoSatisfiedWaitForVisit:
- case EVisitState.None:
- orderData.VisitTypeState = DataSharing.Share.Enums.EVisitTypeState.UnVisit;
- break;
- default:
- break;
- }
- if (tempState != orderData.VisitTypeState)
- await _dsOrderRepository.UpdateAsync(orderData, cancellationToken);
- }
- }
- }
- /// <summary>
- /// 往省上派单
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- public async Task SendCaseInfoDataAsync(OrderDto dto, CancellationToken cancellationToken)
- {
- //先上传拓展信息
- if (dto.OrderExtension != null)
- await SubmitCaseExtendsAsync(dto, cancellationToken);
- //在处理工单信息
- var sendCaseInfo = _mapper.Map<SendCaseInfo>(dto);
- if (dto.OrderExtension != null)
- sendCaseInfo.IsExtends = "1";
- else
- sendCaseInfo.IsExtends = "0";
- #region 处理数据
- //处理性别
- switch (dto.FromGender)
- {
- case EGender.Female:
- sendCaseInfo.AppLicantSex = "0";
- break;
- case EGender.Male:
- sendCaseInfo.AppLicantSex = "1";
- break;
- case EGender.Unknown:
- sendCaseInfo.AppLicantSex = "2";
- break;
- default:
- sendCaseInfo.AppLicantSex = "2";
- break;
- }
- //处理证件类型
- sendCaseInfo.CertifiCateType = dto.LicenceTypeCode switch
- {
- "10" => "10",
- "40" => "20",
- "55" => "30",
- "57" => "40",
- _ => "50",
- };
- //处理紧急程度
- sendCaseInfo.CaseIsUrgent = dto.EmergencyLevel switch
- {
- EEmergencyLevel.QuiteEmergency => "10",
- EEmergencyLevel.Emergency => "20",
- _ => "30",
- };
- //处理诉求类型
- switch (sendCaseInfo.CaseType)
- {
- case "10":
- case "15":
- case "20":
- case "25":
- case "30":
- case "35":
- break;
- default:
- sendCaseInfo.CaseType = "40";
- break;
- }
- #endregion
- switch (dto.SourceChannelCode.ToUpper())
- {
- case "RGDH":
- case "WX":
- case "WB":
- case "AP":
- case "WZ":
- case "YJ":
- case "SCZWFWW":
- case "XCX":
- break;
- default:
- sendCaseInfo.CaseSource = "QT";
- break;
- }
- sendCaseInfo.CaseSource = sendCaseInfo.CaseSource;
- var sendCaseInfoData = _mapper.Map<DsSendCaseInfo>(sendCaseInfo);
- sendCaseInfoData.OrderID = dto.Id;
- sendCaseInfoData.No = dto.No;
- sendCaseInfoData.State = "0";
- await _sendCaseInfoRepository.AddAsync(sendCaseInfoData, cancellationToken);
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<SendCaseInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(sendCaseInfo);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("SendCaseInfo", "send_case_info", sendCaseInfo.CaseSerial,
- jsonData, JsonSerializer.Serialize(sendCaseInfo, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.XieTong,
- generationTime: dto.StartTime, cancellationToken: cancellationToken);
- //处理附件
- await FileDataAsync(dto.FileJson, dto.ProvinceNo, sendCaseInfoData.CliengGuid, EMaterialType.Acceptance, sendCaseInfoData.AreaCode, cancellationToken);
- }
- #endregion
- #region 汇聚-第四批次--已处理
- #region 知识库
- /// <summary>
- /// 知识库上报
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task GetKnowledgeInfoSendAsync(KnowledgeSendDto dto, CancellationToken cancellationToken)
- {
- var validator = new KnowledgeInfoValidator();
- var validResult = await validator.ValidateAsync(dto, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- var data = _mapper.Map<KnowledgeInfoSendInfo>(dto);
- data.AreaCode = _sharingConfigurationManager.GetCityCode();
- data.CliengGuid = Guid.NewGuid().ToString();
- if (data.DisableDate == null)//如果没得有失效时间,默认在生效日期上面加10年
- data.DisableDate = data.BeginDate.Value.AddYears(10);
- data.CategoryCode = "01";
- data.CategoryName = "公共服务";
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<KnowledgeInfoSendInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(data);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("GetKnowledgeInfoSend", "get_knowledge_info_send", data.UID,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.HuiJu,
- generationTime: dto.CreatDate, cancellationToken: cancellationToken);
- #region 处理知识库原始数据
- //查询原有数据,如果有修改原始数据,没有直接新增
- var dataRaw = await _knowledgeRawDataRepository.GetAsync(p => p.UID == data.UID);
- var raw = _mapper.Map<DsKnowledgeRawData>(data);
- if (dataRaw != null)
- {
- raw.Id = dataRaw.Id;
- await _knowledgeRawDataRepository.UpdateAsync(raw, cancellationToken: cancellationToken);
- }
- else
- await _knowledgeRawDataRepository.AddAsync(raw, cancellationToken: cancellationToken);
- #endregion
- //知识附件处理
- await FileDataAsync(dto.FileJson, dto.UID, data.CliengGuid, EMaterialType.Knowledge, data.AreaCode, cancellationToken);
- }
- /// <summary>
- /// 知识库变更
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task GetKnowledgeInfoUpdateAsync(KnowledgeSendDto dto, CancellationToken cancellationToken)
- {
- var validator = new KnowledgeInfoValidator();
- var validResult = await validator.ValidateAsync(dto, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- var data = _mapper.Map<GetKnowledgeInfoUpdateInfo>(dto);
- data.AreaCode = _sharingConfigurationManager.GetCityCode();
- data.CliengGuid = Guid.NewGuid().ToString();
- if (data.DisableDate == null)//如果没得有失效时间,默认在生效日期上面加10年
- data.DisableDate = data.BeginDate.Value.AddYears(10);
- data.CategoryCode = "01";
- data.CategoryName = "公共服务";
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<GetKnowledgeInfoUpdateInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(data);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("GetKnowledgeInfoUpdate", "get_knowledge_info_update", data.UID,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.HuiJu,
- generationTime: dto.CreatDate, cancellationToken: cancellationToken);
- #region 处理知识库原始数据
- //查询原有数据,如果有修改原始数据,没有直接新增
- var dataRaw = await _knowledgeRawDataRepository.GetAsync(p => p.UID == data.UID);
- var raw = _mapper.Map<DsKnowledgeRawData>(data);
- if (dataRaw != null)
- {
- raw.Id = dataRaw.Id;
- await _knowledgeRawDataRepository.UpdateAsync(raw, cancellationToken: cancellationToken);
- }
- else
- await _knowledgeRawDataRepository.AddAsync(raw, cancellationToken: cancellationToken);
- #endregion
- //知识附件处理
- await FileDataAsync(dto.FileJson, dto.UID, data.CliengGuid, EMaterialType.Knowledge, data.AreaCode, cancellationToken);
- }
- /// <summary>
- /// 知识库下架
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- public async Task GetKnowledgeInfoAbandonAsync(KnowledgeSendDto dto, CancellationToken cancellationToken)
- {
- var validator = new KnowledgeInfoAbandonValidator();
- var validResult = await validator.ValidateAsync(dto, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- var data = _mapper.Map<GetKnowledgeInfoAbandonInfo>(dto);
- data.AreaCode = _sharingConfigurationManager.GetCityCode();
- data.CategoryCode = "01";
- data.CategoryName = "公共服务";
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<GetKnowledgeInfoAbandonInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(data);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("GetKnowledgeInfoAbandon", "get_knowledge_info_abandon", data.UID,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.HuiJu,
- generationTime: dto.CreatDate, cancellationToken: cancellationToken);
- //知识下架删除原有原始数据
- await _knowledgeRawDataRepository.RemoveAsync(p => p.UID == data.UID, cancellationToken: cancellationToken);
- }
- #endregion
- /// <summary>
- /// 实时服务上报
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- public async Task SendRealTimeStatusAsync(SendRealTimeStatusInfo dto, CancellationToken cancellationToken)
- {
- dto.AreaCode = _sharingConfigurationManager.GetCityCode();
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<SendRealTimeStatusInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(dto);
- var jsonData = request.ToString();
- #endregion
- await _initPushDataService.InitDsSendTaskProvinceOther("SendRealTimeStatus", "sendrealtimestatus", "",
- jsonData, JsonSerializer.Serialize(dto, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.HuiJu,
- cancellationToken: cancellationToken);
- }
- #endregion
- #region 私有方法
- #region 省数据处理
- /// <summary>
- /// 热线工单办理---服务工单处理/服务工单交办处理过程
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- /// <exception cref="UserFriendlyException"></exception>
- private async Task SubmitCaseProcessFlowAsync(OrderFlowDto dto, bool ispush, CancellationToken cancellationToken)
- {
- //判断是否是热线中心
- if (!string.IsNullOrEmpty(dto.Order.ActualHandleOrgCode) && dto.Order.ActualHandleOrgCode == "001")
- dto.Order.ActualHandleOrgName = "热线中心";
- #region 写本地办理数据-用于查询办理流程
- //写本地办理数据-用于查询办理流程
- var orderWorkFlow = _mapper.Map<DsOrderWorkFlow>(dto.WorkflowTrace);
- orderWorkFlow.OrderId = dto.Order.Id;
- await _dataOrderWorkFlowRepository.AddAsync(orderWorkFlow, cancellationToken);
- #endregion
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- ///如果是省上派下来的,直接将区域设置为系统市州
- if (dto.Order.Source == ESource.ProvinceStraight)
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- //省上下来的工单走协同的接口
- if (dto.Order.Source == ESource.ProvinceStraight && dto.Order.IsProvince)
- {
- var data = _mapper.Map<GetCaseProcessReceiveInfo>(dto);
- data.TacheName = "70:" + data.DeptName;
- data.EndAreaName = string.IsNullOrEmpty(dto.WorkflowTrace.HandlerOrgAreaName) == false ? dto.WorkflowTrace.HandlerOrgAreaName : _sharingConfigurationManager.GetCityName();
- var validator = new GetCaseProcessReceiveInfoValidator();
- var validResult = await validator.ValidateAsync(data, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- #region 处理请求参数
- var request = new ProvinceRequest<GetCaseProcessReceiveInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(data);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("GetCaseProcessReceive", "get_case_process_receive", data.CaseSerial,
- jsonData, JsonSerializer.Serialize(data, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.XieTong,
- generationTime: dto.Order.StartTime, cancellationToken: cancellationToken);
- //处理附件
- await FileDataAsync(dto.WorkflowTrace.FileJson, dto.Order.ProvinceNo, data.CliengGuid, EMaterialType.Process, dto.Order.AreaCode, cancellationToken);
- }
- else //如果不是省上派下来的工单
- {
- if (!ispush)
- return;
- //本地工单走市州接口
- var data = _mapper.Map<SubmitCaseProcessInfo>(dto);
- data.TacheName = "70:" + data.DeptName;
- data.EndAreaName = string.IsNullOrEmpty(dto.WorkflowTrace.HandlerOrgAreaName) == false ? dto.WorkflowTrace.HandlerOrgAreaName : _sharingConfigurationManager.GetCityName();
- var validator = new SubmitCaseProcessInfoValidator();
- var validResult = await validator.ValidateAsync(data, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- #region 处理请求参数
- var requestSubmitCaseProcessInfo = new ProvinceListRequest<SubmitCaseProcessInfo>(configProvince.ClientId, configProvince.ClientSecret);
- requestSubmitCaseProcessInfo.SetData(new List<SubmitCaseProcessInfo>() { data });
- var jsonDataSubmitCaseProcessInfo = requestSubmitCaseProcessInfo.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskSubmitCaseProcess(data.CaseSerial, jsonDataSubmitCaseProcessInfo, data, dto.Order.StartTime, cancellationToken);
- //处理附件
- await FileDataAsync(dto.WorkflowTrace.FileJson, dto.Order.ProvinceNo, data.CliengGuid, EMaterialType.Process, dto.Order.AreaCode, cancellationToken);
- }
- ////这里判断是否需要往其他平台推送数据
- //await OrderDispatchAsync(dto, cancellationToken);
- }
- /// <summary>
- /// 服务工单结果
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- private async Task SubmitCaseResultAsync(OrderFlowDto dto, CancellationToken cancellationToken)
- {
- ///如果是省上派下来的,直接将区域设置为系统市州
- if (dto.Order.Source == ESource.ProvinceStraight)
- dto.Order.AreaCode = _sharingConfigurationManager.GetCityCode();
- var data = _mapper.Map<SubmitCaseResultInfo>(dto);
- data.ConcactType = "40";
- data.FinishType = "1";
- data.HandleTimeLong = (int)dto.Order.AllDuration;
- data.CliengGuid = dto.WorkflowTrace.Id;
- data.EndAreaName = string.IsNullOrEmpty(dto.Order.ActualHandleOrgAreaName) == false ? dto.Order.ActualHandleOrgAreaName : _sharingConfigurationManager.GetCityName();
- //宜宾工单不超期,如果在推送省上数据时,实际办理时间大于过期时间,则将办理时间改成过期时间减2个小时
- if (_sharingConfigurationManager.IsCity(ConfigurationConsts.YiBin))
- {
- if (dto.Order.ExpiredTime < dto.Order.ActualHandleTime)
- {
- var finishTime = dto.Order.ExpiredTime.Value.AddHours(-2);
- data.FinishTime = finishTime;
- data.FdBackTime = finishTime;
- }
- }
- var validator = new SubmitCaseResultInfoValidator();
- var validResult = await validator.ValidateAsync(data, cancellationToken);
- if (!validResult.IsValid)
- throw new UserFriendlyException(string.Join(',', validResult.Errors.Select(d => d.ErrorMessage)));
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceListRequest<SubmitCaseResultInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(new List<SubmitCaseResultInfo>() { data });
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskSubmitCaseResult(data.CaseSerial, jsonData, data, dto.Order.StartTime, cancellationToken);
- //处理附件
- if (dto.WorkflowTrace != null && dto.WorkflowTrace.FileJson != null && dto.WorkflowTrace.FileJson.Count > 0)
- await FileDataAsync(dto.WorkflowTrace.FileJson, data.CaseSerial, data.CliengGuid, EMaterialType.Result, dto.Order.AreaCode, cancellationToken);
- }
- /// <summary>
- /// 工单创建数据处理
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- private SubmitCaseInfo InitDataAsync(OrderDto dto)
- {
- var submitCaseInfo = _mapper.Map<SubmitCaseInfo>(dto);
- //处理性别
- submitCaseInfo.AppLicantSex = dto.FromGender switch
- {
- EGender.Female => "0",
- EGender.Male => "1",
- EGender.Unknown => "2",
- _ => "2",
- };
- //处理证件类型
- submitCaseInfo.CertifiCateType = dto.LicenceTypeCode switch
- {
- "10" => "10",
- "40" => "20",
- "55" => "30",
- "57" => "40",
- _ => "50",
- };
- //处理紧急程度
- submitCaseInfo.CaseIsUrgent = dto.EmergencyLevel switch
- {
- EEmergencyLevel.QuiteEmergency => "10",
- EEmergencyLevel.Emergency => "20",
- _ => "30",
- };
- //处理诉求类型
- switch (submitCaseInfo.CaseType)
- {
- case "10":
- case "15":
- case "20":
- case "25":
- case "30":
- case "35":
- break;
- default:
- submitCaseInfo.CaseType = "40";
- break;
- }
- submitCaseInfo.CaseValid = "1";
- submitCaseInfo.CaseIsPublic = string.IsNullOrEmpty(submitCaseInfo.CaseIsPublic) == true ? "0" : submitCaseInfo.CaseIsPublic;
- submitCaseInfo.ThemeSerial = "20";
- if (dto.SourceChannelCode == "SZMHD" && dto.IsProvince == false && dto.Source == ESource.ProvinceStraight)
- submitCaseInfo.TrowGuid = "【政民互动直派】";
- switch (dto.SourceChannelCode.ToUpper())
- {
- case "RGDH":
- case "WX":
- case "WB":
- case "AP":
- case "WZ":
- case "YJ":
- case "SCZWFWW":
- case "XCX":
- break;
- default:
- submitCaseInfo.CaseSource = "QT";
- break;
- }
- return submitCaseInfo;
- }
- /// <summary>
- /// 服务工单拓展信息
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- private async Task SubmitCaseExtendsAsync(OrderDto dto, CancellationToken cancellationToken)
- {
- var orderExtension = dto.OrderExtension;
- if (orderExtension is null)
- return;
- //工单类型
- string formType = orderExtension.OrderTypeCode;
- //处理为统一的市场监管表单
- if (formType == "scjgjts" || formType == "scjgjjb")
- formType = "scjgj";
- DataSharing.Share.Dtos.Province.HuiJu.SubmitCaseExtendsInfo submitCaseExtendsInfo = new()
- {
- CaseSerial = dto.ProvinceNo,
- FormType = formType
- };
- //处理扩展信息
- switch (formType.ToLower())
- {
- case "yl"://医疗表单
- //转换数据
- submitCaseExtendsInfo.FormMedical = _mapper.Map<FormMedicalInfo>(orderExtension);
- break;
- case "zwfw"://四川政务服务网技术工单
- submitCaseExtendsInfo.FormNetWorktec = _mapper.Map<FormNetWorktecInfo>(orderExtension);
- break;
- case "th"://电视购物及商铺购买退换货工单
- submitCaseExtendsInfo.FormReturnexChange = _mapper.Map<FormReturnexChangeInfo>(orderExtension);
- break;
- case "gsgl"://高速公路工单
- submitCaseExtendsInfo.FormExpressWay = _mapper.Map<FormExpressWayInfo>(orderExtension);
- break;
- case "xjgg"://电视台虚假广告工单
- submitCaseExtendsInfo.FormShamPub = _mapper.Map<FormShamPubInfo>(orderExtension);
- break;
- case "swfwsq"://12366热线诉求交办
- submitCaseExtendsInfo.FormTaxationComplaint = _mapper.Map<FormTaxationComplaintInfo>(orderExtension);
- break;
- case "swfwzx"://12366热线咨询交办
- submitCaseExtendsInfo.FormTaxationConsulting = _mapper.Map<FormTaxationConsultingInfo>(orderExtension);
- break;
- case "jtfwjd"://12328服务监督
- submitCaseExtendsInfo.FormTraffic = _mapper.Map<FormTrafficInfo>(orderExtension);
- break;
- case "yzxf"://邮政业消费者申诉
- submitCaseExtendsInfo.FormPost = _mapper.Map<FormPostInfo>(orderExtension);
- break;
- case "hbjb"://环保举报业务
- submitCaseExtendsInfo.FormEnvironMent = _mapper.Map<FormEnvironMentInfo>(orderExtension);
- break;
- case "scjgj"://12315个性化表单
- var formMarket = _mapper.Map<FormMarketInfo>(orderExtension);
- //转换数据
- switch (orderExtension.OrderTypeCode)
- {
- case "scjgjjb":
- formMarket.Rqsttypy = "25";
- break;
- case "scjgjts":
- formMarket.Rqsttypy = "20";
- foreach (var item in orderExtension.ComplainTypes)
- formMarket.AppealContent += item.Value + ",";
- formMarket.AppealContent = formMarket.AppealContent.TrimEnd(',');
- break;
- default:
- break;
- }
- formMarket.HandDepCode = dto.AcceptorOrgCode;
- formMarket.HandDep = dto.AcceptorOrgName;
- formMarket.Zxgh = dto.AcceptorStaffNo;
- formMarket.AccregperId = dto.AcceptorId;
- formMarket.AccregperName = dto.AcceptorName;
- formMarket.RegTime = Convert.ToDateTime(dto.CreationTime);
- formMarket.CmTime = dto.StartTime;
- submitCaseExtendsInfo.FormMarket = formMarket;
- break;
- default:
- break;
- }
- #region 处理请求参数
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<DataSharing.Share.Dtos.Province.HuiJu.SubmitCaseExtendsInfo>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(submitCaseExtendsInfo);
- var jsonData = request.ToString();
- #endregion
- //将待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("SubmitCaseExtends", "submit_case_extends", submitCaseExtendsInfo.CaseSerial,
- jsonData, JsonSerializer.Serialize(submitCaseExtendsInfo, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.HuiJu, generationTime: dto.StartTime, cancellationToken: cancellationToken);
- }
- /// <summary>
- /// 附件处理
- /// </summary>
- /// <param name="fileJson">附件</param>
- /// <param name="caseSerial">工单编号</param>
- /// <param name="cliengGuid">附件ID</param>
- /// <param name="materialType">附件类型 10:受理材料,20:环节材料,30:结果材料,40:回访评价材料,50:督办材料,60:知识库材料</param>
- /// <param name="areaCode">区域ID</param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- private async Task FileDataAsync(List<Hotline.Share.Dtos.File.FileJson> fileJson, string caseSerial, string cliengGuid, EMaterialType materialType, string areaCode, CancellationToken cancellationToken)
- {
- if (fileJson != null && fileJson.Count > 0)
- {
- //将受到的数据写入本地数据库
- GetCaseMaterialInfoModel materialInfo = new()
- {
- CaseSerial = caseSerial,
- CliengGuid = cliengGuid,
- AreaCode = areaCode.Length > 6 ? areaCode.Substring(0, 6) : areaCode,
- MaterialType = materialType switch
- {
- EMaterialType.Acceptance => "10",
- EMaterialType.Process => "20",
- EMaterialType.Result => "30",
- EMaterialType.Visit => "40",
- EMaterialType.Supervise => "50",
- EMaterialType.Knowledge => "60",
- _ => "20",
- }
- };
- var configProvince = _channelConfigurationManager.GetConfigurationProvince();
- var request = new ProvinceRequest<GetCaseMaterialInfoModel>(configProvince.ClientId, configProvince.ClientSecret);
- request.SetData(materialInfo);
- var jsonData = request.ToString();
- foreach (var item in fileJson)
- {
- // 新增文件到列表
- var fileData = new DsGetCaseMaterialInfo()
- {
- CaseSerial = caseSerial,
- MaterialType = materialInfo.MaterialType,
- CliengGuid = materialInfo.CliengGuid,
- AreaCode = materialInfo.AreaCode,
- FileName = item.FileName,
- Type = item.FileType,
- Additions = item.Id,
- Path = item.Path,
- Direction = "1",
- SyncState = "1"
- };
- await _getCaseMaterialInfoRepository.AddAsync(fileData, cancellationToken);
- List<FileJson> fileJsons = new() { _mapper.Map<FileJson>(item) };
- //待推送数据写入待推送表
- await _initPushDataService.InitDsSendTaskProvinceOther("GetCaseMaterialInfo", "get_case_material_info", materialInfo.CaseSerial,
- jsonData, JsonSerializer.Serialize(materialInfo, ProvinceJsonSerializerOptions.UnStandardDatetimeJsonOptions), pathType: EPathType.File,
- fileJson: fileJsons, cancellationToken: cancellationToken);
- }
- }
- }
- /// <summary>
- /// 处理通话记录队列时间
- /// </summary>
- /// <param name="recordInfo"></param>
- /// <returns></returns>
- private void SetCallTime(SubmitCaseRecordInfo recordInfo)
- {
- // 电话进入顺序 进IVR时间→进队列时间→振铃时间→开始时间→结束时间
- //进入IVR时间为空
- if (recordInfo.InIvr == DateTime.MinValue)
- {
- if (recordInfo.InQueue == DateTime.MinValue)
- {
- if (recordInfo.CallStart == DateTime.MinValue)
- {
- recordInfo.CallStart = recordInfo.CallEnd.AddSeconds(-2);
- }
- recordInfo.InQueue = recordInfo.CallStart.AddSeconds(-2);
- }
- recordInfo.InIvr = recordInfo.InQueue.AddSeconds(-2);
- }
- //进入队列时间为空
- if (recordInfo.InQueue == DateTime.MinValue)
- {
- if (recordInfo.InIvr == DateTime.MinValue)
- {
- if (recordInfo.CallStart == DateTime.MinValue)
- {
- recordInfo.CallStart = recordInfo.CallEnd.AddSeconds(-2);
- }
- recordInfo.InQueue = recordInfo.CallStart.AddSeconds(-2);
- recordInfo.InIvr = recordInfo.InQueue.AddSeconds(-2);
- }
- else
- recordInfo.InQueue = recordInfo.InIvr.AddSeconds(2);
- }
- //振铃时间为空
- if (recordInfo.CallTime == DateTime.MinValue && recordInfo.CallStart != DateTime.MinValue)
- recordInfo.CallTime = recordInfo.CallStart.AddSeconds(-2);
- }
- /// <summary>
- /// 检查是否需要推送未接通话记录
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- private async Task<bool> IsPublishMissedCall(TrCallDto dto, CancellationToken cancellationToken)
- {
- var key = MissedCallKey + DateTime.Now.ToString("yyyyMMdd");
- int missedCallCount;
- //获取系统配置
- var configurationInformation = await _configurationInformationCache.GetAsync(ConstantSettings.ConfigurationInformationCacheKey, cancellationToken);
- if (configurationInformation == null)
- {
- //获取配置信息
- var provinceConfiguration = _channelConfigurationManager.GetConfigurationProvince();
- missedCallCount = provinceConfiguration.MissedCallCount;
- }
- else
- missedCallCount = configurationInformation.MissedCallCount;
- _logger.LogWarning("获取到的不上传的值:------------------------" + missedCallCount);
- var dataCache = await _missedCallModelCache.GetAsync(key, cancellationToken);
- _logger.LogWarning("获取到缓存的值:------------------------" + JsonSerializer.Serialize(dataCache));
- if (dataCache != null)
- {
- //如果存在值,检查是否已经达到推送最大值
- if (!dataCache.IsMax && dataCache.DateTimeList.Count > 0)
- {
- //没有达到最大值
- //检查第一条数据是否匹配当前推送时间
- var list = dataCache.DateTimeList;
- if (list[0] < dto.OverTime)
- {
- _logger.LogWarning("匹配到需要上传的,原始数据:------------------------" + JsonSerializer.Serialize(list));
- //处理数据
- list.RemoveAt(0);
- dataCache.DateTimeList = list;
- //是否推送完成
- if (list == null || list.Count == 0)
- dataCache.IsMax = true;
- _logger.LogWarning("处理后数据:------------------------" + JsonSerializer.Serialize(list));
- //从新写入数据
- await _missedCallModelCache.SetAsync(key, dataCache, TimeSpan.FromDays(1), cancellationToken);
- return true;
- }
- }
- }
- else
- {
- #region 生成时间
- //生成时间
- List<DateTime> timeLists = new();
- Random random = new((int)(DateTime.Now.Ticks));
- for (int i = 0; i < missedCallCount; i++)
- {
- int hour = random.Next(2, 23);
- int minute = random.Next(0, 60);
- int second = random.Next(0, 60);
- string tempStr = string.Format("{0} {1}:{2}:{3}", DateTime.Now.ToString("yyyy-MM-dd"), hour, minute, second);
- DateTime rTime = Convert.ToDateTime(tempStr);
- timeLists.Add(rTime);
- }
- timeLists.Sort();
- #endregion
- if (timeLists[0] < dto.OverTime)
- //处理数据
- timeLists.RemoveAt(0);
- MissedCallModelDto missedCall = new()
- {
- DateTimeList = timeLists
- };
- if (timeLists == null || timeLists.Count == 0)
- missedCall.IsMax = true;
- await _missedCallModelCache.SetAsync(key, missedCall, TimeSpan.FromDays(1), cancellationToken);
- return true;
- }
- return false;
- }
- /// <summary>
- /// 初始化上传通话记录
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="ProvinceNo"></param>
- /// <param name="cancellationToken"></param>
- /// <returns></returns>
- private async Task InitTelCallData(TrCallDto dto, string ProvinceNo, string taskId, CancellationToken cancellationToken)
- {
- var tellCall = await _dsTelCallRepository.GetAsync(p => p.CallId == dto.OtherAccept, cancellationToken);
- if (tellCall != null)
- {
- //修改
- _mapper.Map(dto, tellCall);
- tellCall.ProvinceNo = ProvinceNo;
- tellCall.CallId = dto.OtherAccept;
- tellCall.TaskId = taskId;
- await _dsTelCallRepository.UpdateAsync(tellCall, cancellationToken);
- }
- else
- {
- //新增
- tellCall = new DsTelCall();
- tellCall = _mapper.Map<DsTelCall>(dto);
- tellCall.ProvinceNo = ProvinceNo;
- tellCall.CallId = dto.OtherAccept;
- tellCall.TaskId = taskId;
- tellCall.Id = dto.OtherAccept;
- try
- {
- await _dsTelCallRepository.AddAsync(tellCall, cancellationToken);
- }
- catch (Exception ex)
- {
- var tellCallNew = await _dsTelCallRepository.GetAsync(p => p.CallId == dto.OtherAccept, cancellationToken);
- if (tellCallNew != null)
- {
- //修改
- _mapper.Map(dto, tellCallNew);
- tellCallNew.ProvinceNo = ProvinceNo;
- tellCallNew.CallId = dto.OtherAccept;
- tellCallNew.TaskId = taskId;
- await _dsTelCallRepository.UpdateAsync(tellCallNew, cancellationToken);
- }
- }
- }
- }
- #endregion
- #endregion
- }
- }
|