高章伟
2023-03-03 d8dc84a3d56df839895f1c417a4d9cbee763d262
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
global without sharing class CampaignMemberUploadFileController {
    public String staticResource {get; set;}
    public static String sobjectTypeValue = 'CampaignMember';
    public static Map<String, Schema.SObjectType> schemaMap = Schema.getGlobalDescribe();
    public CampaignMemberUploadFileController(ApexPages.StandardController controller) {
        staticResource = JSON.serialize(PIHelper.getPIIntegrationInfo('Document'));
    }
    global class Response{
        public String message{set;get;}
        public String status{set;get;}
    }
    @RemoteAction
    global static Response saveFile(String CampaignMemberDatas,String transId){
        Response res = new Response();
        Savepoint sp = Database.setSavepoint();
        try{
            System.debug('CampaignMemberDatas:' + JSON.serialize(CampaignMemberDatas));
            Schema.SObjectType CampaignMemberSchema = schemaMap.get(sobjectTypeValue);
            Map<String, Schema.SObjectField> fieldAPIToTypeMap = CampaignMemberSchema.getDescribe().fields.getMap();
            Map<String,Object> fieldValueMap = (Map<String,Object>)JSON.deserializeUntyped(CampaignMemberDatas);
            List<Map<String,Object>> datas = (List<Map<String,Object>>)fieldValueMap.get('idList');
            List<CampaignMember> CMList = new List<CampaignMember>();
            List<String> awsIdList = new List<String>();
            List<String> sfIdList = new List<String>();
            List<String> contentList = new List<String>();
            for (Integer i = 0; i < datas.size(); i++) {
                CampaignMember cm = new CampaignMember();
                for(String fieldAPI : datas[i].keySet()){ 
                    if(!fieldAPIToTypeMap.containskey(fieldAPI)){
                        continue;
                    }
                    Schema.DisplayType fielddataType = fieldAPIToTypeMap.get(fieldAPI).getDescribe().getType();  
                    String fieldValue = String.valueOf(datas[i].get(fieldAPI)); 
                    if(fieldAPI == 'AWS_Data_Id__c'){
                        awsIdList.add(fieldValue);
                    }
                    if(String.valueOf(fielddataType)=='DATE'){
                        cm.put(fieldAPI,(String.isBlank(fieldValue)||String.isEmpty(fieldValue))? null:Date.valueOf(fieldValue.replace('/', '-')));              
                    }else if(String.valueOf(fielddataType)=='DATETIME'){
                        if(String.isNotBlank(fieldValue)&&fieldValue.contains('T')){
                            fieldValue = fieldValue.replace('T',' ');
                            cm.put(fieldAPI, Datetime.valueOfGmt(fieldValue));
                        }else if(String.isNotBlank(fieldValue))  {
                            fieldValue = fieldValue.replace('/', '-') + ':00';
                            cm.put(fieldAPI, Datetime.valueOf(fieldValue));
                        }else{
                            cm.put(fieldAPI, null);
                        }                    
                    }else if(String.valueof(fielddataType)=='CURRENCY'|| String.valueof(fielddataType)=='PERCENT'||String.valueOf(fielddataType)=='Number'||String.valueOf(fielddataType)=='DOUBLE' ){
                        cm.put(fieldAPI, (String.isBlank(fieldValue)||String.isEmpty(fieldValue))?null:Decimal.valueOf(fieldValue.replace(',', ''))); 
                    } else if(String.valueof(fielddataType)=='BOOLEAN'){
                        cm.put(fieldAPI, datas[i].get(fieldAPI));
                    }else {
                        cm.put(fieldAPI,fieldValue);
                    }  
                }
                CMList.add(cm);
            }
            insert CMList;
            for(CampaignMember cm : CMList){
                contentList.add(cm+'');
                sfIdList.add(cm.id);
            }
            //记录日志
            res.message = 'success';
            res.status = 'success';
            PIHelper.saveTransLogBatch(sobjectTypeValue,awsIdList,sfIdList,transId, contentList ,res.status,'');
            return res;
        }catch(DmlException e){
            Integer index = 0;
            System.debug('into catch'+e.getMessage());
            Database.rollback(sp);
            res.message = '保存失败,原因:'+ e.getDmlMessage(index);
            res.status = 'Exception';
            PIHelper.saveTransLog(sobjectTypeValue,'','',transId, '' ,res.status,e.getMessage()+e.getStackTraceString());
            return res;
        }catch(Exception e) {
            System.debug('into catch'+e.getMessage());
            Database.rollback(sp);     
            res.message = e.getMessage()+e.getStackTraceString();  
            res.status = 'Exception';
            PIHelper.saveTransLog(sobjectTypeValue,'','',transId, '' ,res.status,res.message);
            return res;
        }
    }
}