SQL Server
SQL Server
Shopware 6 -List Currencies
See more Shopware 6 Examples
With store-api.currency you can fetch all currencies that are available in this Sales Channel.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 assumes 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
-- Sends the following POST
-- POST /store-api/v3/currency
-- {
-- "includes": {
-- "currency": [
-- "id",
-- "factor",
-- "shortName",
-- "name"
-- ]
-- }
-- }
-- Use this online tool to generate code from sample JSON:
-- Generate Code to Create JSON
DECLARE @json int
EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @json OUT
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'includes.currency[0]', 'id'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'includes.currency[1]', 'factor'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'includes.currency[2]', 'shortName'
EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'includes.currency[3]', 'name'
-- This request simply authenticates with the sw-access-key you can interactively copy from your
-- sales channel in the Shopware 6 administration web portal.
-- We do NOT use OAuth2 for Store API requests.
EXEC sp_OAMethod @http, 'SetRequestHeader', NULL, 'sw-access-key', '<sales-channel-api-access-key>'
DECLARE @resp int
EXEC @hr = sp_OACreate 'Chilkat.HttpResponse', @resp OUT
EXEC sp_OAMethod @http, 'HttpJson', @success OUT, 'POST', 'https://my-shopware-6-shop.de/store-api/v3/currency', @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
DECLARE @sbResponseBody int
EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbResponseBody OUT
EXEC sp_OAMethod @resp, 'GetBodySb', @success OUT, @sbResponseBody
EXEC sp_OAMethod @sbResponseBody, 'GetAsString', @sTmp0 OUT
PRINT @sTmp0
-- If we get a 401 response, it may be that our access token expired and we need to fetch a new one.
DECLARE @respStatusCode int
EXEC sp_OAGetProperty @resp, 'StatusCode', @respStatusCode OUT
PRINT 'Response Status Code = ' + @respStatusCode
IF @respStatusCode >= 400
BEGIN
PRINT 'Response Header:'
EXEC sp_OAGetProperty @resp, 'Header', @sTmp0 OUT
PRINT @sTmp0
PRINT 'Failed.'
EXEC @hr = sp_OADestroy @http
EXEC @hr = sp_OADestroy @json
EXEC @hr = sp_OADestroy @resp
EXEC @hr = sp_OADestroy @sbResponseBody
RETURN
END
-- Sample JSON response:
-- (Sample code for parsing the JSON response is shown below)
-- A single object can be returned.
-- {
-- "factor": 1,
-- "shortName": "EUR",
-- "name": "Euro",
-- "id": "b7d2554b0ce847cd82f3ac9bd1c0dfca",
-- "apiAlias": "currency"
-- }
-- or an array of currency objects can be returned:
-- [
-- {
-- "factor": 0.89157,
-- "shortName": "GBP",
-- "name": "Pound",
-- "id": "01913e4cbe604f45be84cbabd5966239",
-- "apiAlias": "currency"
-- },
-- {
-- "factor": 10.51,
-- "shortName": "SEK",
-- "name": "Swedish krone",
-- "id": "3dfbaa78994b4f1cac491f1a992646fd",
-- "apiAlias": "currency"
-- }
-- ]
-- Sample code for parsing the JSON response...
-- Use the following online tool to generate parsing code from sample JSON:
-- Generate Parsing Code from JSON
DECLARE @factor nvarchar(4000)
DECLARE @shortName nvarchar(4000)
DECLARE @name nvarchar(4000)
DECLARE @id nvarchar(4000)
DECLARE @apiAlias nvarchar(4000)
EXEC sp_OAMethod @sbResponseBody, 'Trim', @success OUT
EXEC sp_OAMethod @sbResponseBody, 'StartsWith', @iTmp0 OUT, '[', 0
IF @iTmp0 = 1
BEGIN
-- This is an array.
DECLARE @jRespArr int
EXEC @hr = sp_OACreate 'Chilkat.JsonArray', @jRespArr OUT
EXEC sp_OAMethod @jRespArr, 'LoadSb', @success OUT, @sbResponseBody
DECLARE @jCurrency int
DECLARE @i int
SELECT @i = 0
DECLARE @count_i int
EXEC sp_OAGetProperty @jRespArr, 'Size', @count_i OUT
WHILE @i < @count_i
BEGIN
EXEC sp_OAMethod @jRespArr, 'ObjectAt', @jCurrency OUT, @i
EXEC sp_OAMethod @jCurrency, 'StringOf', @factor OUT, 'factor'
EXEC sp_OAMethod @jCurrency, 'StringOf', @shortName OUT, 'shortName'
EXEC sp_OAMethod @jCurrency, 'StringOf', @name OUT, 'name'
EXEC sp_OAMethod @jCurrency, 'StringOf', @id OUT, 'id'
EXEC sp_OAMethod @jCurrency, 'StringOf', @apiAlias OUT, 'apiAlias'
EXEC @hr = sp_OADestroy @jCurrency
SELECT @i = @i + 1
END
END
ELSE
BEGIN
-- This is a single currency.
DECLARE @jResp int
EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @jResp OUT
EXEC sp_OAMethod @jResp, 'LoadSb', @success OUT, @sbResponseBody
EXEC sp_OASetProperty @jResp, 'EmitCompact', 0
PRINT 'Response Body:'
EXEC sp_OAMethod @jResp, 'Emit', @sTmp0 OUT
PRINT @sTmp0
EXEC sp_OAMethod @jResp, 'StringOf', @factor OUT, 'factor'
EXEC sp_OAMethod @jResp, 'StringOf', @shortName OUT, 'shortName'
EXEC sp_OAMethod @jResp, 'StringOf', @name OUT, 'name'
EXEC sp_OAMethod @jResp, 'StringOf', @id OUT, 'id'
EXEC sp_OAMethod @jResp, 'StringOf', @apiAlias OUT, 'apiAlias'
END
EXEC @hr = sp_OADestroy @http
EXEC @hr = sp_OADestroy @json
EXEC @hr = sp_OADestroy @resp
EXEC @hr = sp_OADestroy @sbResponseBody
EXEC @hr = sp_OADestroy @jRespArr
EXEC @hr = sp_OADestroy @jResp
END
GO