Sample code for 30+ languages & platforms
AutoIt

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 AutoIt Downloads

AutoIt
Local $bSuccess = False

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

$oHttp = ObjCreate("Chilkat.Http")

; 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

$oJson = ObjCreate("Chilkat.JsonObject")
$oJson.UpdateString("includes.currency[0]","id")
$oJson.UpdateString("includes.currency[1]","factor")
$oJson.UpdateString("includes.currency[2]","shortName")
$oJson.UpdateString("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.
$oHttp.SetRequestHeader "sw-access-key","<sales-channel-api-access-key>"

$oResp = ObjCreate("Chilkat.HttpResponse")
$bSuccess = $oHttp.HttpJson("POST","https://my-shopware-6-shop.de/store-api/v3/currency",$oJson,"application/json",$oResp)
If ($bSuccess = False) Then
    ConsoleWrite($oHttp.LastErrorText & @CRLF)
    Exit
EndIf

$oSbResponseBody = ObjCreate("Chilkat.StringBuilder")
$oResp.GetBodySb($oSbResponseBody)

ConsoleWrite($oSbResponseBody.GetAsString() & @CRLF)

; If we get a 401 response, it may be that our access token expired and we need to fetch a new one.
Local $iRespStatusCode = $oResp.StatusCode
ConsoleWrite("Response Status Code = " & $iRespStatusCode & @CRLF)
If ($iRespStatusCode >= 400) Then
    ConsoleWrite("Response Header:" & @CRLF)
    ConsoleWrite($oResp.Header & @CRLF)
    ConsoleWrite("Failed." & @CRLF)
    Exit
EndIf

; 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

Local $sFactor
Local $shortName
Local $sName
Local $sId
Local $sApiAlias

$oSbResponseBody.Trim()
If ($oSbResponseBody.StartsWith("[",False) = True) Then
    ; This is an array.
    $oJRespArr = ObjCreate("Chilkat.JsonArray")

    $oJRespArr.LoadSb($oSbResponseBody)

Local $oJCurrency
Local $i = 0
Local $iCount_i = $oJRespArr.Size
    While $i < $iCount_i
        $oJCurrency = $oJRespArr.ObjectAt($i)
        $sFactor = $oJCurrency.StringOf("factor")
        $shortName = $oJCurrency.StringOf("shortName")
        $sName = $oJCurrency.StringOf("name")
        $sId = $oJCurrency.StringOf("id")
        $sApiAlias = $oJCurrency.StringOf("apiAlias")

        $i = $i + 1
    Wend

Else
    ; This is a single currency.
    $oJResp = ObjCreate("Chilkat.JsonObject")

    $oJResp.LoadSb($oSbResponseBody)
    $oJResp.EmitCompact = False

    ConsoleWrite("Response Body:" & @CRLF)
    ConsoleWrite($oJResp.Emit() & @CRLF)

    $sFactor = $oJResp.StringOf("factor")
    $shortName = $oJResp.StringOf("shortName")
    $sName = $oJResp.StringOf("name")
    $sId = $oJResp.StringOf("id")
    $sApiAlias = $oJResp.StringOf("apiAlias")
EndIf