# Description of Changes * Refactoring of SSO code around OAuth & SAML 2 * Enabling auto-login with SAML 2 via the new `SSOAutoLogin` property * Correcting typos & general cleanup --- ## Checklist ### General - [x] I have read the [Contribution Guidelines](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/CONTRIBUTING.md) - [x] I have read the [Stirling-PDF Developer Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/DeveloperGuide.md) (if applicable) - [x] I have read the [How to add new languages to Stirling-PDF](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/HowToAddNewLanguage.md) (if applicable) - [x] I have performed a self-review of my own code - [x] My changes generate no new warnings ### Documentation - [x] I have updated relevant docs on [Stirling-PDF's doc repo](https://github.com/Stirling-Tools/Stirling-Tools.github.io/blob/main/docs/) (if functionality has heavily changed) - [x] I have read the section [Add New Translation Tags](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/HowToAddNewLanguage.md#add-new-translation-tags) (for new translation tags only) ### UI Changes (if applicable) - [ ] Screenshots or videos demonstrating the UI changes are attached (e.g., as comments or direct attachments in the PR) ### Testing (if applicable) - [x] I have tested my changes locally. Refer to the [Testing Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/DeveloperGuide.md#6-testing) for more details.
73 lines
1.8 KiB
Java
73 lines
1.8 KiB
Java
package stirling.software.SPDF.model.provider;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.Collection;
|
|
|
|
import lombok.NoArgsConstructor;
|
|
import stirling.software.SPDF.model.UsernameAttribute;
|
|
|
|
@NoArgsConstructor
|
|
public class KeycloakProvider extends Provider {
|
|
|
|
private static final String NAME = "keycloak";
|
|
private static final String CLIENT_NAME = "Keycloak";
|
|
|
|
public KeycloakProvider(
|
|
String issuer,
|
|
String clientId,
|
|
String clientSecret,
|
|
Collection<String> scopes,
|
|
UsernameAttribute useAsUsername) {
|
|
super(
|
|
issuer,
|
|
NAME,
|
|
CLIENT_NAME,
|
|
clientId,
|
|
clientSecret,
|
|
scopes,
|
|
useAsUsername,
|
|
null,
|
|
null,
|
|
null,
|
|
null);
|
|
}
|
|
|
|
@Override
|
|
public String getName() {
|
|
return NAME;
|
|
}
|
|
|
|
@Override
|
|
public String getClientName() {
|
|
return CLIENT_NAME;
|
|
}
|
|
|
|
@Override
|
|
public Collection<String> getScopes() {
|
|
Collection<String> scopes = super.getScopes();
|
|
|
|
if (scopes == null || scopes.isEmpty()) {
|
|
scopes = new ArrayList<>();
|
|
scopes.add("profile");
|
|
scopes.add("email");
|
|
}
|
|
|
|
return scopes;
|
|
}
|
|
|
|
@Override
|
|
public String toString() {
|
|
return "Keycloak [issuer="
|
|
+ getIssuer()
|
|
+ ", clientId="
|
|
+ getClientId()
|
|
+ ", clientSecret="
|
|
+ (getClientSecret() != null && !getClientSecret().isBlank() ? "*****" : "NULL")
|
|
+ ", scopes="
|
|
+ getScopes()
|
|
+ ", useAsUsername="
|
|
+ getUseAsUsername()
|
|
+ "]";
|
|
}
|
|
}
|