| At line 1 added one line | 
| \\ | 
| At line 4 added one line | 
| ---- | 
| At line 4 removed one line | 
| \\ | 
| At line 8 changed 5 lines | 
| \\ | 
| __!!! Proxy Configuration:__ If your server accesses the internet through a proxy, make sure to whitelist the following domains to allow authentication and Microsoft Graph API access:\\ | 
| •	login.microsoftonline.com\\ | 
| •	graph.microsoft.com\\ | 
| \\ | 
| ---- | 
| __⚠️ Proxy Configuration:__ If your server accesses the internet through a proxy, make sure to whitelist the following domains to allow authentication and Microsoft Graph API access:\\ | 
| • __login.microsoftonline.com__\\ | 
| • __graph.microsoft.com__\\ | 
| ---- | 
| At line 19 changed one line | 
| The Redirect URL must end with __"register_microsoft_graph_api/"__.\\ | 
| In the Redirect URI section, for Platform configuration, select __Web__. The Redirect URL must end with __register_microsoft_graph_api/__.\\ | 
| At line 25 added 2 lines | 
| or | 
| https://your.crushftp.domain.com/register_microsoft_graph_api/ | 
| At line 26 removed 6 lines | 
| or | 
| {{{ | 
|  | 
| https://your.crushftp.domain.com/register_microsoft_graph_api/ | 
|  | 
| }}}\\ | 
| At line 33 changed one line | 
| __Secret key__: A new client secret must be created. Go to Certificates & secrets, and generate a new client secret by clicking on New client secret. Ensure you copy over the __value__ immediately!\\ | 
| __Secret key__: A new client secret must be created. Go to Certificates & secrets, and generate a new client secret by clicking on New client secret. ⚠️ Ensure you copy over the __value__ immediately!\\ | 
| At line 39 removed one line | 
| \\ | 
| At line 42 added 3 lines | 
| ---- | 
| !1.1.1 Microsoft Graph Scopes for SharePoint Integration: | 
| ---- | 
| At line 56 changed one line | 
| __b.) Sites.FullControl.All__: Grants the application full control over all site collections in the tenant without user interaction. ( More info -> [Link|https://learn.microsoft.com/en-us/graph/permissions-reference#sites-permissions])\\ | 
| ---- | 
| __b.) Sites.FullControl.All__: Grants the application full control over all site collections in the tenant without user interaction. ( More info -> [Microsoft Graph permissions reference | 
| Link|https://learn.microsoft.com/en-us/graph/permissions-reference#sites-permissions])\\ | 
| At line 63 changed one line | 
| __Configure API Permission__: Navigate to API Permissions. Click on Add a permission button. Select __Microsoft Graph__. Then select __Application Permission__. Search for __Sites__ and check the flag Sites.FullControl.All permission.\\ | 
| ---- | 
| __c.) Sites.Selected__: Grants the application no access to SharePoint sites by default. However, you can explicitly grant access to specific sites by using the __Microsoft Graph API__. __⚠️ Important:__ The application must first be registered in Azure AD with the __Sites.Selected__ application permission. More information is available at the following link: [Managing SharePoint Site Access for Applications Using Sites.Selected Permission|CrushTaskExample19].\\ | 
| At line 65 removed 2 lines | 
| __c.) Sites.Selected__: Grants the application no access to SharePoint sites by default. However, you can explicitly grant access to specific sites by using the Microsoft Graph API. More information is available at the following link: [Managing SharePoint Site Access for Applications Using Sites.Selected Permission|CrushTaskExample19].\\ | 
| \\ | 
| At line 70 added one line | 
| ---- | 
| At line 71 changed one line | 
| Grant __Admin consent__ for the newly added permission.\\ | 
| __⚠️ Important:__ Grant __Admin consent__ for the newly added permission.\\ | 
| At line 79 changed one line | 
| __Sharepoint VFS item configuration:__\\ | 
| !1.1.2 Sharepoint VFS item configuration (Application Permission):\\ | 
| At line 81 changed one line | 
| Select the __Application Permission__ radio button, then click __Application Permission__. Enter the __Client ID__ (See at App Registration -> Overview -> Application (client) ID), __Client Secret__ (See at App Registration -> Manage -> Certificates & secrets) make sure to copy the __value__ field, not the ID, and __Tenant ID__ (See at App Registration -> Overview -> Directory (tenant) ID), then click OK. This will automatically configure the username and password in the VFS item settings. After that, proceed with the SharePoint site-specific configuration.\\ | 
| Select the __Application Permission__ radio button, then click __Application Permission__.\\ | 
| At line 84 added 2 lines | 
| Enter the __Client ID__ (See at App Registration -> Overview -> Application (client) ID), __Client Secret__ (See at App Registration -> Manage -> Certificates & secrets) make sure to copy the __value__ field, not the ID, and __Tenant ID__ (See at App Registration -> Overview -> Directory (tenant) ID), then click OK. This will automatically configure the __username__ and __password__ in the [VFS] item settings. After that, click the __OK__ button and proceed with the SharePoint site-specific configuration.\\ | 
| \\ | 
| At line 92 changed one line | 
| \\ | 
| !1.2.1 Microsoft Graph Scopes for SharePoint Integration:# | 
| ---- | 
| At line 104 added one line | 
| ---- | 
| At line 101 changed one line | 
| __b.) Sites.FullControl.All__: Grants the application full control over all site collections in the tenant without user interaction. ( More info: [Link|https://learn.microsoft.com/en-us/graph/permissions-reference#sites-permissions])\\ | 
| __b.) Sites.FullControl.All__: Grants the application full control over all site collections in the tenant without user interaction. ( More info: [Microsoft Graph permissions reference | 
| Link|https://learn.microsoft.com/en-us/graph/permissions-reference#sites-permissions])\\ | 
| At line 116 added one line | 
| ---- | 
| At line 124 added one line | 
| ---- | 
| At line 118 changed one line | 
| Grant __Admin consent__ for the newly added permission.\\ | 
| ⚠️ Grant __Admin consent__ for the newly added permission.\\ | 
| At line 126 changed one line | 
| __SharePoint remote item settings:__\\ | 
| !1.2.1 SharePoint remote item settings (Delegated Permission):\\ | 
| At line 128 changed one line | 
| __!!! Note__: To obtain the __Refresh Token__, the CrushFTP WebInterface’s host and port must match the __Redirect URL__ specified in the __Azure App Registration__. In our example, it was: http://localhost:9090 or https://your.crushftp.domain.com/\\ | 
| __⚠️ Important__: To obtain the __Refresh Token__, the CrushFTP WebInterface’s host and port must match the __Redirect URL__ specified in the __Azure App Registration__. In our example, it was: http://localhost:9090 or https://your.crushftp.domain.com/\\ | 
| At line 130 changed one line | 
| Select the __Delegated Permission__ radio button, then click __Get Refresh Token__. Enter the __Client ID__ (See at App Registration -> Overview -> Application (client) ID), __Client Secret__ (See at App Registration -> Manage -> Certificates & secrets) make sure to copy the __value__ field, not the ID, and __Tenant ID__ (See at App Registration -> Overview -> Directory (tenant) ID). Proceed with the authentication and authorization process. This will automatically configure the username and password in the VFS item settings. After that, proceed with the SharePoint site-specific configuration.\\ | 
| Select the __Delegated Permission__ radio button, then click __Get Refresh Token__.\\ | 
| Enter the __Client ID__ (See at App Registration -> Overview -> Application (client) ID), __Client Secret__ (See at App Registration -> Manage -> Certificates & secrets) make sure to copy the __value__ field, not the ID, and __Tenant ID__ (See at App Registration -> Overview -> Directory (tenant) ID).\\ | 
| Click the __OK__ button and proceed with the authentication and authorization process.\\ | 
| __⚠️ Important__: Be sure to sign in with the Microsoft Account that has the necessary permissions, as configured in the Azure App Registration mentioned above.\\ | 
| This will automatically configure the username and password in the VFS item settings. After that, proceed with the SharePoint site-specific configuration.\\ | 
| At line 155 changed 3 lines | 
| !!! 2. SharePoint REST service API-based integration\\ | 
| \\ | 
| __!!! Remote item name:__ Sharepoint2\\ | 
| ---- | 
| !!! 2. SharePoint REST service API-based integration (Remote protocol: Sharepoint2)\\ | 
| __⚠️ Remote item name:__ Sharepoint2\\ | 
| At line 159 changed 5 lines | 
| \\ | 
| __!!! Proxy Configuration:__ If your server accesses the internet through a proxy, make sure to whitelist the following domains:\\ | 
| • login.microsoftonline.com\\ | 
| • <yourtenant>.sharepoint.com — for accessing SharePoint site collections\\ | 
| \\ | 
| ---- | 
| __⚠️ Proxy Configuration:__ If your server accesses the internet through a proxy, make sure to whitelist the following domains:\\ | 
| • __login.microsoftonline.co__m\\ | 
| • __<yourtenant>.sharepoint.com__ — for accessing SharePoint site collections\\ | 
| ---- | 
| At line 165 removed one line | 
| \\ | 
| At line 172 changed one line | 
| The Redirect URL must end with __"register_microsoft_graph_api/"__. Examples:\\ | 
| In the Redirect URI section, for Platform configuration, select __Web__. The Redirect URL must end with __register_microsoft_graph_api/__. Examples:\\ | 
| At line 176 changed 3 lines | 
| }}}\\ | 
| or \\ | 
| {{{ | 
| or | 
| At line 184 changed one line | 
| Only __Delegated__ permission types are supported. __CrushFTP__ only supports authentication using a __client secret__ — certificate-based authentication is not supported.\\ | 
| Only __Delegated__ permission types are supported. __CrushFTP__ only supports authentication using a __client secret__ — ⚠️ certificate-based authentication is not supported.\\ | 
| At line 195 added one line | 
| ---- | 
| At line 200 added one line | 
| ---- | 
| At line 201 changed one line | 
| __c.) SharePoint.Sites.Selected__: The __Sites.Selected__ permission allows an app to access only the specific SharePoint sites you explicitly authorize. More information is available at the following link: [Managing SharePoint Site Access for Applications Using Sites.Selected Permission|CrushTaskExample19].\\ | 
| ---- | 
| __c.) SharePoint.Sites.Selected__: The __Sites.Selected__ permission allows an app to access only the specific SharePoint sites you explicitly authorize. __⚠️ Important:__ The application must first be registered in Azure AD with the Sites.Selected application permission. More information is available at the following link: [Managing SharePoint Site Access for Applications Using Sites.Selected Permission|CrushTaskExample19].\\ | 
| At line 218 added one line | 
| ---- | 
| At line 207 changed one line | 
| Grant __Admin consent__ for the newly added permission.\\ | 
| ⚠️ Grant __Admin consent__ for the newly added permission.\\ | 
| At line 211 changed one line | 
| __Secret key__: A new client secret must be created. Go to __Certificates & secrets__, and generate a new client secret by clicking on __New client secret__. Ensure you copy over the __value__ immediately!\\ | 
| __Secret key__: A new client secret must be created. Go to __Certificates & secrets__, and generate a new client secret by clicking on __New client secret__. ⚠️ Ensure you copy over the __value__ immediately!\\ | 
| At line 219 changed one line | 
| __!!! Note__: To obtain the __Refresh Token__, the CrushFTP WebInterface’s host and port must match the __Redirect URL__ specified in the __Azure App Registration__. In our example, it was: http://localhost:9090 or https://your.crushftp.domain.com/\\ | 
| __⚠️ Important__: To obtain the __Refresh Token__, the CrushFTP WebInterface’s host and port must match the __Redirect URL__ specified in the __Azure App Registration__. In our example, it was: http://localhost:9090 or https://your.crushftp.domain.com/\\ | 
| At line 221 changed one line | 
| Click on __Get Refresh Token__. Enter the __Client ID__ (See at App Registration -> Overview -> Application (client) ID), __Client Secret__ (See at App Registration -> Manage -> Certificates & secrets) make sure to copy the __value__ field, not the ID, and __Tenant ID__ (See at App Registration -> Overview -> Directory (tenant) ID). Proceed with the authentication and authorization process. This will automatically configure the username and password in the VFS item settings. After that, proceed with the SharePoint site-specific configuration.\\ | 
| Click on __Get Refresh Token__.\\ | 
| Enter the __Client ID__ (See at App Registration -> Overview -> Application (client) ID), __Client Secret__ (See at App Registration -> Manage -> Certificates & secrets) make sure to copy the __value__ field, not the ID, and __Tenant ID__ (See at App Registration -> Overview -> Directory (tenant) ID).\\ | 
| click the __OK__ button and proceed with the authentication and authorization process.\\ | 
| __⚠️ Important__: Be sure to sign in with the Microsoft Account that has the necessary permissions, as configured in the Azure App Registration mentioned above.\\ | 
| This will automatically configure the username and password in the VFS item settings. After that, proceed with the SharePoint site-specific configuration.\\ | 
| At line 231 changed one line | 
| __!!!Constraint:__ On newer Sharepoint (after 2019) Grant App permission as it is disabled by default. To enable Custom Application APP Authentication run the following PowerShell commands:\\ | 
| __⚠️ Constraint:__ On newer Sharepoint (after 2019) Grant App permission as it is disabled by default. To enable Custom Application APP Authentication run the following PowerShell commands:\\ | 
| At line 292 changed one line | 
| __Drive name__: Each SharePoint site has a Document Library where the site-related files are stored. See [SharePoint: Documents and Libraries Description Link||https://support.microsoft.com/en-us/office/what-is-a-document-library-3b5976dd-65cf-4c9e-bf5a-713c10ca2872] Provide its name\\ | 
| __Drive name__: Each SharePoint site has a Document Library where the site-related files are stored. See [SharePoint: Documents and Libraries Description Link|https://support.microsoft.com/en-us/office/what-is-a-document-library-3b5976dd-65cf-4c9e-bf5a-713c10ca2872] Provide its name\\ |