Sample code for 30+ languages & platforms
Swift

Twilio: Send SMS using Basic Authentication

See more REST Examples

Demonstrates how to use Twilio to send an SMS message using Basic authentication.

Chilkat Swift Downloads

Swift

func chilkatTest() {
    var success: Bool = false

    // Demonstrates how to use Basic Authentication in a REST API call for Twilio.
    // Sends an SMS text message..

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

    let rest = CkoRest()!

    // Use Basic Authentication.
    // Your Twilio Account SID is the username.
    // Your Twilio Auth Token is the password.
    success = rest.setAuthBasic(username: "TWILIO_ACCOUNT_SID", password: "TWILIO_AUTH_TOKEN")

    // Make the initial connection (without sending a request yet) to Twilio.
    var bTls: Bool = true
    var port: Int = 443
    var bAutoReconnect: Bool = true
    success = rest.connect(hostname: "api.twilio.com", port: port, tls: bTls, autoReconnect: bAutoReconnect)
    if success != true {
        print("\(rest.lastErrorText!)")
        return
    }

    // Provide the information for the SMS text message:
    success = rest.addQueryParam(name: "To", value: "+16518675309")
    success = rest.addQueryParam(name: "From", value: "+15005550006")
    success = rest.addQueryParam(name: "Body", value: "Hey Jenny! Good luck on the bar exam!")
    success = rest.addQueryParam(name: "MediaUrl", value: "http://farm2.static.flickr.com/1075/1404618563_3ed9a44a3a.jpg")

    // Send the SMS text message.
    // Your Twilio Account SID is part of the URI path:
    var responseJson: String? = rest.fullRequestFormUrlEncoded(httpVerb: "POST", uriPath: "/2010-04-01/Accounts/TWILIO_ACCOUNT_SID/Messages.json")
    if rest.lastMethodSuccess != true {
        print("\(rest.lastErrorText!)")
        return
    }

    // When successful, the response status code will equal 201.
    if rest.responseStatusCode.intValue != 201 {
        // Examine the request/response to see what happened.
        print("response status code = \(rest.responseStatusCode.intValue)")
        print("response status text = \(rest.responseStatusText!)")
        print("response header: \(rest.responseHeader!)")
        print("response body (if any): \(responseJson!)")
        print("---")
        print("LastRequestStartLine: \(rest.lastRequestStartLine!)")
        print("LastRequestHeader: \(rest.lastRequestHeader!)")
        return
    }

    // The response is JSON.  We'll show how to get a few bits of information from it.
    // A full sample JSON response is shown below..

    let json = CkoJsonObject()!
    json.emitCompact = false
    success = json.load(json: responseJson)

    // First show the entire JSON.
    print("\(json.emit()!)")

    // Now get some individual pieces of information:
    print("sid: \(json.string(of: "sid")!)")
    print("body: \(json.string(of: "body")!)")
    print("media: \(json.string(of: "subresource_uris.media")!)")

    print("Success.")

    // Sample JSON response:

    // {
    //   "sid": "MM97ecfd43e9f24e99b0c2c6ee016949e3",
    //   "date_created": null,
    //   "date_updated": null,
    //   "date_sent": null,
    //   "account_sid": "112e1111e0151133d11112101111d1111",
    //   "to": "+16518675309",
    //   "from": "+15005550006",
    //   "messaging_service_sid": null,
    //   "body": "Sent from your Twilio trial account - Hey Jenny! Good luck on the bar exam!",
    //   "status": "queued",
    //   "num_segments": "1",
    //   "num_media": "0",
    //   "direction": "outbound-api",
    //   "api_version": "2010-04-01",
    //   "price": null,
    //   "price_unit": "USD",
    //   "error_code": null,
    //   "error_message": null,
    //   "uri": "/2010-04-01/Accounts/AC2e9b6bc0f51133df24926f07341d3824/Messages/MM97ecfd43e9f24e99b0c2c6ee016949e3.json",
    //   "subresource_uris": {
    //     "media": "/2010-04-01/Accounts/AC2e9b6bc0f51133df24926f07341d3824/Messages/MM97ecfd43e9f24e99b0c2c6ee016949e3/Media.json"
    //   }
    // }

}