Sample code for 30+ languages & platforms
Visual FoxPro

List Plans for a Group

See more Microsoft Tasks and Plans Examples

Demonstrates how to retrieve a list of plannerPlan objects owned by a group object.

See https://docs.microsoft.com/en-us/graph/api/plannergroup-list-plans?view=graph-rest-1.0 for more information.

Chilkat Visual FoxPro Downloads

Visual FoxPro
LOCAL lnSuccess
LOCAL loHttp
LOCAL loJsonToken
LOCAL lcStrResponse
LOCAL loJson
LOCAL i
LOCAL lnCount_i
LOCAL lcCreatedByApplicationId
LOCAL lcCreatedByUserId
LOCAL lcCreatedDateTime
LOCAL lcOwner
LOCAL lcTitle
LOCAL lcId

lnSuccess = 0

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

loHttp = CreateObject('Chilkat.Http')

* The Microsoft Planner REST API requires an OAuth2 token with the Group.ReadWrite.All scope.
* Use your previously obtained access token as shown here:
*    Get Microsoft Graph OAuth2 Access Token with Group.ReadWrite.All scope.

loJsonToken = CreateObject('Chilkat.JsonObject')
lnSuccess = loJsonToken.LoadFile("qa_data/tokens/msGraphGroup.json")
IF (lnSuccess = 0) THEN
    ? loJsonToken.LastErrorText
    RELEASE loHttp
    RELEASE loJsonToken
    CANCEL
ENDIF

loHttp.AuthToken = loJsonToken.StringOf("access_token")

* Send a GET request to https://graph.microsoft.com/v1.0/groups/{group-id}/planner/plans
lcStrResponse = loHttp.QuickGetStr("https://graph.microsoft.com/v1.0/groups/{group-id}/planner/plans")
IF (loHttp.LastMethodSuccess = 0) THEN
    ? loHttp.LastErrorText
    RELEASE loHttp
    RELEASE loJsonToken
    CANCEL
ENDIF

loJson = CreateObject('Chilkat.JsonObject')
loJson.Load(lcStrResponse)
loJson.EmitCompact = 0

IF (loHttp.LastStatus <> 200) THEN
    ? loJson.Emit()
    ? "Failed, response status code = " + STR(loHttp.LastStatus)
    RELEASE loHttp
    RELEASE loJsonToken
    RELEASE loJson
    CANCEL
ENDIF

? loJson.Emit()

* Sample output:
* (See parsing code below..)

* {
*   "value": [
*     {
*       "createdBy": {
*         "application": {
*           "id": "95e27074-6c4a-447a-aa24-9d718a0b86fa"
*         },
*         "user": {
*           "id": "ebf3b108-5234-4e22-b93d-656d7dae5874"
*         }
*       },
*       "createdDateTime": "2015-03-30T18:36:49.2407981Z",
*       "owner": "ebf3b108-5234-4e22-b93d-656d7dae5874",
*       "title": "title-value",
*       "id": "xqQg5FS2LkCp935s-FIFm2QAFkHM"
*     }
*   ]
* }

* Use this online tool to generate parsing code from sample JSON: 
* Generate Parsing Code from JSON

i = 0
lnCount_i = loJson.SizeOfArray("value")
DO WHILE i < lnCount_i
    loJson.I = i
    lcCreatedByApplicationId = loJson.StringOf("value[i].createdBy.application.id")
    lcCreatedByUserId = loJson.StringOf("value[i].createdBy.user.id")
    lcCreatedDateTime = loJson.StringOf("value[i].createdDateTime")
    lcOwner = loJson.StringOf("value[i].owner")
    lcTitle = loJson.StringOf("value[i].title")
    lcId = loJson.StringOf("value[i].id")
    i = i + 1
ENDDO

? "Success."

RELEASE loHttp
RELEASE loJsonToken
RELEASE loJson