All work is credited to the original author. I am just a man, a simple man... who needed some changes.
A Laravel package for working with Dropbox v2 API.
Dropbox API documentation can be found at: https://www.dropbox.com/developers/documentation/http/documentation
To use Dropbox API an application needs creating at https://www.dropbox.com/developers/apps
Create a new application, select either Dropbox API or Dropbox Business API Next select the type of access needed either the app folder (useful for isolating to a single folder), or full Dropbox.
Next copy and paste the APP Key and App Secret into your .env file:
DROPBOX_CLIENT_ID=
DROPBOX_SECRET_ID=
Now enter your desired redirect URL. This is the URL your application will use to connect to Dropbox API.
A common URL is https://domain.com/dropbox/connect
Via Composer
composer require zanderwar/lumen-dropbox:^1.0
You can publish the config file with:
php artisan vendor:publish --provider="Zanderwar\Dropbox\DropboxServiceProvider" --tag="config"
When published, the config/dropbox.php config file contains, make sure to publish this file and change the scopes to match the scopes of your Dropbox app, inside Dropbox app console.
<?php
return [
/*
* set the client id
*/
'clientId' => env('DROPBOX_CLIENT_ID'),
/*
* set the client secret
*/
'clientSecret' => env('DROPBOX_SECRET_ID'),
/*
* Set the url to trigger the oauth process this url should call return Dropbox::connect();
*/
'redirectUri' => env('DROPBOX_OAUTH_URL'),
/*
* Set the url to redirecto once authenticated;
*/
'landingUri' => env('DROPBOX_LANDING_URL', '/'),
/**
* Set access token, when set will bypass the oauth2 process
*/
'accessToken' => env('DROPBOX_ACCESS_TOKEN', ''),
/**
* Set access type, options are offline and online
* Offline - will return a short-lived access_token and a long-lived refresh_token that can be used to request a new short-lived access token as long as a user's approval remains valid.
*
* Online - will return a short-lived access_token
*/
'accessType' => env('DROPBOX_ACCESS_TYPE', 'offline'),
/*
set the scopes to be used
*/
'scopes' => 'account_info.read files.metadata.write files.metadata.read files.content.write files.content.read',
];
You can publish the migration with:
php artisan vendor:publish --provider="Zanderwar\Dropbox\DropboxServiceProvider" --tag="migrations" After the migration has been published you can create the tokens tables by running the migration:
php artisan migrate
.ENV Configuration Ensure you've set the following in your .env file:
DROPBOX_CLIENT_ID=
DROPBOX_SECRET_ID=
DROPBOX_OAUTH_URL=https://domain.com/dropbox/connect
DROPBOX_LANDING_URL=https://domain.com/dropbox
DROPBOX_ACCESS_TYPE=offline
Bypass Oauth2 You can bypass the oauth2 process by generating an access token in your dropbox app and entering it on the .env file:
DROPBOX_ACCESS_TOKEN=
This package ties tokens to the currently authenticated user. This means the
auth
middleware must be enabled on the connect/disconnect routes. Alternatively, you can use Passport::actingAs($user)
prior to calling connect()
when
the user is returned.
If you need to pass arbitrary data to dropbox (that may aid in preventing CSRF attacks or contain other information useful for post-processing.)
then you can use the $state
parameter within the Dropbox::connect(string $state = null)
method. This will result in dropbox returning this value
to you once the user has been authenticated.
Notes:
- Your route must not use the
dropbox.auth
middleware if you intend to use thestate
parameter.- If setting the access code directly don't rely on
Dropbox::getAccessToken()
.
A routes example:
$router->group([/** Middleware etc */], function(\Laravel\Lumen\Routing\Router $router) {
$router->get('/dropbox/connect', function() {
if (! request()->has('code')) {
// user is heading to dropbox
$arbitraryData = ['hello' => 'world'];
return \Zanderwar\Dropbox\Dropbox::connect(json_encode($arbitraryData));
}
// user is returning from dropbox
$state = request()->input('state');
if (! $state) {
throw new \RuntimeException('The state parameter is missing from the request.');
}
// do stuff with $state...
// e.g. Passport::actingAs(Decrypt::json($state)->user_id)
// finalise the account internally, by calling the connect method again. This will fetch
// an access/refresh token from dropbox. This behaviour is only exhibited when the `code`
// query param is in the URL.
return \Zanderwar\Dropbox\Dropbox::connect();
});
$router->get('/dropbox/disconnect', function() {
return Dropbox::disconnect('path/to/redirect/to');
});
});
Once authenticated you can call Dropbox:: with the following verbs:
Dropbox::get($endpoint, $array = [], $headers = [], $useToken = true)
Dropbox::post($endpoint, $array = [], $headers = [], $useToken = true)
Dropbox::put($endpoint, $array = [], $headers = [], $useToken = true)
Dropbox::patch($endpoint, $array = [], $headers = [], $useToken = true)
Dropbox::delete($endpoint, $array = [], $headers = [], $useToken = true)
The $array is not always required, its requirement is determined from the endpoint being called, see the API documentation for more details.
The $headers are optional when used can pass in additional headers.
The $useToken is optional when set to true will use the authorisation header, defaults to true.
These expect the API endpoints to be passed, the URL https://api.dropboxapi.com/2/ is provided, only endpoints after this should be used ie:
Dropbox::post('users/get_current_account')
To restrict access to authenticated users only you can register the below middleware and assign it to your routes.
bootstrap/app.php
app()->middleware([
'dropbox.auth' => \Zanderwar\Dropbox\Http\Middleware\DropboxAuthMiddleware::class
]);
routes/web.php
$router->group(['middleware' => ['dropbox.auth']], function (\Laravel\Lumen\Routing\Router $router) {
// your routes
});
To access the token model reference this ORM model:
use Zanderwar\Dropbox\Models\DropboxToken;
This package provides a clean way of working with files.
To work with files first call ->files() followed by a method.
Import Namespace
use Zanderwar\Dropbox\Facades\Dropbox;
List Content
list files and folders of a given path
Dropbox::files()->listContents($path = '')
List Content Continue
Using a cursor from the previous listContents call to paginate over the next set of folders/files.
Dropbox::files()->listContentsContinue($cursor = '')
Delete folder/file Pass the path to the file/folder, When delting a folder all child items will be deleted.
Dropbox::files()->delete($path)
Create Folder Pass the path to the folder to be created.
Dropbox::files()->createFolder($path)
Search Files Each word will used to search for files.
Dropbox::files()->search($query)
Upload File Upload files to Dropbox by passing the folder path followed by the filename. Note this method supports uploads up to 150MB only.
Dropbox::files()->upload($path, $file)
Download File Download file from Dropbox by passing the folder path including the file.
Dropbox::files()->download($path)
Move Folder/File Move accepts 4 params:
$fromPath - provide the path for the existing folder/file $toPath - provide the new path for the existing golder/file must start with a / $autoRename - If there's a conflict, have the Dropbox server try to autorename the file to avoid the conflict. The default for this field is false. $allowOwnershipTransfer - Allow moves by owner even if it would result in an ownership transfer for the content being moved. This does not apply to copies. The default for this field is false.
Dropbox::files()->move($fromPath, $toPath, $autoRename = false, $allowOwnershipTransfer = false);
Please see the changelog for more information on what has changed recently.
Contributions are welcome and will be fully credited.
Contributions are accepted via Pull Requests on Github.
-
Document any change in behaviour - Make sure the
readme.md
and any other relevant documentation are kept up-to-date. -
Consider our release cycle - We try to follow SemVer v2.0.0. Randomly breaking public APIs is not an option.
-
One pull request per feature - If you want to do more than one thing, send multiple pull requests.
If you discover any security related issues, please email reece.alexander@gmail.com email instead of using the issue tracker.
license. Please see the license file for more information.