Visual FoxPro
Visual FoxPro
Create Plan
See more Microsoft Tasks and Plans Examples
Demonstrates how to create a new plannerPlan.See https://docs.microsoft.com/en-us/graph/api/planner-post-plans?view=graph-rest-1.0 for more information.
Chilkat Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loHttp
LOCAL loJsonToken
LOCAL loJson
LOCAL loResp
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")
* Create a JSON body for the HTTP POST
* Use this online tool to generate the code from sample JSON:
* Generate Code to Create JSON
* {
* "owner": "ebf3b108-5234-4e22-b93d-656d7dae5874",
* "title": "title-value"
* }
loJson = CreateObject('Chilkat.JsonObject')
loJson.UpdateString("owner","ebf3b108-5234-4e22-b93d-656d7dae5874")
loJson.UpdateString("title","title-value")
* POST the JSON to https://graph.microsoft.com/v1.0/planner/plans
loResp = CreateObject('Chilkat.HttpResponse')
lnSuccess = loHttp.HttpJson("POST","https://graph.microsoft.com/v1.0/planner/plans",loJson,"application/json",loResp)
IF (lnSuccess = 0) THEN
? loHttp.LastErrorText
RELEASE loHttp
RELEASE loJsonToken
RELEASE loJson
RELEASE loResp
CANCEL
ENDIF
loJson.Load(loResp.BodyStr)
loJson.EmitCompact = 0
IF (loResp.StatusCode <> 200) THEN
? loJson.Emit()
? "Failed, response status code = " + STR(loResp.StatusCode)
RELEASE loHttp
RELEASE loJsonToken
RELEASE loJson
RELEASE loResp
CANCEL
ENDIF
? loJson.Emit()
* A sample response:
* (See code for parsing this response below..)
* {
* "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
lcCreatedByApplicationId = loJson.StringOf("createdBy.application.id")
lcCreatedByUserId = loJson.StringOf("createdBy.user.id")
lcCreatedDateTime = loJson.StringOf("createdDateTime")
lcOwner = loJson.StringOf("owner")
lcTitle = loJson.StringOf("title")
lcId = loJson.StringOf("id")
? "Success."
RELEASE loHttp
RELEASE loJsonToken
RELEASE loJson
RELEASE loResp