diff options
author | Simon Brandhof <simon.brandhof@sonarsource.com> | 2017-06-23 21:31:56 +0200 |
---|---|---|
committer | Simon Brandhof <simon.brandhof@sonarsource.com> | 2017-06-25 23:42:50 +0200 |
commit | 70b6899988da0d2ba0a39b846e4f1bd3fa27304f (patch) | |
tree | 1ac093a87e0fba6b07c6feb6aceae89bdd9663cf /tests/plugins/oauth2-auth-plugin/src/main/java/FakeOAuth2IdProvider.java | |
parent | 5dd574819854e9ce7e2f4e181e78153a7ecbf828 (diff) | |
download | sonarqube-70b6899988da0d2ba0a39b846e4f1bd3fa27304f.tar.gz sonarqube-70b6899988da0d2ba0a39b846e4f1bd3fa27304f.zip |
Move integration tests to directory tests/
Diffstat (limited to 'tests/plugins/oauth2-auth-plugin/src/main/java/FakeOAuth2IdProvider.java')
-rw-r--r-- | tests/plugins/oauth2-auth-plugin/src/main/java/FakeOAuth2IdProvider.java | 104 |
1 files changed, 104 insertions, 0 deletions
diff --git a/tests/plugins/oauth2-auth-plugin/src/main/java/FakeOAuth2IdProvider.java b/tests/plugins/oauth2-auth-plugin/src/main/java/FakeOAuth2IdProvider.java new file mode 100644 index 00000000000..deb426145c4 --- /dev/null +++ b/tests/plugins/oauth2-auth-plugin/src/main/java/FakeOAuth2IdProvider.java @@ -0,0 +1,104 @@ +/* + * SonarQube + * Copyright (C) 2009-2017 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +import org.sonar.api.config.Settings; +import org.sonar.api.server.authentication.Display; +import org.sonar.api.server.authentication.OAuth2IdentityProvider; +import org.sonar.api.server.authentication.UnauthorizedException; +import org.sonar.api.server.authentication.UserIdentity; + +public class FakeOAuth2IdProvider implements OAuth2IdentityProvider { + + private static final String ENABLED = "sonar.auth.fake-oauth2-id-provider.enabled"; + private static final String ALLOWS_USERS_TO_SIGN_UP = "sonar.auth.fake-oauth2-id-provider.allowsUsersToSignUp"; + private static final String URL = "sonar.auth.fake-oauth2-id-provider.url"; + private static final String USER_INFO = "sonar.auth.fake-oauth2-id-provider.user"; + + private static final String THROW_UNAUTHORIZED_EXCEPTION = "sonar.auth.fake-oauth2-id-provider.throwUnauthorizedMessage"; + + private final Settings settings; + + public FakeOAuth2IdProvider(Settings settings) { + this.settings = settings; + } + + @Override + public void init(InitContext context) { + String url = settings.getString(URL); + if (url == null) { + throw new IllegalStateException(String.format("The property %s is required", URL)); + } + context.redirectTo(url); + } + + @Override + public void callback(CallbackContext context) { + String userInfoProperty = settings.getString(USER_INFO); + if (userInfoProperty == null) { + throw new IllegalStateException(String.format("The property %s is required", USER_INFO)); + } + boolean throwUnauthorizedException = settings.getBoolean(THROW_UNAUTHORIZED_EXCEPTION); + if (throwUnauthorizedException) { + throw new UnauthorizedException("A functional error has happened"); + } + + String[] userInfos = userInfoProperty.split(","); + context.authenticate(UserIdentity.builder() + .setLogin(userInfos[0]) + .setProviderLogin(userInfos[1]) + .setName(userInfos[2]) + .setEmail(userInfos[3]) + .build()); + context.redirectToRequestedPage(); + } + + @Override + public String getKey() { + return "fake-oauth2-id-provider"; + } + + @Override + public String getName() { + return "Fake oauth2 identity provider"; + } + + @Override + public Display getDisplay() { + return Display.builder() + .setIconPath("/static/oauth2authplugin/oauth2.png") + .setBackgroundColor("#444444") + .build(); + } + + @Override + public boolean isEnabled() { + return settings.getBoolean(ENABLED); + } + + @Override + public boolean allowsUsersToSignUp() { + if (settings.hasKey(ALLOWS_USERS_TO_SIGN_UP)) { + return settings.getBoolean(ALLOWS_USERS_TO_SIGN_UP); + } + // If property is not defined, default behaviour is not always allow users to sign up + return true; + + } + +} |