Sample code for 30+ languages & platforms
PowerShell

Twilio: Send SMS using Basic Authentication

See more REST Examples

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

Chilkat PowerShell Downloads

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

$success = $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.

$rest = New-Object Chilkat.Rest

# Use Basic Authentication.
# Your Twilio Account SID is the username.
# Your Twilio Auth Token is the password.
$success = $rest.SetAuthBasic("TWILIO_ACCOUNT_SID","TWILIO_AUTH_TOKEN")

# Make the initial connection (without sending a request yet) to Twilio.
$bTls = $true
$port = 443
$bAutoReconnect = $true
$success = $rest.Connect("api.twilio.com",$port,$bTls,$bAutoReconnect)
if ($success -ne $true) {
    $($rest.LastErrorText)
    exit
}

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

# Send the SMS text message.
# Your Twilio Account SID is part of the URI path:
$responseJson = $rest.FullRequestFormUrlEncoded("POST","/2010-04-01/Accounts/TWILIO_ACCOUNT_SID/Messages.json")
if ($rest.LastMethodSuccess -ne $true) {
    $($rest.LastErrorText)
    exit
}

# When successful, the response status code will equal 201.
if ($rest.ResponseStatusCode -ne 201) {
    # Examine the request/response to see what happened.
    $("response status code = " + $rest.ResponseStatusCode)
    $("response status text = " + $rest.ResponseStatusText)
    $("response header: " + $rest.ResponseHeader)
    $("response body (if any): " + $responseJson)
    $("---")
    $("LastRequestStartLine: " + $rest.LastRequestStartLine)
    $("LastRequestHeader: " + $rest.LastRequestHeader)
    exit
}

# 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..

$json = New-Object Chilkat.JsonObject
$json.EmitCompact = $false
$success = $json.Load($responseJson)

# First show the entire JSON.
$($json.Emit())

# Now get some individual pieces of information:
$("sid: " + $json.StringOf("sid"))
$("body: " + $json.StringOf("body"))
$("media: " + $json.StringOf("subresource_uris.media"))

$("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"
#   }
# }