Back to Collection Items
#import <CkoHttp.h>
#import <CkoJsonObject.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 JSON: Generate Code to Create JSON
// The following JSON is sent in the request body.
// {
// "card": {
// "expiry_month": "01",
// "expiry_year": "24"
// }
// }
CkoJsonObject *json = [[CkoJsonObject alloc] init];
[json UpdateString: @"card.expiry_month" value: @"01"];
[json UpdateString: @"card.expiry_year" value: @"24"];
[http SetRequestHeader: @"Content-Type" value: @"application/json"];
[http SetRequestHeader: @"X-GP-Idempotency" value: @"234234234"];
[http SetRequestHeader: @"X-GP-Version" value: @"{{version}}"];
// Adds the "Authorization: Bearer {{token}}" header.
http.AuthToken = @"{{token}}";
[http SetRequestHeader: @"Accept" value: @"application/json"];
CkoStringBuilder *sbRequestBody = [[CkoStringBuilder alloc] init];
[json EmitSb: sbRequestBody];
CkoHttpResponse *resp = [http PTextSb: @"PATCH" url: @"https://{{url}}/ucp/payment-methods/{{pmt_id}}" textData: sbRequestBody charset: @"utf-8" contentType: @"application/json" md5: NO gzip: NO];
if (http.LastMethodSuccess == NO) {
NSLog(@"%@",http.LastErrorText);
return;
}
NSLog(@"%d",[resp.StatusCode intValue]);
NSLog(@"%@",resp.BodyStr);
Curl Command
curl -X PATCH
-H "Authorization: Bearer {{token}}"
-H "Accept: application/json"
-H "X-GP-Version: {{version}}"
-H "Content-Type: application/json"
-H "X-GP-Idempotency: 234234234"
-d '{
"card": {
"expiry_month": "01",
"expiry_year": "24"
}
}'
https://{{url}}/ucp/payment-methods/{{pmt_id}}
Postman Collection Item JSON
{
"name": "TKA_2.2 Edit",
"event": [
{
"listen": "test",
"script": {
"exec": [
"tests[\"Response time is acceptable\"] = _.inRange(responseTime, 100, 1500); \r",
"\r",
"\r",
"pm.test(\"Successful POST request\", function () {\r",
" pm.expect(pm.response.code).to.be.oneOf([200,201,202]);\r",
"});\r",
"\r",
"pm.test(\"Status code name has string\", function () {\r",
" pm.response.to.have.status(\"OK\");\r",
"});"
],
"type": "text/javascript"
}
}
],
"request": {
"method": "PATCH",
"header": [
{
"key": "Authorization",
"value": "Bearer {{token}}"
},
{
"key": "Accept",
"value": "application/json",
"disabled": true
},
{
"key": "X-GP-Version",
"type": "text",
"value": "{{version}}"
},
{
"key": "Content-Type",
"value": "application/json",
"type": "text"
},
{
"key": "X-GP-Idempotency",
"value": "234234234",
"type": "text",
"disabled": true
}
],
"body": {
"mode": "raw",
"raw": "{\n \"card\": {\n \"expiry_month\": \"01\",\n \"expiry_year\": \"24\"\n }\n}"
},
"url": {
"raw": "https://{{url}}/ucp/payment-methods/{{pmt_id}}",
"protocol": "https",
"host": [
"{{url}}"
],
"path": [
"ucp",
"payment-methods",
"{{pmt_id}}"
]
},
"description": "This request allows a user to change info about a stored card such as update the card expiry date or the funding type of card or the bank identifier of the account number.\r\nTo alter the card expiry date, go to body of request and input new date. User must enter token received from tokenization of card in query string.\r\nIn the response you should see new expiry date associated with token user entered in query string.\r\n\r\nFor more info on editing a card, visit: https://developer.globalpay.com/api/payment-methods-tokenization#/Edit/patch_payment_methods__id_"
},
"response": [
]
}