Sample code for 30+ languages & platforms
Tcl

OneDrive -- Delete a File or Folder

See more OneDrive Examples

Demonstrates how to delete a file, folder, or any DriveItem.

Note: This example requires Chilkat v9.5.0.97 or greater.

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.

# This example uses the OAuth client credentials flow.
# See How to Create an Azure App Registration for OAuth 2.0 Client Credentials

# Use your client ID, client secret, and tenant ID in the following lines
set json [new_CkJsonObject]

CkJsonObject_UpdateString $json "client_id" "2871da2c-8176-4b7f-869b-2311aa82e743"
CkJsonObject_UpdateString $json "client_secret" "2hu9Q~r5QuryUcEkNbg1btLtnfU1VUXzhSCG6brH"
CkJsonObject_UpdateString $json "scope" "https://graph.microsoft.com/.default"
CkJsonObject_UpdateString $json "token_endpoint" "https://login.microsoftonline.com/114d7ed6-71bf-4dbe-a866-748364121bf2/oauth2/v2.0/token"

set http [new_CkHttp]

CkHttp_put_AuthToken $http [CkJsonObject_emit $json]

# To delete a file or folder, send a DELETE request like this:
# DELETE /v1.0/users/{user_id}/drive/root:/{item-path}

CkHttp_SetUrlVar $http "item_path" "TestDir/sample.pdf"
CkHttp_SetUrlVar $http "user_id" "4fe732c3-322e-4a6b-b729-2fd1eb5c6104"
set resp [CkHttp_quickDeleteStr $http "https://graph.microsoft.com/v1.0/users/{$user_id}/drive/root:/{$item_path}"]
if {[CkHttp_get_LastMethodSuccess $http] != 1} then {
    puts [CkHttp_lastErrorText $http]
    delete_CkJsonObject $json
    delete_CkHttp $http
    exit
}

# A 204 response (with no response body) indicates success.
if {[CkHttp_get_LastStatus $http] == 204} then {
    puts "DriveItem deleted."
} else {
    puts "DriveItem not deleted."
    puts "$resp"
}


delete_CkJsonObject $json
delete_CkHttp $http