RestorePhoneNumber Swift3 Example
func chilkatTest() {
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
let rest = CkoRest()!
var success: Bool
let authAws = CkoAuthAws()!
authAws.accessKey = "AWS_ACCESS_KEY"
authAws.secretKey = "AWS_SECRET_KEY"
// Don't forget to change the region to your particular region. (Also make the same change in the call to Connect below.)
authAws.region = "us-west-2"
authAws.serviceName = "chime"
// SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
rest.setAuthAws(authAws)
// URL: https://chime.us-west-2.amazonaws.com/
// Use the same region as specified above.
success = rest.connect("chime.us-west-2.amazonaws.com", port: 443, tls: true, autoReconnect: true)
if success != true {
print("ConnectFailReason: \(rest.connectFailReason.intValue)")
print("\(rest.lastErrorText!)")
return
}
// The following code creates the JSON request body.
// The JSON created by this code is shown below.
// Use this online tool to generate code from sample JSON:
// Generate Code to Create JSON
let json = CkoJsonObject()!
// The JSON request body created by the above code:
// {}
rest.addHeader("Content-Type", value: "application/x-amz-json-1.1")
rest.addHeader("X-Amz-Target", value: "RestorePhoneNumber")
let sbRequestBody = CkoStringBuilder()!
json.emitSb(sbRequestBody)
let sbResponseBody = CkoStringBuilder()!
success = rest.fullRequestSb("POST", uriPath: "/phone-numbers/{phoneNumberId}?operation=restore", requestBody: sbRequestBody, responseBody: sbResponseBody)
if success != true {
print("\(rest.lastErrorText!)")
return
}
var respStatusCode: Int = rest.responseStatusCode.intValue
print("response status code = \(respStatusCode)")
if respStatusCode != 200 {
print("Response Header:")
print("\(rest.responseHeader!)")
print("Response Body:")
print("\(sbResponseBody.getAsString()!)")
return
}
let jResp = CkoJsonObject()!
jResp.loadSb(sbResponseBody)
// The following code parses the JSON response.
// A sample JSON response is shown below the sample code.
// Use this online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON
var AssociatedTimestamp: Int
var Name: String?
var Value: String?
var CallingName: String? = jResp.string(of: "PhoneNumber.CallingName")
var CallingNameStatus: String? = jResp.string(of: "PhoneNumber.CallingNameStatus")
var InboundCall: Int = jResp.int(of: "PhoneNumber.Capabilities.InboundCall").intValue
var InboundMMS: Int = jResp.int(of: "PhoneNumber.Capabilities.InboundMMS").intValue
var InboundSMS: Int = jResp.int(of: "PhoneNumber.Capabilities.InboundSMS").intValue
var OutboundCall: Int = jResp.int(of: "PhoneNumber.Capabilities.OutboundCall").intValue
var OutboundMMS: Int = jResp.int(of: "PhoneNumber.Capabilities.OutboundMMS").intValue
var OutboundSMS: Int = jResp.int(of: "PhoneNumber.Capabilities.OutboundSMS").intValue
var Country: String? = jResp.string(of: "PhoneNumber.Country")
var CreatedTimestamp: Int = jResp.int(of: "PhoneNumber.CreatedTimestamp").intValue
var DeletionTimestamp: Int = jResp.int(of: "PhoneNumber.DeletionTimestamp").intValue
var E164PhoneNumber: String? = jResp.string(of: "PhoneNumber.E164PhoneNumber")
var PhoneNumberId: String? = jResp.string(of: "PhoneNumber.PhoneNumberId")
var ProductType: String? = jResp.string(of: "PhoneNumber.ProductType")
var Status: String? = jResp.string(of: "PhoneNumber.Status")
var v_Type: String? = jResp.string(of: "PhoneNumber.Type")
var UpdatedTimestamp: Int = jResp.int(of: "PhoneNumber.UpdatedTimestamp").intValue
var i: Int = 0
var count_i: Int = jResp.size(ofArray: "PhoneNumber.Associations").intValue
while i < count_i {
jResp.i = i
AssociatedTimestamp = jResp.int(of: "PhoneNumber.Associations[i].AssociatedTimestamp").intValue
Name = jResp.string(of: "PhoneNumber.Associations[i].Name")
Value = jResp.string(of: "PhoneNumber.Associations[i].Value")
i = i + 1
}
// A sample JSON response body parsed by the above code:
// {
// "PhoneNumber": {
// "Associations": [
// {
// "AssociatedTimestamp": number,
// "Name": "string",
// "Value": "string"
// }
// ],
// "CallingName": "string",
// "CallingNameStatus": "string",
// "Capabilities": {
// "InboundCall": boolean,
// "InboundMMS": boolean,
// "InboundSMS": boolean,
// "OutboundCall": boolean,
// "OutboundMMS": boolean,
// "OutboundSMS": boolean
// },
// "Country": "string",
// "CreatedTimestamp": number,
// "DeletionTimestamp": number,
// "E164PhoneNumber": "string",
// "PhoneNumberId": "string",
// "ProductType": "string",
// "Status": "string",
// "Type": "string",
// "UpdatedTimestamp": number
// }
// }
}