Don,
Does the return code change?
This is what I do.
// Rate Response From API Call
Dcl-ds RateResponse Qualified;
cnt_accessorials Int(5);
Dcl-ds accessorials Dim(50);
code Char(10);
name VarChar(100);
amount Packed(7 : 2);
End-Ds;
Bla-Bla-Bla
End-Ds;
// Rate Results From API Call - Service Not Available
Dcl-ds ErrorResponse Qualified;
cnt_errors Int(5);
Dcl-ds errors Dim(20);
code Char(20);
message VarChar(100);
End-Ds;
End-Ds;
rc = http_post_stmf( RateURL
: RequestFile
: ResponseFile
: HTTP_TIMEOUT
: HTTP_USERAGENT
: 'application/json' );
Select;
// Load Response If No Error
When Rc = 1;
Clear RateResponse;
Monitor;
// Parse Response JSON Rates Doc Using YAJL
data-into RateResponse %DATA(ResponseFile
: 'doc=file case=any countprefix=cnt_ allowmissing=yes allowextra=yes')
%PARSER('YAJLINTO');
// Unable To Shop
When Rc = 400
Or Rc = 503;
Clear Errorcode;
If Rc = 400;
Clear ErrorResponse;
Monitor;
// Parse Response JSON Rates Doc Using YAJL
data-into ErrorResponse %DATA(ResponseFile
: 'doc=file case=any countprefix=cnt_ allowmissing=yes allowextra=yes')
%PARSER('YAJLINTO');
End-Sl;
-----Original Message-----
From: MIDRANGE-L <midrange-l-bounces@xxxxxxxxxxxxxxxxxx> On Behalf Of Don Brown via MIDRANGE-L
Sent: Sunday, December 18, 2022 10:44 PM
To: midrange-l@xxxxxxxxxxxxxxxxxx
Cc: Don Brown <DBrown@xxxxxxxxxx>
Subject: External DATA-INTO - Different JSON depending on succeed or fail
CAUTION: This email originated from outside of the organization. Do not click links or open attachments unless you recognize the sender and know the content is safe.
Hi
We are dealing with a new provider and are consuming their service.
They reply with two completely different JSON formats depending if the request is successful or not. And neither are named.
For example
if error found on the request , then the return data provides the response details
{
"responseType": "executeQuery",
"responseTime": 1669597839789,
"responseCode": 104,
"errorCode": 0,
"message": "Parameter Error: Custom Report Exception: Parameter
2022-11-10 :00:00 and 2022-11-10 23:59:59 must be timestamps in the format YYYY-DD-MM HH:MM:SS"
}
Whereas if the request is successful we get an array of data
[
{ "RequestedDate":"2022-11-10", ....... },
{ "RequestedDate":"2022-11-11", ....... },
{ ... }
]
So what we are doing is attempting a DATA-INTO into the successful data structure and if that fails attempting to load into the response data structure.
While this works I was just wondering if there is a better option to be able to determine which response received and therefore retrieve into the respective data structure rather than the trial and error approach
Thanks for any suggestions
Don
--
This email has been scanned for computer viruses. Although MSD has taken reasonable precautions to ensure no viruses are present in this email, MSD cannot accept responsibility for any loss or damage arising from the use of this email or attachments..
--
This is the Midrange Systems Technical Discussion (MIDRANGE-L) mailing list To post a message email: MIDRANGE-L@xxxxxxxxxxxxxxxxxx To subscribe, unsubscribe, or change list options,
visit:
https://lists.midrange.com/mailman/listinfo/midrange-l
or email: MIDRANGE-L-request@xxxxxxxxxxxxxxxxxx
Before posting, please take a moment to review the archives at
https://archive.midrange.com/midrange-l.
Please contact support@xxxxxxxxxxxxxxxxxxxx for any subscription related questions.
Help support midrange.com by shopping at amazon.com with our affiliate link:
https://amazon.midrange.com
Subject to Change Notice:
WalzCraft reserves the right to improve designs, and to change specifications without notice.
Confidentiality Notice:
This message and any attachments may contain confidential and privileged information that is protected by law. The information contained herein is transmitted for the sole use of the intended recipient(s) and should "only" pertain to "WalzCraft" company matters. If you are not the intended recipient or designated agent of the recipient of such information, you are hereby notified that any use, dissemination, copying or retention of this email or the information contained herein is strictly prohibited and may subject you to penalties under federal and/or state law. If you received this email in error, please notify the sender immediately and permanently delete this email. Thank You
WalzCraft PO Box 1748 La Crosse, WI, 54602-1748
www.walzcraft.com<
http://www.walzcraft.com> Phone: 1-800-237-1326
As an Amazon Associate we earn from qualifying purchases.