Sample code for 30+ languages & platforms
SQL Server

Download File from Dropbox (Streaming)

See more Dropbox Examples

Downloads a file from Dropbox, streaming it directly to a file in the filesystem.

Chilkat SQL Server Downloads

SQL Server
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls.
--
CREATE PROCEDURE ChilkatSample
AS
BEGIN
    DECLARE @hr int
    DECLARE @iTmp0 int
    DECLARE @iTmp1 int
    DECLARE @iTmp2 int
    DECLARE @iTmp3 int
    DECLARE @iTmp4 int
    -- Important: Do not use nvarchar(max).  See the warning about using nvarchar(max).
    DECLARE @sTmp0 nvarchar(4000)
    DECLARE @success int
    SELECT @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.

    DECLARE @rest int
    EXEC @hr = sp_OACreate 'Chilkat.Rest', @rest OUT
    IF @hr <> 0
    BEGIN
        PRINT 'Failed to create ActiveX component'
        RETURN
    END

    -- Connect to Dropbox
    EXEC sp_OAMethod @rest, 'Connect', @success OUT, 'content.dropboxapi.com', 443, 1, 1
    IF @success = 0
      BEGIN
        EXEC sp_OAGetProperty @rest, 'LastErrorText', @sTmp0 OUT
        PRINT @sTmp0
        EXEC @hr = sp_OADestroy @rest
        RETURN
      END

    -- Add request headers.
    EXEC sp_OAMethod @rest, 'AddHeader', @success OUT, '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",
    -- }

    DECLARE @json int
    EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @json OUT

    EXEC sp_OAMethod @json, 'AppendString', @success OUT, 'path', '/Homework/lit/hamlet.xml'
    EXEC sp_OAMethod @json, 'Emit', @sTmp0 OUT
    EXEC sp_OAMethod @rest, 'AddHeader', @success OUT, 'Dropbox-API-Arg', @sTmp0

    -- Setup a file stream for the download
    DECLARE @fileStream int
    EXEC @hr = sp_OACreate 'Chilkat.Stream', @fileStream OUT

    EXEC sp_OASetProperty @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.
    DECLARE @expectedStatus int
    SELECT @expectedStatus = 200
    EXEC sp_OAMethod @rest, 'SetResponseBodyStream', @success OUT, @expectedStatus, 1, @fileStream

    DECLARE @responseStr nvarchar(4000)
    EXEC sp_OAMethod @rest, 'FullRequestNoBody', @responseStr OUT, 'POST', '/2/files/download'
    EXEC sp_OAGetProperty @rest, 'LastMethodSuccess', @iTmp0 OUT
    IF @iTmp0 = 0
      BEGIN
        EXEC sp_OAGetProperty @rest, 'LastErrorText', @sTmp0 OUT
        PRINT @sTmp0
        EXEC @hr = sp_OADestroy @rest
        EXEC @hr = sp_OADestroy @json
        EXEC @hr = sp_OADestroy @fileStream
        RETURN
      END

    -- When successful, Dropbox responds with a 200 response code.
    EXEC sp_OAGetProperty @rest, 'ResponseStatusCode', @iTmp0 OUT
    IF @iTmp0 <> 200
      BEGIN
        -- Examine the request/response to see what happened.

        EXEC sp_OAGetProperty @rest, 'ResponseStatusCode', @iTmp0 OUT
        PRINT 'response status code = ' + @iTmp0

        EXEC sp_OAGetProperty @rest, 'ResponseStatusText', @sTmp0 OUT
        PRINT 'response status text = ' + @sTmp0

        EXEC sp_OAGetProperty @rest, 'ResponseHeader', @sTmp0 OUT
        PRINT 'response header: ' + @sTmp0

        PRINT 'response body (if any): ' + @responseStr

        PRINT '---'

        EXEC sp_OAGetProperty @rest, 'LastRequestStartLine', @sTmp0 OUT
        PRINT 'LastRequestStartLine: ' + @sTmp0

        EXEC sp_OAGetProperty @rest, 'LastRequestHeader', @sTmp0 OUT
        PRINT 'LastRequestHeader: ' + @sTmp0
        EXEC @hr = sp_OADestroy @rest
        EXEC @hr = sp_OADestroy @json
        EXEC @hr = sp_OADestroy @fileStream
        RETURN
      END

    -- 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:
    DECLARE @apiResult nvarchar(4000)
    EXEC sp_OAMethod @rest, 'ResponseHdrByName', @apiResult OUT, 'dropbox-api-result'

    PRINT @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...
    DECLARE @jsonResult int
    EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @jsonResult OUT

    EXEC sp_OASetProperty @jsonResult, 'EmitCompact', 0
    EXEC sp_OAMethod @jsonResult, 'Load', @success OUT, @apiResult
    -- Show the JSON pretty-printed...
    EXEC sp_OAMethod @jsonResult, 'Emit', @sTmp0 OUT
    PRINT @sTmp0

    -- Sample code to get data from the JSON response:
    DECLARE @size int
    EXEC sp_OAMethod @jsonResult, 'IntOf', @size OUT, 'size'

    PRINT 'size = ' + @size

    DECLARE @rev nvarchar(4000)
    EXEC sp_OAMethod @jsonResult, 'StringOf', @rev OUT, 'rev'

    PRINT 'rev = ' + @rev

    DECLARE @clientModified nvarchar(4000)
    EXEC sp_OAMethod @jsonResult, 'StringOf', @clientModified OUT, 'client_modified'
    DECLARE @ckdt int
    EXEC @hr = sp_OACreate 'Chilkat.CkDateTime', @ckdt OUT

    EXEC sp_OAMethod @ckdt, 'SetFromTimestamp', @success OUT, @clientModified
    DECLARE @bLocalTime int
    SELECT @bLocalTime = 1
    DECLARE @dt int
    EXEC @hr = sp_OACreate 'Chilkat.DtObj', @dt OUT

    EXEC sp_OAMethod @ckdt, 'ToDtObj', NULL, @bLocalTime, @dt

    EXEC sp_OAGetProperty @dt, 'Day', @iTmp0 OUT

    EXEC sp_OAGetProperty @dt, 'Month', @iTmp1 OUT

    EXEC sp_OAGetProperty @dt, 'Year', @iTmp2 OUT

    EXEC sp_OAGetProperty @dt, 'Hour', @iTmp3 OUT

    EXEC sp_OAGetProperty @dt, 'Minute', @iTmp4 OUT
    PRINT @iTmp0 + '/' + @iTmp1 + '/' + @iTmp2 + ' ' + @iTmp3 + ':' + @iTmp4

    EXEC @hr = sp_OADestroy @rest
    EXEC @hr = sp_OADestroy @json
    EXEC @hr = sp_OADestroy @fileStream
    EXEC @hr = sp_OADestroy @jsonResult
    EXEC @hr = sp_OADestroy @ckdt
    EXEC @hr = sp_OADestroy @dt


END
GO