
com.stormpath.sdk.servlet.mvc.IdSiteController Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of stormpath-sdk-servlet Show documentation
Show all versions of stormpath-sdk-servlet Show documentation
Servlet-specific additions allowing one to more easily deploy the Stormpath SDK in a servlet-container-based
web application.
The newest version!
/*
* Copyright 2015 Stormpath, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.stormpath.sdk.servlet.mvc;
import com.stormpath.sdk.application.Application;
import com.stormpath.sdk.idsite.IdSiteUrlBuilder;
import com.stormpath.sdk.lang.Assert;
import com.stormpath.sdk.lang.Strings;
import com.stormpath.sdk.servlet.account.AccountResolver;
import com.stormpath.sdk.servlet.application.ApplicationResolver;
import com.stormpath.sdk.servlet.filter.ServerUriResolver;
import com.stormpath.sdk.servlet.http.Resolver;
import com.stormpath.sdk.servlet.idsite.IdSiteOrganizationContext;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class IdSiteController extends AbstractController {
private ServerUriResolver serverUriResolver;
private String callbackUri;
private String idSiteUri;
private String alreadyLoggedInUri = null;
private Resolver idSiteOrganizationResolver;
public void setServerUriResolver(ServerUriResolver serverUriResolver) {
this.serverUriResolver = serverUriResolver;
}
public void setCallbackUri(String callbackUri) {
this.callbackUri = callbackUri;
}
public void setIdSiteUri(String idSiteUri) {
this.idSiteUri = idSiteUri;
}
public void setAlreadyLoggedInUri(String alreadyLoggedInUri) {
this.alreadyLoggedInUri = alreadyLoggedInUri;
}
public void setIdSiteOrganizationResolver(Resolver idSiteOrganizationResolver) {
this.idSiteOrganizationResolver = idSiteOrganizationResolver;
}
public void init() {
Assert.notNull(serverUriResolver, "serverUriResolver must be configured.");
Assert.notNull(callbackUri, "callbackUri must be configured.");
Assert.notNull(idSiteOrganizationResolver, "idSiteOrganizationResolver must be configured.");
Assert.notNull(alreadyLoggedInUri, "alreadyLoggedInUri must be configured.");
}
@Override
public boolean isNotAllowedIfAuthenticated() {
return false;
}
protected Application getApplication(HttpServletRequest request) {
return ApplicationResolver.INSTANCE.getApplication(request);
}
protected String buildCallbackUri(HttpServletRequest request) {
String uri = this.serverUriResolver.getServerUri(request);
String contextPath = request.getContextPath();
if (contextPath == null || contextPath.equals("/")) {
contextPath = "";
}
if (contextPath.endsWith("/")) {
contextPath = contextPath.substring(0, contextPath.length() - 1);
}
uri += contextPath + this.callbackUri;
return uri;
}
@Override
protected ViewModel doGet(HttpServletRequest request, HttpServletResponse response) throws Exception {
//Let's redirect to "alreadyLoggedInUri" if the user is already logged in
if (AccountResolver.INSTANCE.getAccount(request) != null) {
return new DefaultViewModel(alreadyLoggedInUri).setRedirect(true);
}
String idSiteUrl = createIdSiteUrl(request);
response.setHeader("Cache-control", "no-cache, no-store");
response.setHeader("Pragma", "no-cache");
response.setHeader("Expires", "-1");
return new DefaultViewModel(idSiteUrl).setRedirect(true);
}
protected String createIdSiteUrl(HttpServletRequest request) {
IdSiteUrlBuilder builder = createIdSiteUrlBuilder(request);
return builder.build();
}
protected IdSiteUrlBuilder createIdSiteUrlBuilder(HttpServletRequest request) {
Application application = getApplication(request);
String callbackUri = buildCallbackUri(request);
IdSiteUrlBuilder builder = application.newIdSiteUrlBuilder().setCallbackUri(callbackUri);
IdSiteOrganizationContext orgCtx = idSiteOrganizationResolver.get(request, null);
if (orgCtx != null) {
String nameKey = orgCtx.getOrganizationNameKey();
if (Strings.hasText(nameKey)) {
builder.setOrganizationNameKey(nameKey);
//this next field is only relevant if a namekey is set:
Boolean val = orgCtx.isUseSubdomain();
if (val != null) {
builder.setUseSubdomain(orgCtx.isUseSubdomain());
}
}
Boolean val = orgCtx.isShowOrganizationField();
if (val != null) {
builder.setShowOrganizationField(val);
}
}
if (this.idSiteUri != null) {
builder.setPath(this.idSiteUri);
}
return builder;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy