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