Objective-C
Objective-C
Akeneo: Create New Product
See more HTTP Misc Examples
Demonstrates how to create a new product.Chilkat Objective-C Downloads
#import <CkoHttp.h>
#import <CkoJsonObject.h>
#import <NSString.h>
#import <CkoHttpResponse.h>
BOOL success = NO;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkoHttp *http = [[CkoHttp alloc] init];
// Use your previously obtained access token.
// See Get Akeneo Access Token
http.AuthToken = @"access_token";
// Build the following JSON to be sent in the request body:
// Use this online tool to generate the code from sample JSON:
// Generate Code to Create JSON
// {
// "identifier": "top",
// "enabled": true,
// "family": "tshirt",
// "categories": [
// "summer_collection"
// ],
// "groups": [],
// "parent": null,
// "values": {
// "name": [
// {
// "data": "Top",
// "locale": "en_US",
// "scope": null
// },
// {
// "data": "D�bardeur",
// "locale": "fr_FR",
// "scope": null
// }
// ],
// "description": [
// {
// "data": "Summer top",
// "locale": "en_US",
// "scope": "ecommerce"
// },
// {
// "data": "Top",
// "locale": "en_US",
// "scope": "tablet"
// },
// {
// "data": "D�bardeur pour l'�t�",
// "locale": "fr_FR",
// "scope": "ecommerce"
// },
// {
// "data": "D�bardeur",
// "locale": "fr_FR",
// "scope": "tablet"
// }
// ],
// "price": [
// {
// "locale": null,
// "scope": null,
// "data": [
// {
// "amount": "150.5",
// "currency": "EUR"
// },
// {
// "amount": "150",
// "currency": "USD"
// }
// ]
// }
// ],
// "color": [
// {
// "locale": null,
// "scope": null,
// "data": "black"
// }
// ],
// "size": [
// {
// "locale": null,
// "scope": null,
// "data": "m"
// }
// ]
// },
// "associations": {
// "PACK": {
// "products": [
// "sunglass"
// ],
// "groups": []
// }
// }
// }
//
CkoJsonObject *json = [[CkoJsonObject alloc] init];
[json UpdateString: @"identifier" value: @"top"];
[json UpdateBool: @"enabled" value: YES];
[json UpdateString: @"family" value: @"tshirt"];
[json UpdateString: @"categories[0]" value: @"summer_collection"];
[json UpdateNewArray: @"groups"];
[json UpdateNull: @"parent"];
[json UpdateString: @"values.name[0].data" value: @"Top"];
[json UpdateString: @"values.name[0].locale" value: @"en_US"];
[json UpdateNull: @"values.name[0].scope"];
[json UpdateString: @"values.name[1].data" value: @"D�bardeur"];
[json UpdateString: @"values.name[1].locale" value: @"fr_FR"];
[json UpdateNull: @"values.name[1].scope"];
[json UpdateString: @"values.description[0].data" value: @"Summer top"];
[json UpdateString: @"values.description[0].locale" value: @"en_US"];
[json UpdateString: @"values.description[0].scope" value: @"ecommerce"];
[json UpdateString: @"values.description[1].data" value: @"Top"];
[json UpdateString: @"values.description[1].locale" value: @"en_US"];
[json UpdateString: @"values.description[1].scope" value: @"tablet"];
[json UpdateString: @"values.description[2].data" value: @"D�bardeur pour l'�t�"];
[json UpdateString: @"values.description[2].locale" value: @"fr_FR"];
[json UpdateString: @"values.description[2].scope" value: @"ecommerce"];
[json UpdateString: @"values.description[3].data" value: @"D�bardeur"];
[json UpdateString: @"values.description[3].locale" value: @"fr_FR"];
[json UpdateString: @"values.description[3].scope" value: @"tablet"];
[json UpdateNull: @"values.price[0].locale"];
[json UpdateNull: @"values.price[0].scope"];
[json UpdateString: @"values.price[0].data[0].amount" value: @"150.5"];
[json UpdateString: @"values.price[0].data[0].currency" value: @"EUR"];
[json UpdateString: @"values.price[0].data[1].amount" value: @"150"];
[json UpdateString: @"values.price[0].data[1].currency" value: @"USD"];
[json UpdateNull: @"values.color[0].locale"];
[json UpdateNull: @"values.color[0].scope"];
[json UpdateString: @"values.color[0].data" value: @"black"];
[json UpdateNull: @"values.size[0].locale"];
[json UpdateNull: @"values.size[0].scope"];
[json UpdateString: @"values.size[0].data" value: @"m"];
[json UpdateString: @"associations.PACK.products[0]" value: @"sunglass"];
[json UpdateNewArray: @"associations.PACK.groups"];
json.EmitCompact = NO;
// Show the JSON to be sent..
NSLog(@"%@",[json Emit]);
NSString *url = @"http://pim.my-akeneo-site.com/api/rest/v1/products";
CkoHttpResponse *resp = [[CkoHttpResponse alloc] init];
success = [http HttpJson: @"POST" url: url json: json contentType: @"application/json" response: resp];
if (success == NO) {
NSLog(@"%@",http.LastErrorText);
return;
}
NSLog(@"%@%d",@"Response Status Code: ",[resp.StatusCode intValue]);
NSLog(@"%@",@"Response Body: ");
NSLog(@"%@",resp.BodyStr);
// The akeneo response will include a "Location" header, such as the following:
// HTTP/1.1 201 Created
// Date: Tue, 22 Jan 2019 10:36:35 GMT
// Server: Apache/2
// X-Powered-By: PHP/7.1.25
// Cache-Control: max-age=0, private, must-revalidate, no-cache, private
// Set-Cookie: abcdefg; path=/; HttpOnly
// Location: http://xyz.example.com/api/rest/v1/products/L0000123
// Vary: User-Agent
// Content-Length: 0
// Keep-Alive: timeout=2, max=100
// Connection: Keep-Alive
// Content-Type: application/json
// Get the location header using resp.GetHeaderField
NSString *location = [resp GetHeaderField: @"Location"];
NSLog(@"%@%@",@"Location: ",location);