Sample code for 30+ languages & platforms
PowerShell

Refresh WiX Access Token

See more WiX Examples

Request a new access token each time you call a WiX API. Use the refresh token together with your secret key, to request refresh tokens

Chilkat PowerShell Downloads

PowerShell
Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll"

$success = $false

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

$http = New-Object Chilkat.Http

# Implements the following CURL command:

# curl -X POST \
#   https://www.wix.com/oauth/access \
#   -H 'Content-Type: application/json' \
#   -d '{
#     "grant_type": "refresh_token",
#     "client_id": <CLIENT_ID>,
#     "client_secret": <CLIENT_SECRET>,
#     "refresh_token": <REFRESH_TOKEN>
# }'

# It is assumed we previously obtained an OAuth2 access token.
# This example loads the JSON access token file 
# saved by this example: Get WiX OAuth2 Access Token

$jsonToken = New-Object Chilkat.JsonObject
$success = $jsonToken.LoadFile("qa_data/tokens/wix.json")
if ($success -ne $true) {
    $("Failed to load square.json")
    exit
}

# Get the "refresh_token"
$refreshToken = $jsonToken.StringOf("refresh_token")

# The following JSON is sent in the request body.

# {
#   "grant_type": "refresh_token",
#   "client_id": <APP_ID>,
#   "client_secret": <APP_SECRET>,
#   "refresh_token": <REFRESH_TOKEN>
# }

$json = New-Object Chilkat.JsonObject
$json.UpdateString("grant_type","refresh_token")
$json.UpdateString("client_id","CLIENT_ID")
$json.UpdateString("client_secret","CLIENT_SECRET")
$json.UpdateString("refresh_token",$refreshToken)

$resp = New-Object Chilkat.HttpResponse
$success = $http.HttpJson("POST","https://www.wix.com/oauth/access",$json,"application/json",$resp)
if ($success -eq $false) {
    $($http.LastErrorText)
    exit
}

$sbResponseBody = New-Object Chilkat.StringBuilder
$resp.GetBodySb($sbResponseBody)
$jResp = New-Object Chilkat.JsonObject
$jResp.LoadSb($sbResponseBody)
$jResp.EmitCompact = $false

$("Response Body:")
$($jResp.Emit())

$respStatusCode = $resp.StatusCode
$("Response Status Code = " + $respStatusCode)
if ($respStatusCode -ge 400) {
    $("Response Header:")
    $($resp.Header)
    $("Failed.")
    exit
}

# Sample JSON response:

# {
#   "refresh_token": "OAUTH2.eyJraWQ ... vnB4cQ",
#   "access_token": "OAUTH2.eyJra ... la18lrw"
# }

$refresh_token = $jResp.StringOf("refresh_token")
$access_token = $jResp.StringOf("access_token")

# Save the new JSON access token response to a file.
$sbResponseBody.WriteFile("qa_data/tokens/wix.json","utf-8",$false)