Sample code for 30+ languages & platforms
PowerShell

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 PowerShell Downloads

PowerShell
Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll"

$success = $false

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

$http = New-Object 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.

$jsonToken = New-Object Chilkat.JsonObject
$success = $jsonToken.LoadFile("qa_data/tokens/msGraphGroup.json")
if ($success -eq $false) {
    $($jsonToken.LastErrorText)
    exit
}

$http.AuthToken = $jsonToken.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"
# }

$json = New-Object Chilkat.JsonObject
$json.UpdateString("owner","ebf3b108-5234-4e22-b93d-656d7dae5874")
$json.UpdateString("title","title-value")

# POST the JSON to https://graph.microsoft.com/v1.0/planner/plans
$resp = New-Object Chilkat.HttpResponse
$success = $http.HttpJson("POST","https://graph.microsoft.com/v1.0/planner/plans",$json,"application/json",$resp)
if ($success -eq $false) {
    $($http.LastErrorText)
    exit
}

$json.Load($resp.BodyStr)
$json.EmitCompact = $false

if ($resp.StatusCode -ne 200) {
    $($json.Emit())
    $("Failed, response status code = " + $resp.StatusCode)
    exit
}

$($json.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

$createdByApplicationId = $json.StringOf("createdBy.application.id")
$createdByUserId = $json.StringOf("createdBy.user.id")
$createdDateTime = $json.StringOf("createdDateTime")
$owner = $json.StringOf("owner")
$title = $json.StringOf("title")
$id = $json.StringOf("id")

$("Success.")