Tcl
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
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