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/5e231/5e231874ffb8df3a8fe34a6f0b8d52814f23f6d8" 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/513bd/513bd8b6ca4ece6a9469da38d2f01e8dc14a260f" 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/ca1b0/ca1b010af0b3c2b01f84869543424646693dda16" 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/ec280/ec2808e16d186dd9ecd96017bdc12cb796269cdb" 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/b419f/b419f87eecaafe83e63a8f3b11e34c4a42e23446" 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/70536/70536ab0f257bf7f8e4b5f68b0c2d816eb7e9b64" alt="../../_images/edit_profile.png"
Edit Profile
Select the Cloud Storage section, then Add Storage Mapping.
data:image/s3,"s3://crabby-images/8f706/8f706e5dc55273ba0ea5a2a225298958679c0ed0" alt="../../_images/profile_add_storage_mapping.png"
Add Storage Mapping
Select Dropbox from the dropdown, then select Next.
data:image/s3,"s3://crabby-images/77431/77431c849b90ead34da4592709e55794077832bf" alt="../../_images/configure_storage.webp"
Configure Storage
The Dropbox Login page will appear. Login with the desired account.
data:image/s3,"s3://crabby-images/ad9e3/ad9e3f023e0882e2375af40b33104a17338a11dc" alt="../../_images/login1.png"
Login
Dropbox will ask for consent to provide access to the account.
data:image/s3,"s3://crabby-images/8ec0b/8ec0be78e5396deabdd2099cb503876094e7edc0" 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/16675/16675336bb33e17f4c59cfecf01b1f2c8f3c0712" 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/61c84/61c84660d06285a1dca08722fb354211768e4db0" alt="../../_images/files1.png"
In Session View