diff options
Diffstat (limited to 'tests/plugins/oauth2-auth-plugin/src')
-rw-r--r-- | tests/plugins/oauth2-auth-plugin/src/main/java/FakeOAuth2AuthPlugin.java | 32 | ||||
-rw-r--r-- | tests/plugins/oauth2-auth-plugin/src/main/java/FakeOAuth2IdProvider.java | 104 | ||||
-rw-r--r-- | tests/plugins/oauth2-auth-plugin/src/main/resources/static/oauth2.png | bin | 0 -> 2087 bytes |
3 files changed, 136 insertions, 0 deletions
diff --git a/tests/plugins/oauth2-auth-plugin/src/main/java/FakeOAuth2AuthPlugin.java b/tests/plugins/oauth2-auth-plugin/src/main/java/FakeOAuth2AuthPlugin.java new file mode 100644 index 00000000000..5fa419d3289 --- /dev/null +++ b/tests/plugins/oauth2-auth-plugin/src/main/java/FakeOAuth2AuthPlugin.java @@ -0,0 +1,32 @@ +/* + * 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 java.util.ArrayList; +import java.util.List; +import org.sonar.api.SonarPlugin; + +public final class FakeOAuth2AuthPlugin extends SonarPlugin { + + public List getExtensions() { + List extensions = new ArrayList(); + extensions.add(FakeOAuth2IdProvider.class); + return extensions; + } + +} 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; + + } + +} diff --git a/tests/plugins/oauth2-auth-plugin/src/main/resources/static/oauth2.png b/tests/plugins/oauth2-auth-plugin/src/main/resources/static/oauth2.png Binary files differnew file mode 100644 index 00000000000..28a3e01698c --- /dev/null +++ b/tests/plugins/oauth2-auth-plugin/src/main/resources/static/oauth2.png |