Search and Replace Text - Salesforce
PDF Search and Replace Text sample in Salesforce demonstrating ‘Search and Replace Text’
SearchAndReplaceTextPdf.cls
public class SearchAndReplaceTextPdf {
String API_KEY = '*************************';
string DestinationFile = 'resultReplaceText';
string endPointUrl = 'https://api.pdf.co/v1/pdf/edit/replace-text';
public void searchAndReplaceText()
{
// You can also upload your own file into PDF.co and use it as url. Check "Upload File" samples for code snippets: https://github.com/bytescout/pdf-co-api-samples/tree/master/File%20Upload/
String jsonBody = '{ "url": "https://bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-to-text/sample.pdf", "searchString": "Your Company Name", "replaceString": "XYZ LLC", "caseSensitive": true, "replacementLimit": 1, "pages": "", "password":"", "name": "finalFile", "async": false }';
Http http = new Http();
HttpRequest request = new HttpRequest();
request.setHeader('x-api-key', API_KEY);
request.setEndpoint(endPointUrl);
request.setHeader('Content-Type', 'application/json');
request.setMethod('POST');
request.setBody(jsonBody);
HttpResponse response = http.send(request);
Map<String, Object> json = (Map<String, Object>)JSON.deserializeUntyped(response.getBody());
try
{
if(response.getStatusCode() == 200)
{
if ((Boolean)json.get('error') == false)
{
System.debug('response.getBody() :: '+response.getBody());
// Get URL of generated PDF file
String resultFileUrl =(String)json.get('url');
// Download generated PDF file
downloadFile(resultFileUrl, DestinationFile);
System.debug('Generated PDF file saved as \'{0}\' file.'+ DestinationFile);
}
}
else
{
System.debug('Error Response ' + response.getBody());
System.Debug(' Status ' + response.getStatus());
System.Debug(' Status Code' + response.getStatusCode());
System.Debug(' Response String' + response.toString());
}
}
catch (Exception ex)
{
String errorBody = 'Message: ' + ex.getMessage() + ' -- Cause: ' + ex.getCause() + ' -- Stacktrace: ' + ex.getStackTraceString();
System.Debug(errorBody);
}
}
@TestVisible
private static void downloadFile(String extFileUrl, String DestinationFile)
{
Http h = new Http();
HttpRequest req = new HttpRequest();
extFileUrl = extFileUrl.replace(' ', '%20');
req.setEndpoint(extFileUrl);
req.setMethod('GET');
req.setHeader('Content-Type', 'application/pdf');
req.setCompressed(true);
req.setTimeout(60000);
//Now Send HTTP Request
HttpResponse res = h.send(req);
if(res.getStatusCode() == 200)
{
blob fileContent = res.getBodyAsBlob();
ContentVersion conVer = new ContentVersion();
conVer.ContentLocation = 'S'; // to use S specify this document is in Salesforce, to use E for external files
conVer.PathOnClient = DestinationFile + '.pdf'; // The files name, extension is very important here which will help the file in preview.
conVer.Title = DestinationFile; // Display name of the files
conVer.VersionData = fileContent;
insert conVer;
System.Debug('Success');
}
else
{
System.debug('Error Response ' + res.getBody());
System.Debug(' Status ' + res.getStatus());
System.Debug(' Status Code' + res.getStatusCode());
System.Debug(' Response String' + res.toString());
}
}
}
SearchAndReplaceTextPdfTest.cls
@isTest
private class SearchAndReplaceTextPdfTest {
private testmethod static void testSearchAndReplaceText()
{
Test.setMock(HttpCalloutMock.class, new SearchAndReplaceTextPdfTest.ReplaceTextMock());
(new SearchAndReplaceTextPdf()).searchAndReplaceText();
List<ContentVersion> cv = [select Id, VersionData from ContentVersion];
System.assertEquals(1, cv.size());
}
private testmethod static void testReplaceTextWithImageException()
{
Test.setMock(HttpCalloutMock.class, new SearchAndReplaceTextPdfTest.ReplaceTextMockForExp());
(new SearchAndReplaceTextPdf()).searchAndReplaceText();
List<ContentVersion> cv = [select Id, VersionData from ContentVersion];
System.assertEquals(0, cv.size());
}
public class ReplaceTextMock implements HttpCalloutMock {
public HTTPResponse respond(HTTPRequest req) {
HttpResponse res = new HttpResponse();
String testBody = '{ "url": "https://pdf-temp-files.s3.amazonaws.com/1a0e9a51e2d04fe4bcce0a6a31c365a8/finalFile.pdf", "pageCount": 4, "error": false, "status": 200, "name": "finalFile", "remainingCredits": 98310 } ';
res.setHeader('Content-Type', 'application/json');
res.setBody(testBody);
res.setStatusCode(200);
return res;
}
}
public class ReplaceTextMockForExp implements HttpCalloutMock {
public HTTPResponse respond(HTTPRequest req) {
HttpResponse res = new HttpResponse();
String testBody = '{ "url111111": "https://pdf-temp-files.s3.amazonaws.com/1a0e9a51e2d04fe4bcce0a6a31c365a8/finalFile.pdf", "pageCount": 4, "error": false, "status": 200, "name": "finalFile", "remainingCredits": 98310 } ';
res.setHeader('Content-Type', 'application/json');
res.setBody(testBody);
res.setStatusCode(200);
return res;
}
}
}
PDF.co Web API: the Web API with a set of tools for documents manipulation, data conversion, data extraction, splitting and merging of documents. Includes image recognition, built-in OCR, barcode generation and barcode decoders to decode bar codes from scans, pictures and pdf.
Download Source Code (.zip)
return to the previous page explore PDF Search and Replace Text endpoint
Copyright © 2016 - 2024 PDF.co