Sample code for 30+ languages & platforms
Tcl

Box.com Upload File

See more Box Examples

Demonstrates how to upload a file to box.com.

Chilkat Tcl Downloads

Tcl

load ./chilkat.dll

set success 0

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

# ------------------------------------------------------------------------------------------
# Important:
# See this information about Box.com Service Accounts
# Box.com will automatically generate a Service Account where the name of the account is the name of your App.� 
# When you make API calls, it is for this service account, and the files that exist and what you see are not the same as your normal account.
# ------------------------------------------------------------------------------------------

set rest [new_CkRest]

#   Provide a previously obtained OAuth2 access token.
set oauth2 [new_CkOAuth2]

CkOAuth2_put_AccessToken $oauth2 "BOX_ACCESS_TOKEN"
CkRest_SetAuthOAuth2 $rest $oauth2

# First, make the initial connection.
# A single REST object, once connected, can be used for many Box REST API calls.
# The auto-reconnect indicates that if the already-established HTTPS connection is closed,
# then it will be automatically re-established as needed.
set bAutoReconnect 1

# ----------------------------------------------------------------------
# IMPORTANT: Note that the domain is "upload.box.com", not "api.box.com"
# ----------------------------------------------------------------------
set success [CkRest_Connect $rest "upload.box.com" 443 1 $bAutoReconnect]
if {$success != 1} then {
    puts [CkRest_lastErrorText $rest]
    delete_CkRest $rest
    delete_CkOAuth2 $oauth2
    exit
}

# The request body uses the "multipart/form-data" format to transmit two "parts". 
# The first part is called "attributes" and contains a JSON object with information about the file, including the name of the file 
# and the ID of the parent folder. The second part contains the contents of the file. 
# (Note that the name of the second "part" is ignored.)

CkRest_AddHeader $rest "Content-Type" "multipart/form-data"

# Provide the content for each part of the request...

# First the JSON attributes.  Use "0" for the root folder.
#   {"name":"penguins.jpg", "parent":{"id":"0"}}
set jsonAttr [new_CkJsonObject]

CkJsonObject_UpdateString $jsonAttr "name" "penguins.jpg"
CkJsonObject_UpdateString $jsonAttr "parent.id" "0"

CkRest_put_PartSelector $rest "1"
CkRest_AddHeader $rest "Content-Disposition" "form-data; name=\"attributes\"; "
CkRest_SetMultipartBodyString $rest [CkJsonObject_emit $jsonAttr]

CkRest_put_PartSelector $rest "2"
CkRest_AddHeader $rest "Content-Disposition" "form-data; name=\"file\"; filename=\"penguins.jpg\""
# "application/octet-stream" can be safely used for any type file..
CkRest_AddHeader $rest "Content-Type" "application/octet-stream"

# Load the file into a binary data object, and then upload..
set fileDataObj [new_CkBinData]

CkBinData_LoadFile $fileDataObj "qa_data/jpg/penguins.jpg"
CkRest_SetMultipartBodyBd $rest $fileDataObj

# Restore the PartSelector to "0" (for safety, in case something else sends another request on this object)
CkRest_put_PartSelector $rest "0"

# Send the multipart/form-data request, which uploads the file contained in fileDataObj
set responseBody [CkRest_fullRequestMultipart $rest "POST" "/api/2.0/files/content"]
if {[CkRest_get_LastMethodSuccess $rest] != 1} then {
    puts [CkRest_lastErrorText $rest]
    delete_CkRest $rest
    delete_CkOAuth2 $oauth2
    delete_CkJsonObject $jsonAttr
    delete_CkBinData $fileDataObj
    exit
}

# A 201 is received for a successful upload
if {[CkRest_get_ResponseStatusCode $rest] != 201} then {
    puts "Box.com upload failed."
    puts "Request header:"
    puts [CkRest_lastRequestHeader $rest]
    puts "---"
    puts "Response status code = [CkRest_get_ResponseStatusCode $rest]"
    puts "Response body:"
    puts "$responseBody"
    delete_CkRest $rest
    delete_CkOAuth2 $oauth2
    delete_CkJsonObject $jsonAttr
    delete_CkBinData $fileDataObj
    exit
}

puts "File uploaded."

delete_CkRest $rest
delete_CkOAuth2 $oauth2
delete_CkJsonObject $jsonAttr
delete_CkBinData $fileDataObj