Sample code for 30+ languages & platforms
AutoIt

VoiceBase -- Upload a Media File with a JSON Configuration

See more VoiceBase Examples

This example uploads a media file and also provides a configuration file.

Chilkat AutoIt Downloads

AutoIt
Local $bSuccess = False

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

; Insert your Bearer token here:
Local $sAccessToken = "VOICEBASE_TOKEN"

$oHttp = ObjCreate("Chilkat.Http")

$oReq = ObjCreate("Chilkat.HttpRequest")
$oReq.HttpVerb = "POST"
$oReq.Path = "/v2-beta/media"
$oReq.ContentType = "multipart/form-data"

; Add the access (bearer) token to the request, which is a header
; having the following format:
; Authorization: Bearer <userAccessToken>
$oSbAuth = ObjCreate("Chilkat.StringBuilder")
$oSbAuth.Append("Bearer ")
$oSbAuth.Append($sAccessToken)
$oReq.AddHeader "Authorization",$oSbAuth.GetAsString()

$bSuccess = $oReq.AddFileForUpload2("media","qa_data/wav/msg_123_abc.wav","audio/x-wav")
If ($bSuccess = False) Then
    ConsoleWrite($oReq.LastErrorText & @CRLF)
    Exit
EndIf

; This is the JSON of the configuration to be added as a parameter to the upload:
; (Obviously, if you want a callback, you would use a URL that goes to your own web server..)

; 	{ 
; 	   "configuration":{ 
; 	      "publish":{ 
; 	         "callbacks":[
; 	            { 
; 	               "url":"https://www.chilkatsoft.com/dss/update_vm_transcription.asp",
; 	               "method":"POST",
; 	               "include":[
; 	                  "transcripts",
; 	                  "keywords",
; 	                  "topics",
; 	                  "metadata"
; 	               ]
; 	            }
; 	         ]
; 	      },
; 	      "keywords":{ 
; 	         "groups":[]
; 	      }
; 	   }
; 	}

; This code produces the above JSON.
$oJson = ObjCreate("Chilkat.JsonObject")
$oJson.UpdateString("configuration.publish.callbacks[0].url","https://www.chilkatsoft.com/dss/update_vm_transcription.asp")
$oJson.UpdateString("configuration.publish.callbacks[0].method","POST")
$oJson.UpdateString("configuration.publish.callbacks[0].include[0]","transcripts")
$oJson.UpdateString("configuration.publish.callbacks[0].include[1]","keywords")
$oJson.UpdateString("configuration.publish.callbacks[0].include[2]","topics")
$oJson.UpdateString("configuration.publish.callbacks[0].include[3]","metadata")

$oJConfig = ObjCreate("Chilkat.JsonObject")
$oJson.ObjectOf2("configuration",$oJConfig)

$oJKeywords = ObjCreate("Chilkat.JsonObject")
$oJConfig.AppendObject2("keywords",$oJKeywords)

$oJGroups = ObjCreate("Chilkat.JsonArray")
$oJKeywords.AppendArray2("groups",$oJGroups)

; Add the configuration JSON to the upload.
$oReq.AddParam "configuration",$oJson.Emit()

; Do the upload..
$oResp = ObjCreate("Chilkat.HttpResponse")
$bSuccess = $oHttp.HttpSReq("apis.voicebase.com",443,True,$oReq,$oResp)
If ($bSuccess = False) Then
    ConsoleWrite($oHttp.LastErrorText & @CRLF)
    Exit
EndIf

; Examine the response status code and body.
ConsoleWrite("Response status code = " & $oResp.StatusCode & @CRLF)

; The response should be JSON, even if an error.
$oJson.Load($oResp.BodyStr)
$oJson.EmitCompact = False

ConsoleWrite($oJson.Emit() & @CRLF)

; A successful response will have a status code = 200
If ($oResp.StatusCode <> 200) Then
    ConsoleWrite("Failed." & @CRLF)
Else
    ConsoleWrite("mediaId: " & $oJson.StringOf("mediaId") & @CRLF)
    ConsoleWrite("href: " & $oJson.StringOf("_links.self.href") & @CRLF)
    ConsoleWrite("status: " & $oJson.StringOf("status") & @CRLF)
    ConsoleWrite("Success." & @CRLF)
EndIf

; Here is an example of a successful response:

; 	{ 
; 	  "_links": { 
; 	    "self": { 
; 	      "href": "/v2-beta/media/856a1e85-c847-4c3c-b7a4-6cf15cd51db4"
; 	    }
; 	  },
; 	  "mediaId": "856a1e85-c847-4c3c-b7a4-6cf15cd51db4",
; 	  "status": "accepted",
; 	  "metadata": {}
;