Add new attachment

Only authorized users are allowed to upload new attachments.

List of attachments

Kind Attachment Name Size Version Date Modified Author Change note
png
oidc_crushftp_related_settings... 137.0 kB 1 09-Jan-2025 07:29 krivacsz
png
oidc_dmz_plugin_settings.png 141.0 kB 2 09-Jan-2025 23:13 krivacsz
png
oidc_general_plugin_settings.p... 39.3 kB 1 09-Jan-2025 07:32 krivacsz
png
oidc_idp_related_plugin_settin... 176.0 kB 3 09-Jan-2025 23:17 krivacsz
png
oidc_login_buttons.png 59.4 kB 1 09-Jan-2025 07:50 krivacsz

This page (revision-295) was last changed on 10-Jan-2025 02:22 by krivacsz

This page was created on 06-Jan-2025 23:39 by krivacsz

Only authorized users are allowed to rename pages.

Only authorized users are allowed to delete pages.

Difference between version and

At line 7 changed 4 lines
The plugin requires the following IdP information and configuration:\\
• Client ID\\
• Client Secret: Authorization Code Flow requires it.\\
• Redirect URL: The redirect URL is the endpoint in your IdP application where the IdP directs the user after successful authentication. This URL receives the authorization code or access token as part of the authentication process. The redirect URL must target the CrushFTP server and conclude with __/SSO_OIDC/__. Like:\\
The plugin requires the following information and configurations from the IdP's __App Registration__:\\
• __Client ID__\\
• __Client Secret__: Authorization Code Flow requires it.\\
• __Redirect URL__: The redirect URL is the endpoint in your IdP application where the IdP directs the user after successful authentication. This URL receives the authorization code or access token as part of the authentication process. The redirect URL must target the CrushFTP server and conclude with __/SSO_OIDC/__. Like:\\
At line 15 changed one line
Google: [https://support.google.com/googleapi/answer/6158849]\\
__Google__: Refer to the App registration section under: [SMTP Google Mail Integration] ensure the redirect URL is described above.\\
At line 17 changed one line
!!!2. Plugin Configuration\\
__Microsoft__: Refer to the App registration (Ondrive Personal) section under: [OneDriveSetup] ensure the redirect URL is described above.\\
__Microsoft B2C__: Refer to the App registration section under: [Azure Active Directory B2C Configuration] ensure the redirect URL is described above.\\
At line 20 added 6 lines
__Amazon Cognito__: Refer to the App registration section under: [Amazon Cognito Configuration] ensure the redirect URL is described above.\\
\\
__Dropbox__: Refer to the App registration section under: [Dropbox Integration] ensure the redirect URL is described above.\\
\\
!!!2. Plugin Configuration\\
At line 27 changed 2 lines
This HTTP URL is part of the OpenID Connect (OIDC) Discovery mechanism. It follows a standard called __RFC 5785__ ([https://datatracker.ietf.org/doc/html/rfc5785]), which defines the use of __.well-known__ URIs for discovering metadata about services. It queries this HTTP endpoint to configure itself dynamically, avoiding hard-coded values. The retrieved JSON document includes important endpoints and details like:\\
• Authorization endpoint\\
This HTTPS URL is part of the OpenID Connect (OIDC) Discovery mechanism. It follows a standard called __RFC 5785__ ([https://datatracker.ietf.org/doc/html/rfc5785]), which defines the use of __.well-known__ URIs for discovering metadata about services. It queries this HTTP endpoint to configure itself dynamically, avoiding hard-coded values. The retrieved JSON document includes important endpoints and details like:\\
• Authorization endpoint {{''__(Required)__''}}\\
At line 52 changed one line
The JSON file should include the __authorization endpoint__. Example for Box cloud storage:
The JSON file should include the __authorization endpoint__ ({{''__(Required)__''}}). Example for Box cloud storage:
At line 62 changed one line
__Client ID__: Provide the Client ID (the unique identifier) of your IdP.\\
__Client ID__: Provide the Client ID (the unique identifier of your IdP's App registration) of your IdP.\\
At line 86 changed one line
__Get Refresh Token__: It is used to access the user's cloud storage through the IdP. It adjusts the __Authorization URL__ by appending the following parameters:\\
__Get Refresh Token__: It is used for access the user's cloud storage through the IdP. It adjusts the __Authorization URL__ by appending the following parameters:\\
At line 100 changed one line
__Microsoft__ does not require additional scopes for this purpose. Ensure that the __App Registration__ includes the __"Files.ReadWrite.All"__ permission, configured as either Delegated or Application. More info at [SharePoint Integration].\\
__Microsoft Azure App Registration__ does not require additional scopes for this purpose. Ensure the __App Registration__ includes the __"Files.ReadWrite.All"__ permission, configured as either Delegated or Application. More info at [SharePoint Integration].\\
At line 124 added 6 lines
__Special Case for Microsoft Azure AD:__ When using __Microsoft Azure AD__ as the Identity Provider (IdP), a specific user endpoint is required to retrieve group information for the authenticated user:\\
{{{
https://graph.microsoft.com/v1.0/me
}}}
In this scenario, the plugin makes __an additional API call to this endpoint__ to fetch the user's __group membership__ details. The App registration must include the __Group.Read.All__ permission to enable access to group information.\\
\\
At line 155 changed one line
!2.2.3.1 Skip OTP processing\\
!2.2.3.1 Skip OTP processing:\\
At line 157 changed one line
CrushOIDC plugin is not compatible with [OTP Settings] as IDP (identity provider) can have its own two-factor authentication. Turning the flag to true will skip plugin users from CrushFTP's OTP process.
CrushOIDC plugin is not compatible with [OTP Settings], as the IdP may implement its own two-factor authentication. Enabling this flag will exclude plugin users from CrushFTP's OTP process.
At line 172 added 87 lines
!2.2.3.2 Remove email suffix from username:\\
\\
It removes the email suffix from the username. For example, the username "my_user@email.com" will be transformed to "my_user".\\
\\
!2.2.4 OpenID/OAuth only used for Authentication:\\
\\
It is useful when user accounts are already defined and managed within CrushFTP's [User Manager], you can leverage the CrushOIDC plugin to authenticate users against external Identity Providers. This allows existing users to utilize OIDC for login while maintaining their existing user accounts and access privileges as defined within CrushFTP.\\
\\
!2.2.5 User Templates {{''__(Required)__''}}:\\
\\
__Template Username__: The signed-in user inherits both the settings and the VFS items(as Linked [VFS]). __It must have a value!__\\
__Import settings from CrushFTP user__: The signed-in user inherits only the settings from the specified user. __It must have a value!__\\
\\
__Default value__: default (the default user of CrushFTP)\\
\\
!2.2.6 Roles:\\
\\
__Authentication aspect__: Permit users based on specific IdP claims. \\
\\
__!!! Important__: If roles are configured and the IdP's user does not match any of the predefined roles, the authentication will be rejected due to the absence of matching roles.\\
\\
__Template User Aspect__: You can configure different Template Users (see 2.2.5 User Templates) based on IdP claims. If a template user is specified, the signed-in user inherits both the settings and the VFS items (as Linked [VFS]).\\
__!!! Important__: Template user must exist in the [User Manager], otherwise, it will have no effect.\\
\\
__IdP Attribute Value__ -> Supports different types of matching:\\
• __Exact Match__: Matches the value exactly as provided.\\
• __Simple Match__: Use patterns like __*mail.com*__ to match substrings.\\
• __Regex Match__: Use the format __REGEX:<<your-regular-expression>>__ for more complex patterns.\\
\\
Role examples :
{{{
<<IDP attribute name>>=<<IDP attribute value>> : << the template user name>>
or multiple values separated by a comma
<<IDP attribute name>>=<<IDP attribute value>>,<<IDP attribute name>>=<<IDP attribute value>> : << the template user name>>
Like:
groups=Azure_SAML : temp_OIDC_azure_user
or
groups=*SAML*
or
groups=REGEX:.*SAML$
or
groups=Azure_SAML,groups:test_group_one
or
groups=*SAML*,groups:test_group_one
or
groups=REGEX:.*SAML$,groups:test_group_one
}}}
\\
If the attribute value is an array, you can reference only one element for an exact match. Example: If the IDP attribute value is __:\\
{{{
[groups:"group1", "group2"] -> you can match with "group1".
}}}\\
\\
!2.2.7 Custom VFS {{''__(Required Under Specific Conditions)__''}}:
\\
[VFS] related settings. You can configure a custom [VFS] for CrushOIDC users.\\
__!!! Important:__ If the CrushOIDC user has no assigned VFS, __authentication will be rejected due to the absence of an assigned [VFS]__. CrushOAIDC user can inherit VFS configuration from:\\
• Template User (see at __2.2.5 User Templates__)\\
• Roles (Like at __2.2.6 Roles__)\\
• Custom VFS\\
\\
Custom VFS example using plugin settings and refresh token from OpenID connect:\\
{{{
GDrive: gdrive://{oidc_client_id}~{oidc_client_secret_decoded}:{oidc_refresh_token}@www.google.com/
OneDrive: onedrive://{oidc_client_id}~{oidc_client_secret_encoded}:{oidc_refresh_token}@graph.microsoft.com/
DropBox: dropbox://{oidc_client_id}~{oidc_client_secret_decoded}:{oidc_refresh_token}@api.dropboxapi.com/
}}}\\
\\
!3. DMZ\\
\\
[CrushOIDC/oidc_dmz_plugin_settings.png]\\
\\
The DMZ's CrushOIDC plugin has a slightly different UI because IdP user validation is handled exclusively on the internal node. To function properly, the __DMZ must replicate the internal node's settings__ for the following parameters:\\
\\
• Plugin name\\
• OpenID Configuration URL\\
• Client ID\\
• Client Secret (Optional): Only if it is required for the authorization url.\\
• Authorization URL\\
• Scope\\
• Get Refresh Token\\
• Login button text\\
\\
Version Date Modified Size Author Changes ... Change note
295 10-Jan-2025 02:22 16.941 kB krivacsz to previous
294 10-Jan-2025 02:12 16.94 kB krivacsz to previous | to last
293 10-Jan-2025 02:04 16.917 kB krivacsz to previous | to last
292 10-Jan-2025 02:01 16.886 kB krivacsz to previous | to last
291 09-Jan-2025 23:55 16.877 kB krivacsz to previous | to last
290 09-Jan-2025 23:50 16.717 kB krivacsz to previous | to last
289 09-Jan-2025 23:45 16.543 kB krivacsz to previous | to last
288 09-Jan-2025 23:39 16.386 kB krivacsz to previous | to last
287 09-Jan-2025 23:38 16.383 kB krivacsz to previous | to last
286 09-Jan-2025 23:35 16.361 kB krivacsz to previous | to last
285 09-Jan-2025 23:27 16.349 kB krivacsz to previous | to last
284 09-Jan-2025 23:26 16.349 kB krivacsz to previous | to last
283 09-Jan-2025 23:24 16.346 kB krivacsz to previous | to last
282 09-Jan-2025 23:23 16.348 kB krivacsz to previous | to last
281 09-Jan-2025 23:22 16.342 kB krivacsz to previous | to last
« This page (revision-295) was last changed on 10-Jan-2025 02:22 by krivacsz
G’day (anonymous guest)
CrushFTP11 | What's New

Referenced by
CrushOAuth
LeftMenu

JSPWiki