Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(SQL Server) Twilio Send SMS (using Chilkat HTTP)Send an outgoing SMS message. For more information, see https://www.twilio.com/docs/sms/api/message-resource#create-a-message-resource
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int DECLARE @iTmp0 int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- This example assumes the Chilkat API to have been previously unlocked. -- See Global Unlock Sample for sample code. DECLARE @http int -- Use "Chilkat_9_5_0.Http" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Http', @http OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END DECLARE @success int -- Implements the following CURL command: -- (See information about using test credentials and phone numbers: https://www.twilio.com/docs/iam/test-credentials) -- curl -X POST https://api.twilio.com/2010-04-01/Accounts/TWILIO_ACCOUNT_SID/Messages.json \ -- --data-urlencode "From=+15005550006" \ -- --data-urlencode "Body=body" \ -- --data-urlencode "To=+15005551212" \ -- -u TWILIO_ACCOUNT_SID:TWILIO_AUTH_TOKEN -- Use the following online tool to generate HTTP code from a CURL command -- Convert a cURL Command to HTTP Source Code EXEC sp_OASetProperty @http, 'Login', 'TWILIO_ACCOUNT_SID' EXEC sp_OASetProperty @http, 'Password', 'TWILIO_AUTH_TOKEN' DECLARE @req int -- Use "Chilkat_9_5_0.HttpRequest" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.HttpRequest', @req OUT EXEC sp_OASetProperty @req, 'HttpVerb', 'POST' EXEC sp_OASetProperty @req, 'Path', '/2010-04-01/Accounts/TWILIO_ACCOUNT_SID/Messages.json' EXEC sp_OASetProperty @req, 'ContentType', 'application/x-www-form-urlencoded' EXEC sp_OAMethod @req, 'AddParam', NULL, 'From', '+15005550006' EXEC sp_OAMethod @req, 'AddParam', NULL, 'Body', 'body' EXEC sp_OAMethod @req, 'AddParam', NULL, 'To', '+15005551212' DECLARE @resp int EXEC sp_OAMethod @http, 'PostUrlEncoded', @resp OUT, 'https://api.twilio.com/2010-04-01/Accounts/TWILIO_ACCOUNT_SID/Messages.json', @req EXEC sp_OAGetProperty @http, 'LastMethodSuccess', @iTmp0 OUT IF @iTmp0 = 0 BEGIN EXEC sp_OAGetProperty @http, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @http EXEC @hr = sp_OADestroy @req RETURN END DECLARE @sbResponseBody int -- Use "Chilkat_9_5_0.StringBuilder" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbResponseBody OUT EXEC sp_OAMethod @resp, 'GetBodySb', @success OUT, @sbResponseBody DECLARE @jResp int -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @jResp OUT EXEC sp_OAMethod @jResp, 'LoadSb', @success OUT, @sbResponseBody EXEC sp_OASetProperty @jResp, 'EmitCompact', 0 PRINT 'Response Body:' EXEC sp_OAMethod @jResp, 'Emit', @sTmp0 OUT PRINT @sTmp0 -- A 201 status code indicates success. DECLARE @respStatusCode int EXEC sp_OAGetProperty @resp, 'StatusCode', @respStatusCode OUT PRINT 'Response Status Code = ' + @respStatusCode IF @respStatusCode >= 400 BEGIN PRINT 'Response Header:' EXEC sp_OAGetProperty @resp, 'Header', @sTmp0 OUT PRINT @sTmp0 PRINT 'Failed.' EXEC @hr = sp_OADestroy @resp EXEC @hr = sp_OADestroy @http EXEC @hr = sp_OADestroy @req EXEC @hr = sp_OADestroy @sbResponseBody EXEC @hr = sp_OADestroy @jResp RETURN END EXEC @hr = sp_OADestroy @resp -- Sample JSON response: -- (Sample code for parsing the JSON response is shown below) -- { -- "account_sid": "ACXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX", -- "api_version": "2010-04-01", -- "body": "body", -- "date_created": "Thu, 30 Jul 2015 20:12:31 +0000", -- "date_sent": "Thu, 30 Jul 2015 20:12:33 +0000", -- "date_updated": "Thu, 30 Jul 2015 20:12:33 +0000", -- "direction": "outbound-api", -- "error_code": null, -- "error_message": null, -- "from": "+15017122661", -- "messaging_service_sid": "MGXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX", -- "num_media": "0", -- "num_segments": "1", -- "price": null, -- "price_unit": null, -- "sid": "MMXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX", -- "status": "sent", -- "subresource_uris": { -- "media": "/2010-04-01/Accounts/ACXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX/Messages/SMXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX/Media.json" -- }, -- "to": "+15558675310", -- "uri": "/2010-04-01/Accounts/ACXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX/Messages/SMXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX.json" -- } -- Sample code for parsing the JSON response... -- Use the following online tool to generate parsing code from sample JSON: -- Generate Parsing Code from JSON DECLARE @account_sid nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @account_sid OUT, 'account_sid' DECLARE @api_version nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @api_version OUT, 'api_version' DECLARE @body nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @body OUT, 'body' DECLARE @date_created nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @date_created OUT, 'date_created' DECLARE @date_sent nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @date_sent OUT, 'date_sent' DECLARE @date_updated nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @date_updated OUT, 'date_updated' DECLARE @direction nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @direction OUT, 'direction' DECLARE @error_code nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @error_code OUT, 'error_code' DECLARE @error_message nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @error_message OUT, 'error_message' DECLARE @from nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @from OUT, 'from' DECLARE @messaging_service_sid nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @messaging_service_sid OUT, 'messaging_service_sid' DECLARE @num_media nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @num_media OUT, 'num_media' DECLARE @num_segments nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @num_segments OUT, 'num_segments' DECLARE @price nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @price OUT, 'price' DECLARE @price_unit nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @price_unit OUT, 'price_unit' DECLARE @sid nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @sid OUT, 'sid' DECLARE @status nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @status OUT, 'status' DECLARE @subresource_urisMedia nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @subresource_urisMedia OUT, 'subresource_uris.media' DECLARE @v_to nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @v_to OUT, 'to' DECLARE @uri nvarchar(4000) EXEC sp_OAMethod @jResp, 'StringOf', @uri OUT, 'uri' EXEC @hr = sp_OADestroy @http EXEC @hr = sp_OADestroy @req EXEC @hr = sp_OADestroy @sbResponseBody EXEC @hr = sp_OADestroy @jResp END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.