dropbox-sdk-go-unofficial

module
v6.0.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 23, 2019 License: MIT

README

Dropbox SDK for Go [UNOFFICIAL] GoDoc Build Status Go Report Card

An UNOFFICIAL Go SDK for integrating with the Dropbox API v2. Tested with Go 1.5+

⚠ WARNING: This SDK is NOT yet official. What does this mean?

  • There is no formal Dropbox support for this SDK at this point
  • Bugs may or may not get fixed
  • Not all SDK features may be implemented and implemented features may be buggy or incorrect
Uh OK, so why are you releasing this?
  • the SDK, while unofficial, is usable. See dbxcli for an example application built using the SDK
  • we would like to get feedback from the community and evaluate the level of interest/enthusiasm before investing into official supporting one more SDK

Installation

$ go get github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/...

For most applications, you should just import the relevant namespace(s) only. The SDK exports the following sub-packages:

  • github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/auth
  • github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/files
  • github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/sharing
  • github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/team
  • github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/users

Additionally, the base github.com/dropbox/dropbox-sdk-go-unofficial/dropbox package exports some configuration and helper methods.

Usage

First, you need to register a new "app" to start making API requests. Once you have created an app, you can either use the SDK via an access token (useful for testing) or via the regular OAuth2 flow (recommended for production).

Using OAuth token

Once you've created an app, you can get an access token from the app's console. Note that this token will only work for the Dropbox account the token is associated with.

import "github.com/dropbox/dropbox-sdk-go-unofficial/dropbox"
import "github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/users"

func main() {
  config := dropbox.Config{
      Token: token,
      LogLevel: dropbox.LogInfo, // if needed, set the desired logging level. Default is off
  }
  dbx := users.New(config)
  // start making API calls
}
Using OAuth2 flow

For this, you will need your APP_KEY and APP_SECRET from the developers console. Your app will then have to take users though the oauth flow, as part of which users will explicitly grant permissions to your app. At the end of this process, users will get a token that the app can then use for subsequent authentication. See this for an example of oauth2 flow in Go.

Once you have the token, usage is same as above.

Making API calls

Each Dropbox API takes in a request type and returns a response type. For instance, /users/get_account takes as input a GetAccountArg and returns a BasicAccount. The typical pattern for making API calls is:

  • Instantiate the argument via the New* convenience functions in the SDK
  • Invoke the API
  • Process the response (or handle error, as below)

Here's an example:

  arg := users.NewGetAccountArg(accountId)
  if resp, err := dbx.GetAccount(arg); err != nil {
    return err
  }
  fmt.Printf("Name: %v", resp.Name)
Error Handling

As described in the API docs, all HTTP errors except 409 are returned as-is to the client (with a helpful text message where possible). In case of a 409, the SDK will return an endpoint-specific error as described in the API. This will be made available as EndpointError member in the error.

Note on using the Teams API

To use the Team API, you will need to create a Dropbox Business App. The OAuth token from this app will only work for the Team API.

Please read the API docs carefully to appropriate secure your apps and tokens when using the Team API.

Code Generation

This SDK is automatically generated using the public Dropbox API spec and Stone. See this README for more details on how code is generated.

Caveats

  • To re-iterate, this is an UNOFFICIAL SDK and thus has no official support from Dropbox
  • Only supports the v2 API. Parts of the v2 API are still in beta, and thus subject to change
  • This SDK itself is in beta, and so interfaces may change at any point

Directories

Path Synopsis
async
Package async : has no documentation (yet)
Package async : has no documentation (yet)
auth
Package auth : has no documentation (yet)
Package auth : has no documentation (yet)
common
Package common : has no documentation (yet)
Package common : has no documentation (yet)
contacts
Package contacts : has no documentation (yet)
Package contacts : has no documentation (yet)
file_properties
Package file_properties : This namespace contains helpers for property and template metadata endpoints.
Package file_properties : This namespace contains helpers for property and template metadata endpoints.
file_requests
Package file_requests : This namespace contains endpoints and data types for file request operations.
Package file_requests : This namespace contains endpoints and data types for file request operations.
files
Package files : This namespace contains endpoints and data types for basic file operations.
Package files : This namespace contains endpoints and data types for basic file operations.
paper
Package paper : This namespace contains endpoints and data types for managing docs and folders in Dropbox Paper.
Package paper : This namespace contains endpoints and data types for managing docs and folders in Dropbox Paper.
seen_state
Package seen_state : has no documentation (yet)
Package seen_state : has no documentation (yet)
sharing
Package sharing : This namespace contains endpoints and data types for creating and managing shared links and shared folders.
Package sharing : This namespace contains endpoints and data types for creating and managing shared links and shared folders.
team
Package team : has no documentation (yet)
Package team : has no documentation (yet)
team_common
Package team_common : has no documentation (yet)
Package team_common : has no documentation (yet)
team_log
Package team_log : has no documentation (yet)
Package team_log : has no documentation (yet)
team_policies
Package team_policies : has no documentation (yet)
Package team_policies : has no documentation (yet)
users
Package users : This namespace contains endpoints and data types for user management.
Package users : This namespace contains endpoints and data types for user management.
users_common
Package users_common : This namespace contains common data types used within the users namespace.
Package users_common : This namespace contains common data types used within the users namespace.
generator

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL