\\
The plugin supports __OpenID Connect SSO__ ( more info: [https://en.wikipedia.org/wiki/OpenID]), an authentication protocol built on top of the OAuth 2.0 ([https://en.wikipedia.org/wiki/OAuth]) authorization framework.\\
\\
__!!! Constraints__: It only works through __HTTP__ or __HTTPS__ protocol. __Authorization Code Flow__ is supported (Implicit Flow or Hybrid Flow are not supported). It requires __Enterprise License__.\\
\\
!!!1. Identity Provider's (IdP) general configuration\\
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:\\
{{{
https://your.domain.com/SSO_OIDC/
}}}\\
\\
Google: [https://support.google.com/googleapi/answer/6158849]\\
\\
!!!2. Plugin Configuration\\
\\
!!2.1 IdP related settings\\
\\
[attachments|CrushOIDC/oidc_idp_related_plugin_settings.png]\\
\\
!2.1.1 OpenID Configuration URL {{''__(Required)__''}}: \\
\\
__Dynamic endpoint:__\\
\\
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\\
•	Token endpoint\\
•	User info endpoint\\
•	Supported scopes and claims\\
•	Public keys for verifying tokens\\
\\
List of __.well-known__ URLs for various identity providers and services that support OpenID Connect (OIDC):\\
{{{
Google:              https://accounts.google.com/.well-known/openid-configuration
Microsoft Azure AD:  https://login.microsoftonline.com/{tenant_id}/v2.0/.well-known/openid-configuration
Microsoft Azure B2C: https://{tenant_name}.b2clogin.com/{tenant_name}.onmicrosoft.com/{policy}/v2.0/.well-known/openid-configuration
Amazon (Cognito):    https://cognito-idp.{region}.amazonaws.com/{userPoolId}/.well-known/openid-configuration
Okta:                https://{yourOktaDomain}/.well-known/openid-configuration
Auth0:               https://{yourDomain}.auth0.com/.well-known/openid-configuration
Dropbox:             https://www.dropbox.com/.well-known/openid-configuration
}}}\\
\\
__Local endpoint:__\\
\\
You can reference a __local JSON file__ if the identity provider (IdP) does not support OpenID Connect but does support __OAuth 2.0__ (like Box cloud storage). Instead of specifying an HTTP URL, provide the path to a local JSON file, such as:\\
{{{
./box_open_id_config.json
}}}\\
\\
The JSON file should include the __authorization endpoint__. Example for Box cloud storage:
{{{
{
	"authorization_endpoint":"https://account.box.com/api/oauth2/authorize",
	"token_endpoint":"https://api.box.com/oauth2/token"
}
}}}
\\
!2.1.2 App registration related informations:\\
\\
__Client ID__: Provide the Client ID (the unique identifier) of your IdP.\\
__Client Secret__: Provide the Client Secret of your IdP.\\
\\
!2.1.3 Authorization related settings {{''__(Required)__''}}:\\
\\
__Authorization URL__: It is the endpoint where IdP initiates the authentication and authorization process. The default configuration would be:\\
{{{
{authorization_endpoint}?client_id={oidc_client_id}&response_type=code&scope={oidc_scope}&redirect_uri={oidc_redirect_url}&state={oidc_state}
}}}\\
\\
Variables:\\
• {authorization_endpoint}: Authorization URL of IdP, retrieved from the OpenID Configuration JSON.\\
• {oidc_client_id}: Client ID assigned by the IdP during app registration. Retrieved from plugin's "Client ID" setting.\\
• {oidc_scope}: Specifies the "Scope"(s) provided by the plugin to determine the level of access.\\
• {oidc_redirect_url}:  An autogenerated URL by CrushFTP, composed of the initial host and port, followed by __/SSO_IDC/__.  This URL is used to redirect the user after successful authentication. __!!! It must exactly match the redirect URL registered and configured in the IdP.__\\
• {oidc_state}: An autogenerated value by CrushFTP to maintain the state between the authentication request and callback. This is used to prevent CSRF attacks. \\
\\
__Scope__:  It defines the permissions or access levels requested by CrushFTP during the authentication process. The scopes determine the type of information (claims) IdP will include in the ID token and what resources the client application can access. (like user profile information, email address, and cloud storage access). Commonly supported scope values include:\\
{{{
openid profile email
}}}
\\
__Scope Suggestions__: Displays possible scope values based on the OpenID configuration data.\\
\\
__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:\\
{{{
access_type=offline&prompt=consent
}}}\\
\\
• The __access_type=offline__ parameter is used in the Authorization URL in OpenID Connect (OIDC) and OAuth 2.0 flows to request a refresh token from the IdP. A refresh token allows the application to obtain new access tokens without requiring the user to log in again, enabling offline access.\\
__The refresh token enables access to the user's cloud storage through the IdP. __CrushFTP supports cloud storage integration with services such as Google Drive ([GDriveSetup]), OneDrive ([OneDriveSetup]), SharePoint ([SharePoint Integration]), and Dropbox ([Dropbox Integration]).\\
\\
When integrating cloud storage, ensure the __"Scope"__ parameter includes the __necessary permissions for accessing the user's cloud storage__. Add the following scopes for the respective services:\\
{{{
Google: https://www.googleapis.com/auth/drive
Dropbox: files.metadata.write files.content.write files.content.read
}}}\\
\\
__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].\\
\\
At "__Custom VFS__" settings you can reference the gained __refresh token__ as variable:
{{{
{oidc_refresh_token}
}}}
\\
• The __prompt=consent__ parameter is used in the authorization URL to explicitly request the user's consent during the authentication process. This parameter __ensures that the Identity Provider (IdP) displays a consent screen__, even if the user has previously authorized the application.\\
\\
__Verify ID Token:__ The Authorization Code Flow uses the code value returned by the IdP to obtain the ID token. Although this step is not mandatory in the OpenID protocol, you can enable an additional verification of the returned ID token by selecting this checkbox. __!!!__ This feature works only if the OpenID configuration includes the "__jwks_uri__" endpoint. __It provides an extra layer of validation for the ID token.__\\
\\
!2.1.4 IdP User endpoint:\\
\\
__Check User Endpoint URL?__: This option enables CrushFTP to retrieve additional information about the user from the IdP via the "__user_info__" endpoint URL. __!!!__ This feature only works if the OpenID configuration includes a "userinfo_endpoint" URL or if you manually specify it in the "__User Endpoint URL__" input field. \\ 
\\
The __"userinfo_endpoint"__ is a key component of the OpenID Connect (OIDC) protocol, providing a standardized way to __retrieve additional user information from the IdP__ after authentication. It complements the information included in the ID token by allowing the client application to fetch more detailed and up-to-date user attributes.\\
\\
__Revocation Endpoint URL__: The revocation endpoint is an __optional endpoint__ in OIDC and OAuth 2.0 that allows client applications to __revoke access tokens and refresh tokens issued by the IdP__. Revoking a token ensures that it can no longer be used to access protected resources or obtain new tokens.\\
\\
__Refresh Token__: The refresh token will be revoked at the __end of the CrushFTP session__.\\
__Access Token__:\\
    - If __no refresh token is retrieved__, the access token will be revoked during __the plugin authentication process__.\\
    - If a __refresh token is present__, only the refresh token will be revoked, as __revoking the access token inherently invalidates any associated refresh tokens sent by the IdP__.\\
\\
!2.1.6 Claim and IdP session related configs:\\
\\
__Claim as Username__ {{''__(Required)__''}}: Specify the name of the claim within the IdP's response that should be used as the __username for the CrushFTP session__.
\\
__!!!__ If this claim is not present or its value is missing in the IdP's response (either within the ID Token or retrieved from the user endpoint), __the authentication will fail due to a missing username__.\\ 
\\
__Claim Suggestions__: Displays possible claim values based on the OpenID configuration data.\\
\\
__End Session URL__:  This URL is called at __the end of the CrushFTP session__ to terminate the user's session. You can use the "end_session_endpoint" provided in the OpenID configuration data by referencing it as the variable __{end_session_endpoint}__, or you can specify the URL manually.\\
\\
!!2.2 CrushFTP related plugin settings:\\
\\
[CrushOIDC/oidc_general_plugin_settings.png]\\
\\
__Enable__: Activate the plugin. {{''__(Required)__''}}\\
__Debug__:  Enable detailed logging of plugin activities. This helps troubleshoot issues. Set the debug level to 1 and at "Log File Options" check the flag "GENERAL" (see [Logging]).\\
__Allowed Servers/Groups__: Each plugin instance can restrict the allowed users to certain Server Ports or Sever Connection Groups (see [IP Servers]). To deselect the currently selected option, use __ALT + Click__ (or __⌥ + Click__ on macOS).\\
\\
[CrushOIDC/oidc_crushftp_related_settings.png]\\
\\
!2.2.1 Login Button {{''__(Required)__''}}:\\
\\
__Login button text__: Specify the text to display on the login button. This button will only be visible on the designated "Server Port."(allowed at "Allowed Servers/Groups") Users can authenticate through multiple Identity Providers by configuring multiple CrushOIDC plugin instances. Like:\\
[CrushOIDC/oidc_login_buttons.png]\\
\\
!2.2.2 Username matching {{''__(Required)__''}}:\\
\\
 It filters usernames based on the value configured in __"Username matching"__. The default value (*) allows all users. Multiple values can be specified, separated by commas. Domain filtering is also supported (Like: *mydomain.com).\\
\\
IdPs that do not support tenant-based app registrations generally use a global, centralized app registration model. In such cases, applications are registered once and are not tied to a specific tenant or organizational boundary. To manage access effectively, domain filtering is often necessary (Like: Google, Dropbox).
\\
!2.2.3.1 Skip OTP processing:\\
\\
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.
\\
!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:\\ 
\\
([User Manager] defines user's access.) -> If users already exist in CrushFTP's User Manager, you can use the CrushOIDC plugin __just for authentication__.
\\
!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's claim. \\
\\
__!!! 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 the template user is provided the signed-in user inherits both the settings and the VFS items (as Linked [VFS]).\\
\\
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 
}}}
\\
__!!! 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.\\
__!!! Important__: Template user must exist on [User Manager], otherwise, it will have no effect.\\
\\