From 5c4f90cad0e828faacbbf3528bc0929db34be383 Mon Sep 17 00:00:00 2001 From: 彭锟 <pengkun@prec-tech.com> Date: 星期五, 25 三月 2022 18:07:50 +0800 Subject: [PATCH] NFM624325修改 --- force-app/main/default/classes/NFM624Rest.cls | 148 +++++++++++++++++++------------------------------ 1 files changed, 58 insertions(+), 90 deletions(-) diff --git a/force-app/main/default/classes/NFM624Rest.cls b/force-app/main/default/classes/NFM624Rest.cls index 8b9b01b..84f63b1 100644 --- a/force-app/main/default/classes/NFM624Rest.cls +++ b/force-app/main/default/classes/NFM624Rest.cls @@ -7,7 +7,7 @@ } *************************************************************************/ - + @RestResource(urlMapping = '/NFM624/*') global with sharing class NFM624Rest { //add to AWS 鍥炲 start sushanhu 20220225 @@ -18,12 +18,12 @@ // global class GeDatasRest { // public GeDatas GeDatas; // } - + global class GeDatas { public NFMUtil.Monitoring Monitoring; public GeData[] GeData; } - + global class GeData { public String ContactId; //缁熶竴骞冲彴ID//Update to aws 瀛樺偍鐨凙WSContactId 20220225 SUSHANHU public String ServiceUserId; //鏈嶅姟骞冲彴鐢ㄦ埛ID @@ -51,31 +51,31 @@ public String ApproverID; //瀹℃牳浜哄憳鍛樺伐缂栫爜 public String DataId;//aws瀛樺偍鍑嵁 } - + @HttpPost global static void execute() { - + // 鍙栧緱鎺ュ彛浼犺緭鍐呭 String strData = RestContext.request.requestBody.toString(); GeDatas ges = (GeDatas) JSON.deserializeStrict(strData, GeDatas.class); system.debug('ges---'+ges); - + if (ges == null) { return; } - + NFMUtil.Monitoring Monitoring = ges.Monitoring; if (Monitoring == null) { return; } - + BatchIF_Log__c rowData = NFMUtil.saveRowData(Monitoring, LOG_TYPE, ges.GeData); system.debug('String.isBlank(rowData.Log__c) == false?'); if (String.isBlank(rowData.Log__c) == false) { System.debug('杩涘叆if鏂规硶锛屾垚鍔熻皟鐢╡xecutefuture'); executefuture(rowData.Id); } - + // JSON銈掓埢銇� RestResponse res = RestContext.response; res.addHeader('Content-Type', 'application/json'); @@ -92,16 +92,16 @@ //updata response toAWS 20220225 sushanhu end return; } - - + + @future global static void executefuture(String rowData_Id) { system.debug('杩涘叆executefuture鏂规硶' + rowData_Id); main(rowData_Id); } - + global static void main(String rowData_Id) { - + // Map<String,String> RecordTypeMap = new Map<String,String>(); // RecordTypeMap.put('','') Map < string, string > RecordTypeMap = new Map < string, string > (); //瀛樻斁璁板綍绫诲瀷Id @@ -122,7 +122,7 @@ iflog.Log__c = logstr; iflog.ErrorLog__c = ''; insert iflog; - + String rowDataStr = NFMUtil.getRowDataStr(rowData); List < GeData > GeDataList = (List < GeData > ) JSON.deserialize(rowDataStr, List < GeData > .class); if (GeDataList == null || GeDataList.size() == 0) { @@ -136,7 +136,7 @@ // continue; // } // } - + Savepoint sp = Database.setSavepoint(); List<string> ApproverIDList = new List <string>();// List < string > PersonManagementCodeList = new List < String > (); //浜哄憳绠$悊缂栫爜List @@ -161,8 +161,12 @@ StateList.add(gedata.State); CityList.add(gedata.City); ApproverIDList.add(gedata.ApproverID); - ManagementList.add(gedata.HospitalManagementCode2); - ManagementList.add(gedata.DepartmentManagementCode2); + if(string.isnotblank(gedata.HospitalManagementCode2)){ + ManagementList.add(gedata.HospitalManagementCode2); + } + if(string.isnotblank(gedata.DepartmentManagementCode2)){ + ManagementList.add(gedata.DepartmentManagementCode2); + } //system.debug('AccountCodeList'+AccountCodeList); if (string.isnotblank(gedata.RelatedHospital)) { SFDCCodeList.add(gedata.RelatedHospital); @@ -192,21 +196,21 @@ for (Address_Level2__c temp: citytempList) { CityMap.put(temp.Name, temp.Id); } - + //鏌ヨ鍖婚櫌鎵�鏈変汉 Map<string,String> ownerMap = new Map<string,String>(); List<User> ownerList = [select Id,Employee_No__c from User where Employee_No__c IN:ApproverIDList]; for(User temp : ownerList){ ownerMap.put(temp.Employee_No__c,temp.Id); } - + //鏌ヨOCSM钀ヤ笟绐楀彛 Map<string,Id> OCSMMap = new Map<string,Id>(); List<OCM_Management_Province__c> OCSMList = [select Id,Name,Window1__c from OCM_Management_Province__c]; for(OCM_Management_Province__c ocsm : OCSMList){ OCSMMap.put(ocsm.name,ocsm.Window1__c); } - + //鏌ヨ鑱旂郴浜� Map < String, Map < String, Contact >> nameMap = new Map < String, Map < String, Contact >> (); //澶栧眰鎴樼暐绉戝锛屽唴灞傜瀹ゅ悕+鑱旂郴浜哄悕 List < Contact > peopleList = [select Id, @@ -216,7 +220,7 @@ Account.PlatformCode__c, Account.Management_Code__c, Account.parent.Department_Class_Label__c, - Name, + Name,LastName_Encrypted__c, Account.Parent_Management_Code__c, Account.Parent_PlatformCode__c, CManageCode__c, @@ -230,15 +234,15 @@ for (Contact ct: peopleList) { if (string.isnotblank(ct.Account.parent.Name)) { Map < String, Contact > snameMap = new Map < String, Contact > (); - string Name = ct.Name.replaceAll(' ',''); - string namekey = ct.Account.Name + ' ' + Name; + string namekey = ct.Account.Name + ' ' + ct.LastName_Encrypted__c; // snameMap.put(namekey,ct); if (nameMap.containsKey(ct.Account.parent.Name)) { snameMap = nameMap.get(ct.Account.parent.Name); } snameMap.put(namekey, ct); - snameMap.put(ct.Name, ct); + snameMap.put(ct.LastName_Encrypted__c, ct); nameMap.put(ct.Account.parent.Name, snameMap); + system.debug('snameMap'+snameMap); } peopleMap.put(ct.CManageCode__c, ct); System.debug('peopleMap'+peopleMap); @@ -246,7 +250,7 @@ //string temp = ct.Name + ct.Account.parent.Department_Class_Label__c; // peopleMap.put(temp, ct); } - + //鏌ヨ鍖婚櫌绉戝 //List<Account> AccountList = [select Id,PlatformCode__c,PlatformCode__c,Department_Class_Label__c,Name,Management_Code__c,Is_Active__c,AgentCode_Ext__c,ParentId,Parent.ParentId from Account where PlatformCode__c IN :HpCodeList OR parent.PlatformCode__c IN :HpCodeList OR PlatformCode__c IN :HpCodeList OR Management_Code__c IN :RelatedHospitalList OR Parent_Management_Code__c IN :RelatedHospitalList]; //List < Account > AccountList = [select Id, PlatformCode__c, Department_Class_Label__c, Name, Management_Code__c, Is_Active__c, AgentCode_Ext__c, ParentId, Parent.ParentId from Account where Management_Code__c IN :AccountCodeList OR Parent_Management_Code__c IN :AccountCodeList OR PlatformCode__c IN :AccountCodeList OR Parent.Parent.PlatformCode__c IN :AccountCodeList]; @@ -276,25 +280,25 @@ } system.debug('AccountMap '+AccountMap); System.debug('DepartmentClassMap '+DepartmentClassMap); - - + + //瀹㈡埛List锛堟洿鏂扮敤锛� List < Account > upsertAccountList = new List < Account > (); //鑱旂郴浜篖ist锛堟洿鏂扮敤锛� List < Contact > upsertContactList = new List < Contact > (); - + for (Gedata gedata: newGeDataList) { logstr += gedata.Name; logstr += gedata.AccountName; logstr += gedata.DepartmentClass; logstr += gedata.DepartmentName; - - + + string comefrom = gedata.RegSource == '1' ? '鏅烘収鍖荤枟' : '鏈嶅姟瀹㈡埛绔�'; //骞冲彴鏉ユ簮 - + //鏂板缓鍖婚櫌 Account hp = new Account(); - + //鏂板缓鑱旂郴浜� Contact ct = new Contact(); ct.LastName = gedata.Name; @@ -316,9 +320,9 @@ ct.AWS_Data_Id__c =gedata.DataId;//add 20220215 aws瀛樺偍鍑瘉 ct.MobilePhone_Encrypted__c =gedata.MobileEncrypted;//add 20220215 鎵嬫満瀵嗘枃 ct.LastName_Encrypted__c =gedata.NameEncrypted;//add 20220215 濮撳悕瀵嗘枃 - + String personCode = gedata.PersonManagementCode; - + Map < String, Contact > contactMap = new Map < String, Contact > ();//鐢ㄤ簬鏆傚瓨鏇存柊鑱旂郴浜� //1缁忛攢鍟唗rue if (gedata.AgentFlag == true) { @@ -365,11 +369,13 @@ } else { //浜哄憳绠$悊缂栫爜涓嶅瓨鍦� //鎼滅储浜哄悕/涓斿湪褰撳墠鎴樼暐绉戝绉戝涓� System.debug('浜哄憳绠$悊缂栫爜涓嶅瓨鍦�'); - string namekey = gedata.Name; + string namekey = gedata.NameEncrypted; system.debug('DepartmentClasskey = '+DepartmentClasskey); system.debug('nameMap22222222 '+nameMap); if (nameMap.containskey(DepartmentClasskey)) { // 6 瀹屾垚 鏇存柊鎿嶄綔 Map < String, Contact > sMap = nameMap.get(DepartmentClasskey); + System.debug('sMap'+sMap); + System.debug('sMap.containsKey(namekey)'+sMap.containsKey(namekey)); if (sMap.containsKey(namekey)) { system.debug('Id璧嬪��'+sMap); ct.id = sMap.get(namekey).id; @@ -404,7 +410,7 @@ } } else { //浜哄憳绠$悊缂栫爜涓嶅瓨鍦� system.debug('浜哄憳绠$悊缂栫爜涓嶅瓨鍦�'); - string namekey = gedata.DepartmentName+ ' ' + gedata.Name; + string namekey = gedata.DepartmentName+ ' ' + gedata.NameEncrypted; //string namekey = gedata.AccountName + ' ' + gedata.DepartmentName + ' ' + gedata.DepartmentClass + ' ' + gedata.Name; system.debug('DepartmentClasskey'+DepartmentClasskey); system.debug('351nameMap '+nameMap); @@ -412,6 +418,8 @@ System.debug('浜哄憳绠$悊缂栫爜涓嶅瓨鍦ㄧ殑鎯呭喌涓嬫垬鐣ョ瀹ゅ瓨鍦�'); system.debug('鎴樼暐绉戝瀛樺湪' + nameMap.get(DepartmentClasskey)); Map < String, Contact > sMap = nameMap.get(DepartmentClasskey); + system.debug('namekey'+namekey); + system.debug('sMap.containsKey(namekey)'+sMap.containsKey(namekey)); if (sMap.containsKey(namekey)) { //鏌ユ壘瀛樺湪 8 瀹屾垚 system.debug('8閫昏緫'); system.debug('璇ヨ仈绯讳汉瀛樺湪'); @@ -421,14 +429,16 @@ // if(sMap.containsKey(gedata.Name)){ // ct.Id = sMap.get(gedata.Name).Id; // } - }else if(sMap.containsKey(gedata.Name)){ + }else if(sMap.containsKey(gedata.NameEncrypted)){ system.debug('1234567890'); - ct.Id = sMap.get(gedata.Name).Id; + ct.Id = sMap.get(gedata.NameEncrypted).Id; //upsertAccountList.add(dpt); } system.debug('contactMap ' + contactMap); System.debug('9閫昏緫'); contactMap.put(Gedata.DepartmentManagementCode2, ct); + system.debug('contactMap ' + contactMap); + //upsertContactList.add(ct); } system.debug('鍒涘缓鑱旂郴浜哄拰绉戝'); dpt.Department_Name__c = gedata.DepartmentName; @@ -468,10 +478,16 @@ StaticParameter.EscapeNFM001AgencyContractTrigger2 = true; system.debug('upsertAccountList ' + upsertAccountList); upsert upsertAccountList; + system.debug('SFDCCodeList'+SFDCCodeList); + system.debug('SFDCCodeList'+ManagementList); List < Account > List1 = [select Id,RecordTypeId,Is_Active__c,PlatformCode__c,OCM_man_province_HP__c,OwnerId from Account where PlatformCode__c In: SFDCCodeList OR PlatformCode__c IN: ManagementList];//瀹㈡埛鎵�鏈変汉淇敼11.18 11.35 鏈畬鎴� + system.debug('List1'+List1); List<Account> updateHPList = new List<Account>(); for (Account ac: List1) { Contact c = new contact(); + system.debug('ac.PlatformCode__c'+ac.PlatformCode__c); + system.debug('ContactMap'+ContactMap); + system.debug('ContactMap.containsKey(ac.PlatformCode__c)'+ContactMap.containsKey(ac.PlatformCode__c)); if(ContactMap.containsKey(ac.PlatformCode__c)){ c = contactMap.get(ac.PlatformCode__c); if(string.isblank(c.Id)|| c.AccountId != ac.Id){ @@ -482,7 +498,7 @@ system.debug('OwnerId'+ac.OwnerId); system.debug('upsertContactList'+upsertContactList); } - + if(ac.RecordTypeId == '01210000000QemGAAS' && ac.Is_Active__c == '鑽夋涓�' && string.isNotBlank( OCSMMap.get(ac.OCM_man_province_HP__c))){ ac.OwnerId = OCSMMap.get(ac.OCM_man_province_HP__c); updateHPList.add(ac); @@ -534,7 +550,7 @@ } update iflog; } - + private static String verify(GeData gda) { String result = ''; if (string.isblank(gda.ContactId)) { @@ -595,55 +611,7 @@ } return result; } - // global static String contactAllName(String contactName){ - // // 涓浗 澶嶅澶у叏 - // String CompoundSurname = '婵槼銆佸叕鍐躲�佸お鍙斻�佺敵灞犮�佸叕瀛欍�佹厱瀹广�佷徊瀛欍�侀挓绂汇�侀暱瀛欍�佸畤鏂囥�佸徃寰掋�侀矞浜庛�佸徃绌恒�侀椌涓樸�佸瓙杞︺�佷簱瀹樸�佸徃瀵囥�佸帆椹�佸叕瑗裤�侀瀛欍�佸¥椹枫�佸叕鑹�佹紗闆曘�佷箰姝c�佸鐖躲�佽胺姊併�佹嫇璺嬨�佸す璋枫�佽僵杈曘�佷护鐙愩�佹骞层�佺櫨閲屻�佸懠寤躲�佷笢閮�佸崡闂ㄣ�佺緤鑸屻�佸井鐢熴�佸叕鎴枫�佸叕鐜夈�佸叕浠�佹涓樸�佸叕浠层�佸叕涓娿�佸叕闂ㄣ�佸叕灞便�佸叕鍧氥�佸乏涓樸�佸叕浼�佽タ闂ㄣ�佸叕绁栥�佺浜斻�佸叕涔樸�佽疮涓樸�佸叕鐨欍�佸崡鑽c�佷笢閲屻�佷笢瀹�佷徊闀裤�佸瓙涔︺�佸瓙妗戙�佸嵆澧ㄣ�佽揪濂氥�佽甯堛�佸惔閾�'; - // // string allname = '鏈卞惎璐�'; - // // contactName = '绗簲鎯嗘��'; - // String lastName = ''; - // String firstName = ''; - // String result = ''; - // if (contactName.contains('路')) { - // lastName = contactName.split('路')[0]; - // firstName = contactName.split('路')[1]; - // } else { - // if (contactName.length() > 2) { - - // system.debug('CompoundSurname--->01' + contactName.subString(0, 2)); - // if (CompoundSurname.contains(contactName.subString(0, 2))) { - // lastName = contactName.substring(0,2); - // firstName = contactName.substring(2,contactName.length()); - // system.debug('lastName--->'+lastName); - // system.debug('firstName--->'+firstName); - // } else { - // lastName = contactName.substring(0,1); - // firstName = contactName.substring(1,contactName.length()); - // system.debug('lastName--->'+lastName); - // system.debug('firstName--->'+firstName); - // } - // } else { - // if (contactName.length() == 2) { - // lastName = contactName.substring(0,1); - // firstName = contactName.substring(1,contactName.length()); - // system.debug('lastName--->'+lastName); - // system.debug('firstName--->'+firstName); - // } else { - // lastName = contactName; - // firstName = contactName; - // system.debug('lastName--->'+lastName); - // system.debug('firstName--->'+firstName); - // } - // } - // } - // if (!contactName.equals(lastName+firstName)) { - // lastName = contactName; - // firstName = contactName; - // } - // result = lastName + '_' + firstName; - // //system.debug('CompoundSurname--->02' + CompoundSurname); - // return result; - // } - + private static void supplement (String ContactId){ //鎶�620Batch 鍜� 623Batch 鎼繃鏉� //琛ュ厖璇㈤棶鍗曢儴鍒� start @@ -656,7 +624,7 @@ //鏍规嵁缁熶竴鐢ㄦ埛Id鏌ヨ鑱旂郴浜� List<Contact> contactList = [select Id,Name,UnifiedI_Contact_ID__c,Account.Id,Strategic_dept_Class__c,AccountId,Account.Name,Strategic_dept_Class__r.OwnerId from Contact where UnifiedI_Contact_ID__c = :ContactId]; system.debug('contactList' + contactList); - + if(InquiryList.size()>0){ //缁熶竴鐢ㄦ埛ID瀛樺叆List銆佽闂崟ID瀛楳ap Map<String, String> inquiryMap = new Map<String, String>(); -- Gitblit v1.9.1