Tcl
Tcl
Download File from Dropbox
See more Dropbox Examples
Downloads a file from Dropbox.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.
# A Dropbox access token should have been previously obtained.
# Dropbox access tokens do not expire.
# See Dropbox Access Token.
set rest [new_CkRest]
# Connect to Dropbox
set success [CkRest_Connect $rest "content.dropboxapi.com" 443 1 1]
if {$success == 0} then {
puts [CkRest_lastErrorText $rest]
delete_CkRest $rest
exit
}
# Add request headers.
CkRest_AddHeader $rest "Authorization" "Bearer DROPBOX_ACCESS_TOKEN"
# The download "parameters" are contained in JSON passed in an HTTP request header.
# This is the JSON indicating the file to be downloaded:
# {
# "path": "/Homework/lit/hamlet.xml",
# }
set json [new_CkJsonObject]
CkJsonObject_AppendString $json "path" "/Homework/lit/hamlet.xml"
CkRest_AddHeader $rest "Dropbox-API-Arg" [CkJsonObject_emit $json]
set bd [new_CkBinData]
set success [CkRest_FullRequestNoBodyBd $rest "POST" "/2/files/download" $bd]
if {$success == 0} then {
puts [CkRest_lastErrorText $rest]
delete_CkRest $rest
delete_CkJsonObject $json
delete_CkBinData $bd
exit
}
# When successful, Dropbox responds with a 200 response code.
if {[CkRest_get_ResponseStatusCode $rest] != 200} then {
# Examine the request/response to see what happened.
puts "response status code = [CkRest_get_ResponseStatusCode $rest]"
puts "response status text = [CkRest_responseStatusText $rest]"
puts "response header: [CkRest_responseHeader $rest]"
puts "response body (if any): [CkBinData_getString $bd utf-8]"
puts "---"
puts "LastRequestStartLine: [CkRest_lastRequestStartLine $rest]"
puts "LastRequestHeader: [CkRest_lastRequestHeader $rest]"
delete_CkRest $rest
delete_CkJsonObject $json
delete_CkBinData $bd
exit
}
# The file was downloaded into bd.
# Save it to the filesystem.
set success [CkBinData_WriteFile $bd "c:/temp/qa_output/hamlet.xml"]
# Information about the downloaded file is also available as JSON in a response header.
# The "dropbox-api-result" response header contains the information. For example:
set apiResult [CkRest_responseHdrByName $rest "dropbox-api-result"]
puts "$apiResult"
# In this case, the pretty-formatted dropbox-api-result JSON looks like this:
# {
# "name": "hamlet.xml",
# "path_lower": "/homework/lit/hamlet.xml",
# "path_display": "/Homework/lit/hamlet.xml",
# "id": "id:74FkdeNuyKAAAAAAAAAAAQ",
# "client_modified": "2016-06-02T23:19:00Z",
# "server_modified": "2016-06-02T23:19:00Z",
# "rev": "9482db15f",
# "size": 279658
# }
# Load the JSON, pretty-print it, and demonstrate how to get some values...
set jsonResult [new_CkJsonObject]
CkJsonObject_put_EmitCompact $jsonResult 0
CkJsonObject_Load $jsonResult $apiResult
# Show the JSON pretty-printed...
puts [CkJsonObject_emit $jsonResult]
# Sample code to get data from the JSON response:
set size [CkJsonObject_IntOf $jsonResult "size"]
puts "size = $size"
set rev [CkJsonObject_stringOf $jsonResult "rev"]
puts "rev = $rev"
set clientModified [CkJsonObject_stringOf $jsonResult "client_modified"]
set ckdt [new_CkDateTime]
CkDateTime_SetFromTimestamp $ckdt $clientModified
set bLocalTime 1
set dt [new_CkDtObj]
CkDateTime_ToDtObj $ckdt $bLocalTime $dt
puts [CkDtObj_get_Day $dt]/[CkDtObj_get_Month $dt]/[CkDtObj_get_Year $dt] [CkDtObj_get_Hour $dt]:[CkDtObj_get_Minute $dt]
delete_CkRest $rest
delete_CkJsonObject $json
delete_CkBinData $bd
delete_CkJsonObject $jsonResult
delete_CkDateTime $ckdt
delete_CkDtObj $dt