Sample code for 30+ languages & platforms
PowerBuilder

Find a Label ID by Name

See more GMail REST API Examples

Lookup the ID of a GMail label by the label name.

Chilkat PowerBuilder Downloads

PowerBuilder
integer li_rc
integer li_Success
oleobject loo_Http
string ls_UserId
string ls_Url
oleobject loo_Sb
oleobject loo_Json
oleobject loo_JRecord

li_Success = 0

// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

loo_Http = create oleobject
li_rc = loo_Http.ConnectToNewObject("Chilkat.Http")
if li_rc < 0 then
    destroy loo_Http
    MessageBox("Error","Connecting to COM object failed")
    return
end if
loo_Http.AuthToken = "GMAIL-ACCESS-TOKEN"

ls_UserId = "me"
loo_Http.SetUrlVar("userId",ls_UserId)

ls_Url = "https://www.googleapis.com/gmail/v1/users/{$userId}/labels"

// Get the list of GMail labels as JSON.
loo_Sb = create oleobject
li_rc = loo_Sb.ConnectToNewObject("Chilkat.StringBuilder")

li_Success = loo_Http.QuickGetSb(ls_Url,loo_Sb)
if li_Success <> 1 then
    Write-Debug loo_Http.LastErrorText
    destroy loo_Http
    destroy loo_Sb
    return
end if

loo_Json = create oleobject
li_rc = loo_Json.ConnectToNewObject("Chilkat.JsonObject")

loo_Json.LoadSb(loo_Sb)
loo_Json.EmitCompact = 0
Write-Debug loo_Json.Emit()

if loo_Http.LastStatus <> 200 then
    Write-Debug "Failed."
    destroy loo_Http
    destroy loo_Sb
    destroy loo_Json
    return
end if

// The JSON returned looks like this:
// {
//   "labels": [
//     {
//       "id": "Label_5",
//       "name": "QA",
//       "messageListVisibility": "show",
//       "labelListVisibility": "labelShow",
//       "type": "user"
//     },
//     {
//       "id": "Label_21",
//       "name": "[Gmail]/testFolder",
//       "type": "user"
//     },
//     {
//       "id": "CATEGORY_PERSONAL",
//       "name": "CATEGORY_PERSONAL",
//       "type": "system"
//     },
// 	...

// The name of the label is generally known because it's what we visually see.
// The id is what we need to get.  Assuming the name is unique,
// find the JSON record having name=<desired name>
// For example...
loo_JRecord = loo_Json.FindRecord("labels","name","QA",0)
if loo_Json.LastMethodSuccess = 1 then
    Write-Debug "The id of QA is: " + loo_JRecord.StringOf("id")
    destroy loo_JRecord
end if

loo_JRecord = loo_Json.FindRecord("labels","name","[Gmail]/testFolder",0)
if loo_Json.LastMethodSuccess = 1 then
    Write-Debug "The id of [Gmail]/testFolder is: " + loo_JRecord.StringOf("id")
    destroy loo_JRecord
end if

loo_JRecord = loo_Json.FindRecord("labels","name","questions",0)
if loo_Json.LastMethodSuccess = 1 then
    Write-Debug "The id of questions is: " + loo_JRecord.StringOf("id")
    destroy loo_JRecord
end if

// Output:

// The id of QA is: Label_5
// The id of [Gmail]/testFolder is: Label_21
// The id of questions is: Label_43


destroy loo_Http
destroy loo_Sb
destroy loo_Json