Sample code for 30+ languages & platforms
Ruby

VoiceBase -- Compound Expression Search

See more VoiceBase Examples

Demonstrates how to do a VoiceBase compound expression search. See VoiceBase Search for more details about Search.

Chilkat Ruby Downloads

Ruby
require 'chilkat'

success = 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:
accessToken = "VOICEBASE_TOKEN"

http = Chilkat::CkHttp.new()

req = Chilkat::CkHttpRequest.new()
req.put_HttpVerb("GET")
req.put_Path("/v2-beta/media")

# Add the access (bearer) token to the request, which is a header
# having the following format:
# Authorization: Bearer <userAccessToken>
sbAuth = Chilkat::CkStringBuilder.new()
sbAuth.Append("Bearer ")
sbAuth.Append(accessToken)
req.AddHeader("Authorization",sbAuth.getAsString())

# Search for media containing the terms any of the terms "test", "number", or "three"
req.AddParam("query","\"test\" OR \"number\" OR \"three\"")

resp = Chilkat::CkHttpResponse.new()
success = http.HttpSReq("apis.voicebase.com",443,true,req,resp)
if (success == false)
    print http.lastErrorText() + "\n";
    exit
end

# Examine the response status code and body.
print "Response status code = " + resp.get_StatusCode().to_s() + "\n";

# The response should be JSON, even if an error.
json = Chilkat::CkJsonObject.new()
json.Load(resp.bodyStr())
json.put_EmitCompact(false)

# A successful response will have a status code = 200
if (resp.get_StatusCode() != 200)
    print "Failed." + "\n";
else
    print "mediaId: " + json.stringOf("mediaId") + "\n";
    print "href: " + json.stringOf("_links.self.href") + "\n";
    print "status: " + json.stringOf("status") + "\n";
    print "Success." + "\n";
end

# See the sample JSON response below..

# Iterate over the JSON like this:
dt = Chilkat::CkDateTime.new()
dtObj = Chilkat::CkDtObj.new()

mediaCount = json.SizeOfArray("media")
i = 0
while i < mediaCount
    json.put_I(i)

    print "-- " + i.to_s() + " --" + "\n";
    print "  mediaId: " + json.stringOf("media[i].mediaId") + "\n";
    print "  status: " + json.stringOf("media[i].status") + "\n";
    print "  contentType: " + json.stringOf("media[i].metadata.contentType") + "\n";
    print "  milliseconds: " + json.stringOf("media[i].metadata.length.milliseconds") + "\n";
    print "  descriptive: " + json.stringOf("media[i].metadata.length.descriptive") + "\n";
    dateCreated = json.stringOf("media[i].dateCreated")
    dt.SetFromTimestamp(dateCreated)

    localTime = true
    dt.ToDtObj(localTime,dtObj)

    print "  " + dtObj.get_Month().to_s() + "/" + dtObj.get_Day().to_s() + "  " + dtObj.get_Hour().to_s() + ":" + 
        dtObj.get_Minute().to_s() + "\n";

    i = i + 1
end
print "Finished." + "\n";

# A sample JSON response:

# { 
#   "_links": { 
#     "self": { 
#       "href": "/v2-beta/media"
#     }
#   },
#   "media": [
#     { 
#       "mediaId": "26063536-FFFF-4020-93ba-0878112d834b",
#       "status": "finished",
#       "metadata": { 
#         "contentType": "audio/x-wav",
#         "length": { 
#           "milliseconds": 85141,
#           "descriptive": "85.0 sec"
#         }
#       },
#       "dateCreated": "2017-01-19T16:49:32.000Z"
#     },
#     { 
#       "mediaId": "8163fbbc-FFFF-4794-aa95-045420bb321d",
#       "status": "finished",
#       "metadata": { 
#         "contentType": "audio/x-wav",
#         "length": { 
#           "milliseconds": 65342,
#           "descriptive": "65.0 sec"
#         }
#       },
#       "dateCreated": "2017-01-19T20:08:49.000Z"
#     },
# ...
# ...
#     { 
#       "mediaId": "b01e27be-FFFF-4b62-8802-6dc66a75c4d3",
#       "status": "finished",
#       "metadata": { 
#         "contentType": "audio/x-wav",
#         "length": { 
#           "milliseconds": 11581,
#           "descriptive": "11.0 sec"
#         }
#       },
#       "dateCreated": "2017-02-06T20:55:43.000Z"
#     }
#   ]
# }