From c51e03fbf2f6633d8e88aeec9dcb8df13524df8f Mon Sep 17 00:00:00 2001
From: buli <137736985@qq.com>
Date: 星期四, 13 七月 2023 12:00:06 +0800
Subject: [PATCH] backup0713

---
 force-app/main/default/classes/Batch_FixAttachmentToFiles.cls |   52 ++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 46 insertions(+), 6 deletions(-)

diff --git a/force-app/main/default/classes/Batch_FixAttachmentToFiles.cls b/force-app/main/default/classes/Batch_FixAttachmentToFiles.cls
index e7b7f7a..9c83139 100644
--- a/force-app/main/default/classes/Batch_FixAttachmentToFiles.cls
+++ b/force-app/main/default/classes/Batch_FixAttachmentToFiles.cls
@@ -29,11 +29,13 @@
   global void execute(Database.BatchableContext BC, List<Attachment> scope) {
     List<ContentVersion> insertContents = new List<ContentVersion>();
     Map<string, id> nameParentMaps = new Map<string, id>();
+    Set<String> attachmentIds = new Set<String>();
     for (Attachment att : scope) {
-      nameParentMaps.put(att.Name, att.ParentId);
+      nameParentMaps.put(att.Id, att.ParentId);
+      attachmentIds.add(att.Id);
       ContentVersion cVersion = new ContentVersion();
       cVersion.ContentLocation = 'S'; //S-Document is in Salesforce. E-Document is outside of Salesforce. L-Document is on a Social Netork.
-      cVersion.PathOnClient = att.Name; //File name with extention
+      cVersion.PathOnClient = att.Id; //File name with extention
       cVersion.Origin = 'C'; //C-Content Origin. H-Chatter Origin.
       cVersion.Title = att.Name; //Name of the file
       cVersion.VersionData = att.Body; //File content
@@ -42,13 +44,18 @@
     if (insertContents.isEmpty()) {
       return;
     }
-    insert insertContents;
+    //Insert insertContents;
+    List<Database.SaveResult> saveResultsContents = Database.insert(
+      insertContents,
+      false
+    );
+    insertLog(saveResultsContents, attachmentIds);
     set<Id> contentIds = new Set<Id>();
     for (ContentVersion cv : insertContents) {
       contentIds.add(cv.id);
     }
     List<ContentVersion> conDocuments = [
-      SELECT ContentDocumentId, Title
+      SELECT ContentDocumentId, Title, PathOnClient
       FROM ContentVersion
       WHERE Id IN :contentIds
     ];
@@ -56,12 +63,45 @@
     for (ContentVersion cv : conDocuments) {
       ContentDocumentLink cDocLink = new ContentDocumentLink();
       cDocLink.ContentDocumentId = cv.ContentDocumentId; //Add ContentDocumentId
-      cDocLink.LinkedEntityId = nameParentMaps.get(cv.Title); //Add attachment parentId
+      cDocLink.LinkedEntityId = nameParentMaps.get(cv.PathOnClient); //Add attachment parentId
       cDocLink.ShareType = 'V'; //V - Viewer permission. C - Collaborator permission. I - Inferred permission.
       cDocLink.Visibility = 'AllUsers';
       insertDocLinks.add(cDocLink);
     }
-    insert insertDocLinks;
+    //Insert insertDocLinks;
+    List<Database.SaveResult> saveResultsLinks = Database.insert(
+      insertDocLinks,
+      false
+    );
+    insertLog(saveResultsLinks, attachmentIds);
+  }
+
+  global void insertLog(
+    List<Database.SaveResult> saveResults,
+    Set<String> attachmentIds
+  ) {
+    Transaction_Log__c traLog = new Transaction_Log__c();
+    List<Map<String, String>> logMapList = new List<Map<String, String>>();
+    for (Database.SaveResult result : saveResults) {
+      String recordId = result.getId();
+      if (!result.isSuccess()) {
+        for (Database.Error error : result.getErrors()) {
+          Map<String, String> logMap = new Map<String, String>();
+          String errorMsg = error.getMessage();
+          logMap.put('recordId', recordId);
+          logMap.put('errorMsg', errorMsg);
+          logMapList.add(logMap);
+        }
+      }
+    }
+    if (logMapList.size() > 0) {
+      Map<String, String> attachmentIdMap = new Map<String, String>();
+      attachmentIdMap.put('attachmentIds', JSON.serialize(attachmentIds));
+      logMapList.add(attachmentIdMap);
+      traLog.Response__c = JSON.serialize(logMapList);
+      traLog.Module__c = 'Attachment COnvert Transaction ';
+      insert traLog;
+    }
   }
 
   global void finish(Database.BatchableContext BC) {

--
Gitblit v1.9.1