Sample code for 30+ languages & platforms
Visual FoxPro

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 Visual FoxPro Downloads

Visual FoxPro
LOCAL lnSuccess
LOCAL lcAccessToken
LOCAL loHttp
LOCAL loReq
LOCAL loSbAuth
LOCAL loJson
LOCAL loJConfig
LOCAL loJKeywords
LOCAL loJGroups
LOCAL loResp

lnSuccess = 0

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

* Insert your Bearer token here:
lcAccessToken = "VOICEBASE_TOKEN"

loHttp = CreateObject('Chilkat.Http')

loReq = CreateObject('Chilkat.HttpRequest')
loReq.HttpVerb = "POST"
loReq.Path = "/v2-beta/media"
loReq.ContentType = "multipart/form-data"

* Add the access (bearer) token to the request, which is a header
* having the following format:
* Authorization: Bearer <userAccessToken>
loSbAuth = CreateObject('Chilkat.StringBuilder')
loSbAuth.Append("Bearer ")
loSbAuth.Append(lcAccessToken)
loReq.AddHeader("Authorization",loSbAuth.GetAsString())

lnSuccess = loReq.AddFileForUpload2("media","qa_data/wav/msg_123_abc.wav","audio/x-wav")
IF (lnSuccess = 0) THEN
    ? loReq.LastErrorText
    RELEASE loHttp
    RELEASE loReq
    RELEASE loSbAuth
    CANCEL
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.
loJson = CreateObject('Chilkat.JsonObject')
loJson.UpdateString("configuration.publish.callbacks[0].url","https://www.chilkatsoft.com/dss/update_vm_transcription.asp")
loJson.UpdateString("configuration.publish.callbacks[0].method","POST")
loJson.UpdateString("configuration.publish.callbacks[0].include[0]","transcripts")
loJson.UpdateString("configuration.publish.callbacks[0].include[1]","keywords")
loJson.UpdateString("configuration.publish.callbacks[0].include[2]","topics")
loJson.UpdateString("configuration.publish.callbacks[0].include[3]","metadata")

loJConfig = CreateObject('Chilkat.JsonObject')
loJson.ObjectOf2("configuration",loJConfig)

loJKeywords = CreateObject('Chilkat.JsonObject')
loJConfig.AppendObject2("keywords",loJKeywords)

loJGroups = CreateObject('Chilkat.JsonArray')
loJKeywords.AppendArray2("groups",loJGroups)

* Add the configuration JSON to the upload.
loReq.AddParam("configuration",loJson.Emit())

* Do the upload..
loResp = CreateObject('Chilkat.HttpResponse')
lnSuccess = loHttp.HttpSReq("apis.voicebase.com",443,1,loReq,loResp)
IF (lnSuccess = 0) THEN
    ? loHttp.LastErrorText
    RELEASE loHttp
    RELEASE loReq
    RELEASE loSbAuth
    RELEASE loJson
    RELEASE loJConfig
    RELEASE loJKeywords
    RELEASE loJGroups
    RELEASE loResp
    CANCEL
ENDIF

* Examine the response status code and body.
? "Response status code = " + STR(loResp.StatusCode)

* The response should be JSON, even if an error.
loJson.Load(loResp.BodyStr)
loJson.EmitCompact = 0

? loJson.Emit()

* A successful response will have a status code = 200
IF (loResp.StatusCode <> 200) THEN
    ? "Failed."
ELSE
    ? "mediaId: " + loJson.StringOf("mediaId")
    ? "href: " + loJson.StringOf("_links.self.href")
    ? "status: " + loJson.StringOf("status")
    ? "Success."
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": {}
* 	

RELEASE loHttp
RELEASE loReq
RELEASE loSbAuth
RELEASE loJson
RELEASE loJConfig
RELEASE loJKeywords
RELEASE loJGroups
RELEASE loResp