> ## Documentation Index
> Fetch the complete documentation index at: https://docs.refold.ai/llms.txt
> Use this file to discover all available pages before exploring further.

# Setup

> Connect to your Microsoft OneDrive app for OAuth.

To setup your Microsoft OneDrive app in Refold for OAuth, you will need the following credentials from your [Microsoft Azure account](https://azure.microsoft.com/en-gb/):

* Client ID
* Client Secret
* Scopes

### Pre-requisites

1. Microsoft Azure Account. You can create one [here](https://azure.microsoft.com/en-gb/).

### Required Settings

* **Mandatory Scopes**

1. openid
2. offline\_access
3. Files.Read
4. Files.ReadWrite
5. Files.ReadWrite.AppFolder

<Info>If you haven't already created an app in Microsoft Azure, you'd need to create one.</Info>

### Creating an app in Microsoft Azure

To create a Microsoft OneDrive app and acquire the above mentioned credentials, please follow the steps mentioned below:

1. Log in to your [Microsoft Azure account](https://azure.microsoft.com/en-gb/).
2. Search for **Microsoft Entra ID** and select it from **Services** in the top search bar.

<img height="200" src="https://mintcdn.com/cobalt-55/wOGvLSncBaYd4o6C/images/Ms365/ms365_navigation.png?fit=max&auto=format&n=wOGvLSncBaYd4o6C&q=85&s=15504278a7f8cda14af4d9d3c861b1df" alt="Navigation for App setup" data-path="images/Ms365/ms365_navigation.png" />

3. Navigate to `Overview` in the side menu > Click on `+Add` > Select `App Registration`.
4. Enter the App **Name** for your application and select `Accounts in any organizational directory (Any Microsoft Entra ID tenant - Multitenant)` under **Supported Account Types**.
5. Go to your [`Apps catalog`](https://app.gocobalt.io/apps) in **Refold** > Search for `Microsoft One Drive` > `Settings` > `Use your credentials` > `Callback Url` > Copy it.
6. Under the **Redirect URI** section, select **Platform** as `Web`, paste the **Callback Url** as the URL and click `Register`.

<img height="200" src="https://mintcdn.com/cobalt-55/wOGvLSncBaYd4o6C/images/Msonedrive/onedrive_register.png?fit=max&auto=format&n=wOGvLSncBaYd4o6C&q=85&s=075eb7aeca608b7475ea44561e4c0a7b" alt="App Registration" data-path="images/Msonedrive/onedrive_register.png" />

<Info>
  If you already have an app created, then follows these steps to add Redirect URL:

  Select your Application > Select **Authentication** in side menu > Under **Platform configurations**, press the  **Add a platform** button > Select **Web** > Paste the Callback Url > Click on **Configure** > Click **Save** button at the bottom.
</Info>

7. Navigate to `Manage` > `API permissions` in the side menu > Click on `+ Add a permission`.
8. Choose the `Microsoft Graph` card under **Microsoft APIs** > Choose `Application permissions` > Select the **mandatory scopes** > click on the `Add Permissions` button.
   <Info>**Offline\_access** and **openid** scope will be present under **Delegated permissions** in **Microsoft Graph**</Info>

<img height="200" src="https://mintcdn.com/cobalt-55/wOGvLSncBaYd4o6C/images/Msonedrive/onedrive_config.png?fit=max&auto=format&n=wOGvLSncBaYd4o6C&q=85&s=74a0bd07882eec8cdaebd5e2f04a60cf" alt="Setting up OneDrive Developer app" data-path="images/Msonedrive/onedrive_config.png" />

9. Navigate to `Certificates and Secrets` in the side menu and under **Client Secrets** tab, press the `+ New client secret` button. Give a **Description**, select the best expiry for your application and click `Add` to create your credentials.
10. Copy the displayed **Client Secret** under the `Value` column.

<img height="200" src="https://mintcdn.com/cobalt-55/wOGvLSncBaYd4o6C/images/Msonedrive/onedrive_credentials.png?fit=max&auto=format&n=wOGvLSncBaYd4o6C&q=85&s=6bb3eba2bd8c59c6f4897f7ea3e05286" alt="Getting Client Secret" data-path="images/Msonedrive/onedrive_credentials.png" />

11. Navigate to `Overview` in the side menu > `Essentials` tab > Copy the **Client ID** under `Application (client) ID`.

<img height="200" src="https://mintcdn.com/cobalt-55/wOGvLSncBaYd4o6C/images/Msonedrive/onedrive_id.png?fit=max&auto=format&n=wOGvLSncBaYd4o6C&q=85&s=5b570642c0fa2409edb4a5e75b9c3e99" alt="Getting Client ID" data-path="images/Msonedrive/onedrive_id.png" />

#### Configuring credentials in Refold

App settings page lets you configure the authentication settings for an `OAuth 2.0` based application. For your customers to provide you authorization to access their data,
they would first need to install your application. This page lets you set up your application credentials.

<img height="200" src="https://mintcdn.com/cobalt-55/wOGvLSncBaYd4o6C/images/Msonedrive/onedrive_cobalt.png?fit=max&auto=format&n=wOGvLSncBaYd4o6C&q=85&s=c72e05dabe3d0951760c6d38304dfdca" alt="Setting up application client credentials" data-path="images/Msonedrive/onedrive_cobalt.png" />

Provide the acquired Client ID and Client Secret under Settings of the app and save it.

#### Configuring Scopes

Refold lets you configure what permissions to ask from your users while they install your application. The scopes can be added or removed from the App settings page, under `Permissions & Scopes`
section.

For some applications Refold sets **mandatory scopes** which cannot be removed. Additional scopes can be selected from the drop down. Refold also has the provision to add any
custom scopes supported by the respective platform.

<img height="200" src="https://mintcdn.com/cobalt-55/wOGvLSncBaYd4o6C/images/Msonedrive/onedrive_scopes.png?fit=max&auto=format&n=wOGvLSncBaYd4o6C&q=85&s=77641b56b67745eaca8220c15e7fd1f7" alt="OAuth Scopes" data-path="images/Msonedrive/onedrive_scopes.png" />

Once the scopes has been added to the application in Refold, go to your [Microsoft Azure account](https://azure.microsoft.com/en-gb/) and update the scopes as added on Refold.

Select the OAuth App created for Refold and follow **Step 7** and **8** [above](https://docs.gocobalt.io/resources/integration-providers/ms_one_drive#creating-an-app-in-microsoft-azure).

<Warning>
  If you are facing scopes missing or invalid scope error. Make sure you are not passing any custom scope not supported by the platform. And, the scopes selected here are
  identical to the ones selected in the platform.
</Warning>

#### Actions and triggers

Once the above setup is completed, you can create orchestrations of your use-cases using OneDrive actions and triggers. Following are the set of OneDrive actions and triggers
supported by Refold.

<Tabs>
  <Tab title="Actions">
    <AccordionGroup>
      <Accordion title="File">
        1. **Get File** - Get a file from Microsoft OneDrive.
        2. **List Files** - List files in a OneDrive folder.
      </Accordion>

      <Accordion title="Folder">
        3. **Create Folder** - Create a new folder in Microsoft OneDrive.
        4. **Get Folder By Id** - Get a folder by its Id in Microsoft OneDrive.
        5. **Search Folders** - Search for folders in Microsoft OneDrive.
        6. **Move Folder** - Move a folder in Microsoft OneDrive.
        7. **Delete Folder** - Delete a folder in Microsoft OneDrive.
      </Accordion>

      <Accordion title="Upload File">
        8. **Upload a file using url** - Enter file name and hosted url to upload a file to your Microsoft OneDrive.
        9. **Upload using relative path to root or folderId** - Upload file using relative path in your Microsoft OneDrive.
      </Accordion>

      <Accordion title="Others">
        10. **HTTP Request** - Make HTTP API calls to any Microsoft OneDrive documented REST APIs.
      </Accordion>
    </AccordionGroup>
  </Tab>

  <Tab title="Triggers">
    There are no triggers in this application.
  </Tab>
</Tabs>
