buli
2023-07-13 c51e03fbf2f6633d8e88aeec9dcb8df13524df8f
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) {