MakeSearchablePdfFromUrlAsynchronously.ps1
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 | # Cloud API asynchronous "Make Searchable PDF" job example. # Allows to avoid timeout errors when processing huge or scanned PDF documents. # The authentication key (API Key). # Get your own by registering at https://app.pdf.co/documentation/api $API_KEY = "***********************************" # Direct URL of source PDF file. $SourceFileURL = "https://s3-us-west-2.amazonaws.com/bytescout-com/files/demo-files/cloud-api/pdf-make-searchable/sample.pdf" # Comma-separated list of page indices (or ranges) to process. Leave empty for all pages. Example: '0,2-5,7-'. $Pages = " " # PDF document password. Leave empty for unprotected documents. $Password = "" # OCR language. " eng ", " fra ", " deu ", " spa " supported currently. Let us know if you need more. $Language = " eng " # Destination PDF file name $DestinationFile = " .\result.pdf " # (!) Make asynchronous job $Async = $true # Prepare URL for `Make Searchable PDF` API call $query = " https://api.pdf.co/v1/pdf/makesearchable ? name={0}&password={1}&pages={2}&lang={3}&url={4}&async={5} " -f ` $(Split-Path $DestinationFile -Leaf), $Password, $Pages, $Language, $SourceFileURL, $Async $query = [System.Uri]::EscapeUriString($query) try { # Execute request $jsonResponse = Invoke-RestMethod -Method Get -Headers @{ " x-api-key " = $API_KEY } -Uri $query if ($jsonResponse.error -eq $false) { # Asynchronous job ID $jobId = $jsonResponse.jobId # URL of generated PDF file that will available after the job completion $resultFileUrl = $jsonResponse.url # Check the job status in a loop. do { $jsonStatus = Invoke-RestMethod -Method Get -Uri $statusCheckUrl # Display timestamp and status (for demo purposes) Write-Host " $( Get-date ): $( $jsonStatus .Status) " if ($jsonStatus.Status -eq " Finished ") { # Download PDF file Invoke-WebRequest -Headers @{ " x-api-key " = $API_KEY } -OutFile $DestinationFile -Uri $resultFileUrl Write-Host " Generated PDF file saved as ` "$($DestinationFile)`" file." break } elseif ( $jsonStatus .Status -eq "InProgress" ) { # Pause for a few seconds Start-Sleep -Seconds 3 } else { Write-Host $jsonStatus .Status break } } while ( $true ) } else { # Display service reported error Write-Host $jsonResponse .message } } catch { # Display request error Write-Host $_ .Exception } |
run.bat
1 2 3 4 5 6 | @echo off powershell -NoProfile -ExecutionPolicy Bypass -Command "& .\MakeSearchablePdfFromUrlAsynchronously.ps1" echo Script finished with errorlevel=%errorlevel% pause |
Click here to get your Free Trial version of the SDK
IMPORTANT:
Cloud API is deprecated and was replaced with more powerful and secure www.PDF.co Web API
CLICK HERE
TO LEARN MORE
ABOUT NEW
www.PDF.co
w/ Web API
On-Premise API Server
Cloud API Server