From 8612a1521d4d3da6046cc0d7f9a6a76d116c7800 Mon Sep 17 00:00:00 2001 From: Christopher Green Date: Mon, 24 Jun 2024 14:37:20 -0500 Subject: [PATCH] Add polling retries to samples that lacked it --- .../Multipart Payload/request-status.js | 79 +++++++++++-------- .../Multipart Payload/request-status.php | 13 ++- .../Multipart Payload/request-status.py | 6 ++ .../Multipart Payload/request-status.sh | 15 +++- 4 files changed, 79 insertions(+), 34 deletions(-) diff --git a/JavaScript/Endpoint Examples/Multipart Payload/request-status.js b/JavaScript/Endpoint Examples/Multipart Payload/request-status.js index e541f37..e0f7789 100644 --- a/JavaScript/Endpoint Examples/Multipart Payload/request-status.js +++ b/JavaScript/Endpoint Examples/Multipart Payload/request-status.js @@ -2,42 +2,59 @@ const axios = require("axios"); const FormData = require("form-data"); const fs = require("fs"); - const apiKey = "xxxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"; // Replace with your API key const pathToFile = "/path/to/file.pdf"; -let bmpRequestData = new FormData(); -bmpRequestData.append("file", fs.createReadStream(pathToFile)); -let bmpConfig = { - method: "post", - maxBodyLength: Infinity, - url: "https://api.pdfrest.com/bmp", - headers: { - "Api-Key": apiKey, - "Response-Type": "requestId", // Use this header to get a request ID. - ...bmpRequestData.getHeaders(), - }, - data: bmpRequestData, +const sleep = (ms) => { + return new Promise(resolve => setTimeout(resolve, ms)); +} + +const sendBmpReq = async (config) => { + return await axios(config); +}; + +const pollUntilFulfilled = async (requestId) => { + const pollConfig = { + method: "get", + maxBodyLength: Infinity, // set maximum length of the request body + url: `https://api.pdfrest.com/request-status/${requestId}`, + headers: { "Api-Key": apiKey } + }; + requestStatusResponse = await axios(pollConfig); + let status = requestStatusResponse.data.status; + while (status === "pending") { + console.log(JSON.stringify(requestStatusResponse.data)); + await sleep(5000); + requestStatusResponse = await axios(pollConfig); + status = requestStatusResponse.data.status; + } + console.log(JSON.stringify(requestStatusResponse.data)); }; -axios(bmpConfig) - .then(bmpResponse => { +const demoApiPolling = async () => { + try { + const bmpRequestData = new FormData(); + bmpRequestData.append("file", fs.createReadStream(pathToFile)); + + const bmpConfig = { + method: "post", + maxBodyLength: Infinity, + url: "https://api.pdfrest.com/bmp", + headers: { + "Api-Key": apiKey, + "Response-Type": "requestId", // Use this header to get a request ID. + ...bmpRequestData.getHeaders(), + }, + data: bmpRequestData, + }; + bmpResponse = await sendBmpReq(bmpConfig); console.log(JSON.stringify(bmpResponse.data)); const requestId = bmpResponse.data.requestId; - let config = { - method: "get", - maxBodyLength: Infinity, // set maximum length of the request body - url: `https://api.pdfrest.com/request-status/${requestId}`, - headers: { "Api-Key": apiKey } - }; - axios.request(config) - .then((requestStatusResponse) => { - console.log(JSON.stringify(requestStatusResponse.data)); - }) - .catch((error) => { - console.log(error); - }); - }).catch(error => { - console.log(error); - }) + await pollUntilFulfilled(requestId); + } catch (err) { + console.error(err); + } +}; + +demoApiPolling(); diff --git a/PHP/Endpoint Examples/Multipart Payload/request-status.php b/PHP/Endpoint Examples/Multipart Payload/request-status.php index 10859c5..353d2e7 100644 --- a/PHP/Endpoint Examples/Multipart Payload/request-status.php +++ b/PHP/Endpoint Examples/Multipart Payload/request-status.php @@ -46,6 +46,17 @@ $res = $client->sendAsync($request)->wait(); -echo $res->getBody(); // Output the response body, which contains the status information. +$status = json_decode($res->getBody())->{'status'}; + +while (strcmp($status, "pending") == 0): + echo $res->getBody(); // Output the response body, which contains the status information. + echo "\r\n"; + sleep(5); + $res = $client->sendAsync($request)->wait(); + $status = json_decode($res->getBody())->{'status'}; +endwhile; + +echo $res->getBody(); echo "\r\n"; + ?> diff --git a/Python/Endpoint Examples/Multipart Payload/request-status.py b/Python/Endpoint Examples/Multipart Payload/request-status.py index 588e62f..3ca13cf 100644 --- a/Python/Endpoint Examples/Multipart Payload/request-status.py +++ b/Python/Endpoint Examples/Multipart Payload/request-status.py @@ -1,6 +1,7 @@ from requests_toolbelt import MultipartEncoder import requests import json +import time api_key = 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx' # place your api key here @@ -42,6 +43,11 @@ if response.ok: response_json = response.json() + while response_json["status"] == "pending": + print(json.dumps(response_json, indent = 2)) + time.sleep(5) + response = requests.get(api_polling_endpoint_url, headers=headers) + response_json = response.json() print(json.dumps(response_json, indent = 2)) else: print(response.text) diff --git a/cURL/Endpoint Examples/Multipart Payload/request-status.sh b/cURL/Endpoint Examples/Multipart Payload/request-status.sh index d62bcb8..811ed90 100755 --- a/cURL/Endpoint Examples/Multipart Payload/request-status.sh +++ b/cURL/Endpoint Examples/Multipart Payload/request-status.sh @@ -12,5 +12,16 @@ REQUEST_ID=$(curl -X POST "https://api.pdfrest.com/pdfa" \ -F "output=example_out" \ | jq -r '.requestId') -curl -X GET "https://api.pdfrest.com/request-status/$REQUEST_ID" \ - -H "Api-Key: $API_KEY" \ No newline at end of file +RESPONSE=$(curl -X GET "https://api.pdfrest.com/request-status/$REQUEST_ID" \ + -H "Api-Key: $API_KEY") +echo $RESPONSE +STATUS=$(echo $RESPONSE | jq -r '.status') + +while [ $STATUS = "pending" ] +do + sleep 5 + RESPONSE=$(curl -X GET "https://api.pdfrest.com/request-status/$REQUEST_ID" \ + -H "Api-Key: $API_KEY") + echo $RESPONSE + STATUS=$(echo $RESPONSE | jq -r '.status') +done \ No newline at end of file