Chilkat Online Tools

Objective-C / Coupa Postman Collection - OAuth - Master / Create FxRates

Back to Collection Items

#import <CkoHttp.h>
#import <CkoXml.h>
#import <CkoStringBuilder.h>
#import <CkoHttpResponse.h>

// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

CkoHttp *http = [[CkoHttp alloc] init];
BOOL success;

// Use this online tool to generate code from sample XML: Generate Code to Create XML

// The following XML is sent in the request body.

// <?xml version="1.0" encoding="utf-8"?>
// <exchange-rate>
//     <rate type="decimal">0.801539004</rate>
//     <rate-date type="dateTime">2021-11-22</rate-date>
//     <from-currency>
//         <code>USD</code>
//     </from-currency>
//     <to-currency>
//         <code>EUR</code>
//     </to-currency>
// </exchange-rate>
// 

CkoXml *xml = [[CkoXml alloc] init];
xml.Tag = @"exchange-rate";
[xml UpdateAttrAt: @"rate" autoCreate: YES attrName: @"type" attrValue: @"decimal"];
[xml UpdateChildContent: @"rate" value: @"0.801539004"];
[xml UpdateAttrAt: @"rate-date" autoCreate: YES attrName: @"type" attrValue: @"dateTime"];
[xml UpdateChildContent: @"rate-date" value: @"2021-11-22"];
[xml UpdateChildContent: @"from-currency|code" value: @"USD"];
[xml UpdateChildContent: @"to-currency|code" value: @"EUR"];

// Adds the "Authorization: Bearer <access_token>" header.
http.AuthToken = @"<access_token>";

CkoStringBuilder *sbRequestBody = [[CkoStringBuilder alloc] init];
[xml GetXmlSb: sbRequestBody];

CkoHttpResponse *resp = [http PTextSb: @"POST" url: @"[\"code\",\"decimals\"]}]" textData: sbRequestBody charset: @"utf-8" contentType: @"application/xml" md5: NO gzip: NO];
if (http.LastMethodSuccess == NO) {
    NSLog(@"%@",http.LastErrorText);
    return;
}

NSLog(@"%d",[resp.StatusCode intValue]);
NSLog(@"%@",resp.BodyStr);

Curl Command

curl -X POST
	-H "Authorization: Bearer <access_token>"
	-d '<exchange-rate>
    <rate type="decimal">0.801539004</rate>
    <rate-date type="dateTime">2021-11-22</rate-date>
    <from-currency>
        <code>USD</code>
    </from-currency>
    <to-currency>
        <code>EUR</code>
    </to-currency>
</exchange-rate>'
https://domain.com/exchange_rates?fields=["id","rate","rate_date",{"from_currency": ["code","decimals"]},{"to_currency": ["code","decimals"]}]

Postman Collection Item JSON

{
  "name": "Create FxRates",
  "request": {
    "method": "POST",
    "header": [
    ],
    "body": {
      "mode": "raw",
      "raw": "<exchange-rate>\n    <rate type=\"decimal\">0.801539004</rate>\n    <rate-date type=\"dateTime\">2021-11-22</rate-date>\n    <from-currency>\n        <code>USD</code>\n    </from-currency>\n    <to-currency>\n        <code>EUR</code>\n    </to-currency>\n</exchange-rate>",
      "options": {
        "raw": {
          "language": "xml"
        }
      }
    },
    "url": {
      "raw": "{{URL}}/exchange_rates?fields=[\"id\",\"rate\",\"rate_date\",{\"from_currency\": [\"code\",\"decimals\"]},{\"to_currency\": [\"code\",\"decimals\"]}]",
      "host": [
        "{{URL}}"
      ],
      "path": [
        "exchange_rates"
      ],
      "query": [
        {
          "key": "fields",
          "value": "[\"id\",\"rate\",\"rate_date\",{\"from_currency\": [\"code\",\"decimals\"]},{\"to_currency\": [\"code\",\"decimals\"]}]"
        }
      ]
    }
  },
  "response": [
  ]
}