Sample code for 30+ languages & platforms
SQL Server

Upload File to Google Cloud Storage

See more Google Cloud Storage Examples

Demonstrates how to upload a file to Google Cloud Storage.

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
    -- 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.

    -- This example uses a previously obtained access token having permission for the 
    -- scope "https://www.googleapis.com/auth/cloud-platform"

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

    EXEC sp_OAMethod @jsonToken, 'LoadFile', @success OUT, 'qa_data/tokens/googleCloudStorage.json'
    IF @success = 0
      BEGIN
        EXEC sp_OAGetProperty @jsonToken, 'LastErrorText', @sTmp0 OUT
        PRINT @sTmp0
        EXEC @hr = sp_OADestroy @jsonToken
        RETURN
      END

    -- Send a POST equivalent to this curl command.
    -- The content of the file is contained in the request body.

    -- curl -X POST --data-binary @[OBJECT] \
    --     -H "Authorization: Bearer [OAUTH2_TOKEN]" \
    --     -H "Content-Type: [OBJECT_CONTENT_TYPE]" \
    --     "https://www.googleapis.com/upload/storage/v1/b/[BUCKET_NAME]/o?uploadType=media&name=[OBJECT_NAME]"

    DECLARE @http int
    EXEC @hr = sp_OACreate 'Chilkat.Http', @http OUT

    EXEC sp_OAMethod @jsonToken, 'StringOf', @sTmp0 OUT, 'access_token'
    EXEC sp_OASetProperty @http, 'AuthToken', @sTmp0

    DECLARE @sbPath int
    EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbPath OUT

    EXEC sp_OAMethod @sbPath, 'Append', @success OUT, '/upload/storage/v1/b/bucket_name/o?uploadType=media&name=object_name'
    DECLARE @numReplaced int
    EXEC sp_OAMethod @sbPath, 'Replace', @numReplaced OUT, 'bucket_name', 'chilkat-bucket-b'
    EXEC sp_OAMethod @sbPath, 'Replace', @numReplaced OUT, 'object_name', 'penguins.jpg'

    DECLARE @req int
    EXEC @hr = sp_OACreate 'Chilkat.HttpRequest', @req OUT

    EXEC sp_OASetProperty @req, 'HttpVerb', 'POST'
    EXEC sp_OAMethod @sbPath, 'GetAsString', @sTmp0 OUT
    EXEC sp_OASetProperty @req, 'Path', @sTmp0
    EXEC sp_OASetProperty @req, 'ContentType', 'image/jpeg'
    -- Indicate the file to be streamed in the request body when the HTTP POST is sent.
    EXEC sp_OAMethod @req, 'StreamBodyFromFile', @success OUT, 'qa_data/jpg/penguins.jpg'

    DECLARE @resp int
    EXEC @hr = sp_OACreate 'Chilkat.HttpResponse', @resp OUT

    EXEC sp_OAMethod @http, 'HttpSReq', @success OUT, 'www.googleapis.com', 443, 1, @req, @resp
    IF @success = 0
      BEGIN
        EXEC sp_OAGetProperty @http, 'LastErrorText', @sTmp0 OUT
        PRINT @sTmp0
        EXEC @hr = sp_OADestroy @jsonToken
        EXEC @hr = sp_OADestroy @http
        EXEC @hr = sp_OADestroy @sbPath
        EXEC @hr = sp_OADestroy @req
        EXEC @hr = sp_OADestroy @resp
        RETURN
      END

    DECLARE @responseCode int
    EXEC sp_OAGetProperty @resp, 'StatusCode', @responseCode OUT
    IF @responseCode = 401
      BEGIN
        EXEC sp_OAGetProperty @resp, 'BodyStr', @sTmp0 OUT
        PRINT @sTmp0

        PRINT 'If invalid credentials, then it is likely the access token expired.'

        PRINT 'Your app should automatically fetch a new access token and re-try.'
        EXEC @hr = sp_OADestroy @jsonToken
        EXEC @hr = sp_OADestroy @http
        EXEC @hr = sp_OADestroy @sbPath
        EXEC @hr = sp_OADestroy @req
        EXEC @hr = sp_OADestroy @resp
        RETURN
      END


    PRINT 'Response code: ' + @responseCode

    PRINT 'Response body'
    EXEC sp_OAGetProperty @resp, 'BodyStr', @sTmp0 OUT
    PRINT @sTmp0

    -- A successful response looks like this:
    -- Response code: 200
    -- Response body
    -- {
    --  "kind": "storage#object",
    --  "id": "chilkat-ocean/penguins.jpg/1502643657837855",
    --  "selfLink": "https://www.googleapis.com/storage/v1/b/chilkat-ocean/o/penguins.jpg",
    --  "name": "penguins.jpg",
    --  "bucket": "chilkat-ocean",
    --  "generation": "1502643657837855",
    --  "metageneration": "1",
    --  "contentType": "image/jpeg",
    --  "timeCreated": "2017-08-13T17:00:57.811Z",
    --  "updated": "2017-08-13T17:00:57.811Z",
    --  "storageClass": "MULTI_REGIONAL",
    --  "timeStorageClassUpdated": "2017-08-13T17:00:57.811Z",
    --  "size": "777835",
    --  "md5Hash": "nTd7EM53jEk4s8fixjoimg==",
    --  "mediaLink": "https://www.googleapis.com/download/storage/v1/b/chilkat-ocean/o/penguins.jpg?generation=1502643657837855&alt=media",
    --  "crc32c": "ixxYVw==",
    --  "etag": "CJ+azOvX1NUCEAE="
    -- }

    EXEC @hr = sp_OADestroy @jsonToken
    EXEC @hr = sp_OADestroy @http
    EXEC @hr = sp_OADestroy @sbPath
    EXEC @hr = sp_OADestroy @req
    EXEC @hr = sp_OADestroy @resp


END
GO