Sample code for 30+ languages & platforms
Objective-C

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 Objective-C Downloads

Objective-C
#import <CkoHttp.h>
#import <CkoJsonObject.h>
#import <NSString.h>
#import <CkoHttpResponse.h>
#import <CkoStringBuilder.h>

BOOL success = NO;

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

CkoHttp *http = [[CkoHttp alloc] init];

// 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

CkoJsonObject *jsonToken = [[CkoJsonObject alloc] init];
success = [jsonToken LoadFile: @"qa_data/tokens/wix.json"];
if (success != YES) {
    NSLog(@"%@",@"Failed to load square.json");
    return;
}

// Get the "refresh_token"
NSString *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>
// }

CkoJsonObject *json = [[CkoJsonObject alloc] init];
[json UpdateString: @"grant_type" value: @"refresh_token"];
[json UpdateString: @"client_id" value: @"CLIENT_ID"];
[json UpdateString: @"client_secret" value: @"CLIENT_SECRET"];
[json UpdateString: @"refresh_token" value: refreshToken];

CkoHttpResponse *resp = [[CkoHttpResponse alloc] init];
success = [http HttpJson: @"POST" url: @"https://www.wix.com/oauth/access" json: json contentType: @"application/json" response: resp];
if (success == NO) {
    NSLog(@"%@",http.LastErrorText);
    return;
}

CkoStringBuilder *sbResponseBody = [[CkoStringBuilder alloc] init];
[resp GetBodySb: sbResponseBody];
CkoJsonObject *jResp = [[CkoJsonObject alloc] init];
[jResp LoadSb: sbResponseBody];
jResp.EmitCompact = NO;

NSLog(@"%@",@"Response Body:");
NSLog(@"%@",[jResp Emit]);

int respStatusCode = [resp.StatusCode intValue];
NSLog(@"%@%d",@"Response Status Code = ",respStatusCode);
if (respStatusCode >= 400) {
    NSLog(@"%@",@"Response Header:");
    NSLog(@"%@",resp.Header);
    NSLog(@"%@",@"Failed.");
    return;
}

// Sample JSON response:

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

NSString *refresh_token = [jResp StringOf: @"refresh_token"];
NSString *access_token = [jResp StringOf: @"access_token"];

// Save the new JSON access token response to a file.
[sbResponseBody WriteFile: @"qa_data/tokens/wix.json" charset: @"utf-8" emitBom: NO];