SQL Server
SQL Server
Akeneo: Create New Family
See more HTTP Misc Examples
Demonstrates how to create a new family.Chilkat SQL Server Downloads
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls.
--
CREATE PROCEDURE ChilkatSample
AS
BEGIN
DECLARE @hr int
DECLARE @iTmp0 int
-- Important: Do not use nvarchar(max). See the warning about using nvarchar(max).
DECLARE @sTmp0 nvarchar(4000)
DECLARE @success int
SELECT @success = 0
-- This example requires the Chilkat API to have been previously unlocked.
-- See Global Unlock Sample for sample code.
DECLARE @http int
EXEC @hr = sp_OACreate 'Chilkat.Http', @http OUT
IF @hr <> 0
BEGIN
PRINT 'Failed to create ActiveX component'
RETURN
END
-- Use your previously obtained access token.
-- See Get Akeneo Access Token
EXEC sp_OASetProperty @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
-- {
-- "code": "caps",
-- "attributes": [
-- "sku",
-- "name",
-- "description",
-- "price",
-- "color",
-- "picture"
-- ],
-- "attribute_as_label": "name",
-- "attribute_as_image": "picture",
-- "attribute_requirements": {
-- "ecommerce": [
-- "sku",
-- "name",
-- "description",
-- "price",
-- "color"
-- ],
-- "tablet": [
-- "sku",
-- "name",
-- "description",
-- "price"
-- ]
-- },
-- "labels": {
-- "en_US": "Caps",
-- "fr_FR": "Casquettes"
-- }
-- }
--
DECLARE @json int
EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @json OUT
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'code', 'caps'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attributes[0]', 'sku'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attributes[1]', 'name'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attributes[2]', 'description'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attributes[3]', 'price'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attributes[4]', 'color'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attributes[5]', 'picture'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attribute_as_label', 'name'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attribute_as_image', 'picture'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attribute_requirements.ecommerce[0]', 'sku'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attribute_requirements.ecommerce[1]', 'name'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attribute_requirements.ecommerce[2]', 'description'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attribute_requirements.ecommerce[3]', 'price'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attribute_requirements.ecommerce[4]', 'color'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attribute_requirements.tablet[0]', 'sku'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attribute_requirements.tablet[1]', 'name'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attribute_requirements.tablet[2]', 'description'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'attribute_requirements.tablet[3]', 'price'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'labels.en_US', 'Caps'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'labels.fr_FR', 'Casquettes'
EXEC sp_OASetProperty @json, 'EmitCompact', 0
-- Show the JSON to be sent..
EXEC sp_OAMethod @json, 'Emit', @sTmp0 OUT
PRINT @sTmp0
DECLARE @url nvarchar(4000)
SELECT @url = 'http://pim.my-akeneo-site.com/api/rest/v1/families'
DECLARE @resp int
EXEC @hr = sp_OACreate 'Chilkat.HttpResponse', @resp OUT
EXEC sp_OAMethod @http, 'HttpJson', @success OUT, 'POST', @url, @json, 'application/json', @resp
IF @success = 0
BEGIN
EXEC sp_OAGetProperty @http, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @http
EXEC @hr = sp_OADestroy @json
EXEC @hr = sp_OADestroy @resp
RETURN
END
EXEC sp_OAGetProperty @resp, 'StatusCode', @iTmp0 OUT
PRINT 'Response Status Code: ' + @iTmp0
PRINT 'Response Body: '
EXEC sp_OAGetProperty @resp, 'BodyStr', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @http
EXEC @hr = sp_OADestroy @json
EXEC @hr = sp_OADestroy @resp
END
GO