Sample code for 30+ languages & platforms
Tcl

Download File from Dropbox

See more Dropbox Examples

Downloads a file from Dropbox.

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.

# 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