Dropbox Storage Provider Setup
The Dropbox Storage Provider allows end-users to map in their OneDrive storage into container-based sessions. Access is provided via Dropbox’s OAuth interface and leveraging the Rclone Docker volume plugin.
Reference Docs:
Creating a Dropbox OAuth App
Login to the Dropbox App Console: https://www.dropbox.com/developers/apps/create .
Select Scoped Access, Full Dropbox, give the app a name (e.g
Kasm-Example
), then click Create app.
data:image/s3,"s3://crabby-images/daeaa/daeaaac2831739aaf3b89169c64e7cd29af8c9b9" alt="../../_images/create_new_app.png"
Create new App
On the next screen take note of the App key and App Secret , these will be used as the Client ID and Client Secret in the Storage Provider Configuration.
data:image/s3,"s3://crabby-images/a8d2a/a8d2a0c79a176d85f51b44f8972e1f3ef13088bb" alt="../../_images/app_key_secret.png"
Authentication Details
In the Development users section, click Enable additional users to allow additional accounts to use this app.
data:image/s3,"s3://crabby-images/2f841/2f84105bd3cdb0fc9d7c7313d59ef3c8e2da6c16" alt="../../_images/enable_additional_users.png"
Enable Additional Users
In the OAuth 2 section, enter the following URL for Redirect URI , substituting the hostname of the Kasm deployment
https://kasm.example.com/api/cloud_storage_callback
, then click Add.
data:image/s3,"s3://crabby-images/82951/829518e65aa67b4b76303b74b64672a22f87653f" alt="../../_images/app_redirect.png"
Redirect Settings
Select the Permissions tab and ensure the following permissions are selected, then click Submit.
account_info.read files.metadata.read files.metadata.write files.content.write files.content.read sharing.read sharing.write
data:image/s3,"s3://crabby-images/aabe5/aabe596f56d66dbf3e6741d23bab06b650351df0" alt="../../_images/app_permissions.png"
DropBox Permissions
Kasm Storage Provider Config
Log into the Kasm UI as an administrator.
Select Settings -> Storage -> Add.
Update the form with the following entries, using the Client ID and Client Secret gathered in the previous section.
Name |
|
Storage Provider Type |
|
Enabled |
|
Client ID |
|
Client Secret |
|
Authorization URL |
|
Authorization URL Options |
|
Token URL |
|
Redirect URL |
|
Scope |
files.metadata.read
files.metadata.write
files.content.read
files.content.write
sharing.read
sharing.write
account_info.read
|
Default Target |
|
Volume Config |
{
"driver" : "rclone",
"driver_opts" : {
"type" : "dropbox",
"uid" : "1000",
"gid" : "1000",
"allow_other" : "true"
}
}
|
Mount Config |
|
Click Save to save the changes.
Dropbox Storage Mapping Configuration
From any page, select the profile icon at the top right of the page. Select Edit Profile.
data:image/s3,"s3://crabby-images/dacb4/dacb4ab2f236079d24ce52982d88b9108730e782" alt="../../_images/edit_profile.png"
Edit Profile
Select the Cloud Storage section, then Add Storage Mapping.
data:image/s3,"s3://crabby-images/eb988/eb988314b88ab7af700e35e823a66eacd1dad55a" alt="../../_images/profile_add_storage_mapping.png"
Add Storage Mapping
Select Dropbox from the dropdown, then select Next.
data:image/s3,"s3://crabby-images/fb16c/fb16c4550486102a46fcafc08424067643f67afe" alt="../../_images/configure_storage.webp"
Configure Storage
The Dropbox Login page will appear. Login with the desired account.
data:image/s3,"s3://crabby-images/e64bf/e64bf08a026f9237147cd01ffcb3bec0e6c64cc2" alt="../../_images/login1.png"
Login
Dropbox will ask for consent to provide access to the account.
data:image/s3,"s3://crabby-images/b648f/b648f130be0f3cd3d7956c30e362ad091f69beba" alt="../../_images/approve.png"
Approve Kasm
If successful, a redirect will occur to the Workspaces dashboard. The new storage mapping can be seen in the Cloud Storage section of the profile.
data:image/s3,"s3://crabby-images/0d9e8/0d9e8aa80d3d404a635976c99354d079fa02a9a4" alt="../../_images/storage_mapping.png"
Storage Mapping
Launch a new container-based session. Verify Dropbox is mapped inside the session at the
/dropbox
location.
data:image/s3,"s3://crabby-images/c8be5/c8be58721c42d73be41dfee3d4f2cf5239b11890" alt="../../_images/files1.png"
In Session View