Sample code for 30+ languages & platforms
Tcl

Create Task

See more Microsoft Tasks and Plans Examples

Demonstrates how to create a new plannerTask.

See https://docs.microsoft.com/en-us/graph/api/planner-post-tasks?view=graph-rest-1.0 for more information.

Chilkat Tcl Downloads

Tcl

load ./chilkat.dll

set success 0

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

set http [new_CkHttp]

# 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.

set jsonToken [new_CkJsonObject]

set success [CkJsonObject_LoadFile $jsonToken "qa_data/tokens/msGraphGroup.json"]
if {$success == 0} then {
    puts [CkJsonObject_lastErrorText $jsonToken]
    delete_CkHttp $http
    delete_CkJsonObject $jsonToken
    exit
}

CkHttp_put_AuthToken $http [CkJsonObject_stringOf $jsonToken "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

# {
#   "planId": "xqQg5FS2LkCp935s-FIFm2QAFkHM",
#   "bucketId": "hsOf2dhOJkqyYYZEtdzDe2QAIUCR",
#   "title": "Update client list",
#   "assignments": {
#     "fbab97d0-4932-4511-b675-204639209557": {
#       "@odata.type": "#microsoft.graph.plannerAssignment",
#       "orderHint": " !"
#     }
#   },
# }

set json [new_CkJsonObject]

CkJsonObject_UpdateString $json "planId" "xqQg5FS2LkCp935s-FIFm2QAFkHM"
CkJsonObject_UpdateString $json "bucketId" "hsOf2dhOJkqyYYZEtdzDe2QAIUCR"
CkJsonObject_UpdateString $json "title" "Update client list"
CkJsonObject_UpdateString $json "assignments.fbab97d0-4932-4511-b675-204639209557.\"@odata.type\"" "#microsoft.graph.plannerAssignment"
CkJsonObject_UpdateString $json "assignments.fbab97d0-4932-4511-b675-204639209557.orderHint" " !"

# POST the JSON to https://graph.microsoft.com/v1.0/planner/tasks

set resp [new_CkHttpResponse]

set success [CkHttp_HttpJson $http "POST" "https://graph.microsoft.com/v1.0/planner/tasks" $json "application/json" $resp]
if {$success == 0} then {
    puts [CkHttp_lastErrorText $http]
    delete_CkHttp $http
    delete_CkJsonObject $jsonToken
    delete_CkJsonObject $json
    delete_CkHttpResponse $resp
    exit
}

CkJsonObject_Load $json [CkHttpResponse_bodyStr $resp]
CkJsonObject_put_EmitCompact $json 0

if {[CkHttpResponse_get_StatusCode $resp] != 200} then {
    puts [CkJsonObject_emit $json]
    puts "Failed, response status code = [CkHttpResponse_get_StatusCode $resp]"
    delete_CkHttp $http
    delete_CkJsonObject $jsonToken
    delete_CkJsonObject $json
    delete_CkHttpResponse $resp
    exit
}

puts [CkJsonObject_emit $json]

# A sample response:
# (See code for parsing this response below..)

# {
#   "createdBy": {
#     "user": {
#       "id": "6463a5ce-2119-4198-9f2a-628761df4a62"
#     }
#   },
#   "planId": "xqQg5FS2LkCp935s-FIFm2QAFkHM",
#   "bucketId": "hsOf2dhOJkqyYYZEtdzDe2QAIUCR",
#   "title": "Update client list",
#   "orderHint": "85752723360752+",
#   "createdDateTime": "2015-03-25T18:36:49.2407981Z",
#   "assignments": {
#     "fbab97d0-4932-4511-b675-204639209557": {
#       "@odata.type": "#microsoft.graph.plannerAssignment",
#       "assignedBy": {
#         "user": {
#           "id": "6463a5ce-2119-4198-9f2a-628761df4a62"
#         }
#       },
#       "assignedDateTime": "2015-03-25T18:36:49.2407981Z",
#       "orderHint": "RWk1"
#     }
#   },
#   "id":"01gzSlKkIUSUl6DF_EilrmQAKDhh"
# }

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

set createdByUserId [CkJsonObject_stringOf $json "createdBy.user.id"]
set planId [CkJsonObject_stringOf $json "planId"]
set bucketId [CkJsonObject_stringOf $json "bucketId"]
set title [CkJsonObject_stringOf $json "title"]
set orderHint [CkJsonObject_stringOf $json "orderHint"]
set createdDateTime [CkJsonObject_stringOf $json "createdDateTime"]
set assignments_odataType [CkJsonObject_stringOf $json "assignments.fbab97d0-4932-4511-b675-204639209557.\"@odata.type\""]
set assignmentsAssignedByUserId [CkJsonObject_stringOf $json "assignments.fbab97d0-4932-4511-b675-204639209557.assignedBy.user.id"]
set assignmentsAssignedDateTime [CkJsonObject_stringOf $json "assignments.fbab97d0-4932-4511-b675-204639209557.assignedDateTime"]
set assignmentsOrderHint [CkJsonObject_stringOf $json "assignments.fbab97d0-4932-4511-b675-204639209557.orderHint"]
set id [CkJsonObject_stringOf $json "id"]

puts "Success."

delete_CkHttp $http
delete_CkJsonObject $jsonToken
delete_CkJsonObject $json
delete_CkHttpResponse $resp