PowerShell
PowerShell
Download File from Dropbox (Streaming)
See more Dropbox Examples
Downloads a file from Dropbox, streaming it directly to a file in the filesystem.Chilkat PowerShell Downloads
Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll"
$success = $false
# 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.
$rest = New-Object Chilkat.Rest
# Connect to Dropbox
$success = $rest.Connect("content.dropboxapi.com",443,$true,$true)
if ($success -eq $false) {
$($rest.LastErrorText)
exit
}
# Add request headers.
$rest.AddHeader("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",
# }
$json = New-Object Chilkat.JsonObject
$json.AppendString("path","/Homework/lit/hamlet.xml")
$rest.AddHeader("Dropbox-API-Arg",$json.Emit())
# Setup a file stream for the download
$fileStream = New-Object Chilkat.Stream
$fileStream.SinkFile = "qa_output/hamletFromDropbox.xml"
# Indicate that the call to FullRequestNoBody should send the response body
# to fileStream if the response status code is 200.
# If a non-success response status code is received, then nothing
# is streamed to the output file and the error response is returned by FullRequestNoBody.
$expectedStatus = 200
$rest.SetResponseBodyStream($expectedStatus,$true,$fileStream)
$responseStr = $rest.FullRequestNoBody("POST","/2/files/download")
if ($rest.LastMethodSuccess -eq $false) {
$($rest.LastErrorText)
exit
}
# When successful, Dropbox responds with a 200 response code.
if ($rest.ResponseStatusCode -ne 200) {
# Examine the request/response to see what happened.
$("response status code = " + $rest.ResponseStatusCode)
$("response status text = " + $rest.ResponseStatusText)
$("response header: " + $rest.ResponseHeader)
$("response body (if any): " + $responseStr)
$("---")
$("LastRequestStartLine: " + $rest.LastRequestStartLine)
$("LastRequestHeader: " + $rest.LastRequestHeader)
exit
}
# 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:
$apiResult = $rest.ResponseHdrByName("dropbox-api-result")
$($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...
$jsonResult = New-Object Chilkat.JsonObject
$jsonResult.EmitCompact = $false
$jsonResult.Load($apiResult)
# Show the JSON pretty-printed...
$($jsonResult.Emit())
# Sample code to get data from the JSON response:
$size = $jsonResult.IntOf("size")
$("size = " + $size)
$rev = $jsonResult.StringOf("rev")
$("rev = " + $rev)
$clientModified = $jsonResult.StringOf("client_modified")
$ckdt = New-Object Chilkat.CkDateTime
$ckdt.SetFromTimestamp($clientModified)
$bLocalTime = $true
$dt = New-Object Chilkat.DtObj
$ckdt.ToDtObj($bLocalTime,$dt)
$([string]$dt.Day + "/" + $dt.Month + "/" + $dt.Year + " " + $dt.Hour + ":" + $dt.Minute)