fixed institutional entrypoint
This commit is contained in:
parent
26f36d264d
commit
7f41446558
2 changed files with 57 additions and 23 deletions
|
@ -11,6 +11,7 @@ package ch.ethz.seb.sebserver.gui;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import java.io.Reader;
|
import java.io.Reader;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import javax.servlet.RequestDispatcher;
|
import javax.servlet.RequestDispatcher;
|
||||||
import javax.servlet.ServletException;
|
import javax.servlet.ServletException;
|
||||||
|
@ -25,6 +26,7 @@ import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.beans.factory.annotation.Value;
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
import org.springframework.context.annotation.Lazy;
|
import org.springframework.context.annotation.Lazy;
|
||||||
|
import org.springframework.core.ParameterizedTypeReference;
|
||||||
import org.springframework.core.io.Resource;
|
import org.springframework.core.io.Resource;
|
||||||
import org.springframework.core.io.ResourceLoader;
|
import org.springframework.core.io.ResourceLoader;
|
||||||
import org.springframework.http.HttpEntity;
|
import org.springframework.http.HttpEntity;
|
||||||
|
@ -41,6 +43,7 @@ import org.springframework.web.client.RestTemplate;
|
||||||
import ch.ethz.seb.sebserver.ClientHttpRequestFactoryService;
|
import ch.ethz.seb.sebserver.ClientHttpRequestFactoryService;
|
||||||
import ch.ethz.seb.sebserver.gbl.Constants;
|
import ch.ethz.seb.sebserver.gbl.Constants;
|
||||||
import ch.ethz.seb.sebserver.gbl.api.API;
|
import ch.ethz.seb.sebserver.gbl.api.API;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.EntityName;
|
||||||
import ch.ethz.seb.sebserver.gbl.profile.GuiProfile;
|
import ch.ethz.seb.sebserver.gbl.profile.GuiProfile;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.auth.WebserviceURIService;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.auth.WebserviceURIService;
|
||||||
import ch.ethz.seb.sebserver.gui.widget.ImageUploadSelection;
|
import ch.ethz.seb.sebserver.gui.widget.ImageUploadSelection;
|
||||||
|
@ -50,7 +53,7 @@ import ch.ethz.seb.sebserver.gui.widget.ImageUploadSelection;
|
||||||
@GuiProfile
|
@GuiProfile
|
||||||
public final class InstitutionalAuthenticationEntryPoint implements AuthenticationEntryPoint {
|
public final class InstitutionalAuthenticationEntryPoint implements AuthenticationEntryPoint {
|
||||||
|
|
||||||
private static final String INST_SUFFIX_ATTRIBUTE = "instSuffix";
|
private static final String INST_SUFFIX_ATTRIBUTE = "endpointInstId";
|
||||||
|
|
||||||
private static final Logger log = LoggerFactory.getLogger(InstitutionalAuthenticationEntryPoint.class);
|
private static final Logger log = LoggerFactory.getLogger(InstitutionalAuthenticationEntryPoint.class);
|
||||||
|
|
||||||
|
@ -108,6 +111,29 @@ public final class InstitutionalAuthenticationEntryPoint implements Authenticati
|
||||||
final AuthenticationException authException) throws IOException, ServletException {
|
final AuthenticationException authException) throws IOException, ServletException {
|
||||||
|
|
||||||
final String institutionalEndpoint = extractInstitutionalEndpoint(request);
|
final String institutionalEndpoint = extractInstitutionalEndpoint(request);
|
||||||
|
|
||||||
|
if (StringUtils.isNoneBlank(institutionalEndpoint) && log.isDebugEnabled()) {
|
||||||
|
log.debug("No default gui entrypoint requested: {}", institutionalEndpoint);
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
final RestTemplate restTemplate = new RestTemplate();
|
||||||
|
final List<EntityName> institutions = restTemplate
|
||||||
|
.exchange(
|
||||||
|
this.webserviceURIService.getURIBuilder()
|
||||||
|
.path(API.INFO_ENDPOINT + API.INFO_INST_ENDPOINT)
|
||||||
|
.toUriString(),
|
||||||
|
HttpMethod.GET,
|
||||||
|
HttpEntity.EMPTY,
|
||||||
|
new ParameterizedTypeReference<List<EntityName>>() {
|
||||||
|
},
|
||||||
|
institutionalEndpoint,
|
||||||
|
API.INFO_PARAM_INST_SUFFIX,
|
||||||
|
institutionalEndpoint)
|
||||||
|
.getBody();
|
||||||
|
|
||||||
|
if (!institutions.isEmpty()) {
|
||||||
request.getSession().setAttribute(
|
request.getSession().setAttribute(
|
||||||
INST_SUFFIX_ATTRIBUTE,
|
INST_SUFFIX_ATTRIBUTE,
|
||||||
StringUtils.isNotBlank(institutionalEndpoint)
|
StringUtils.isNotBlank(institutionalEndpoint)
|
||||||
|
@ -115,19 +141,27 @@ public final class InstitutionalAuthenticationEntryPoint implements Authenticati
|
||||||
: null);
|
: null);
|
||||||
|
|
||||||
if (log.isDebugEnabled()) {
|
if (log.isDebugEnabled()) {
|
||||||
log.debug("No default gui entrypoint requested: {}", institutionalEndpoint);
|
log.debug("Known and active gui entrypoint requested:", institutions);
|
||||||
}
|
}
|
||||||
|
|
||||||
final String logoImageBase64 = requestLogoImage(institutionalEndpoint);
|
final String logoImageBase64 = requestLogoImage(institutionalEndpoint);
|
||||||
if (StringUtils.isNotBlank(logoImageBase64)) {
|
if (StringUtils.isNotBlank(logoImageBase64)) {
|
||||||
request.getSession().setAttribute(API.PARAM_LOGO_IMAGE, logoImageBase64);
|
request.getSession().setAttribute(API.PARAM_LOGO_IMAGE, logoImageBase64);
|
||||||
|
|
||||||
|
}
|
||||||
forwardToEntryPoint(request, response, this.guiEntryPoint);
|
forwardToEntryPoint(request, response, this.guiEntryPoint);
|
||||||
} else {
|
return;
|
||||||
|
}
|
||||||
|
} catch (final Exception e) {
|
||||||
|
log.error("Failed to extract and set institutional endpoint request: ", e);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
request.getSession().setAttribute(INST_SUFFIX_ATTRIBUTE, null);
|
||||||
request.getSession().removeAttribute(API.PARAM_LOGO_IMAGE);
|
request.getSession().removeAttribute(API.PARAM_LOGO_IMAGE);
|
||||||
response.setStatus(HttpStatus.UNAUTHORIZED.value());
|
response.setStatus(HttpStatus.UNAUTHORIZED.value());
|
||||||
forwardToEntryPoint(request, response, this.guiEntryPoint);
|
forwardToEntryPoint(request, response, this.guiEntryPoint);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void forwardToEntryPoint(
|
private void forwardToEntryPoint(
|
||||||
|
|
|
@ -8,9 +8,9 @@
|
||||||
|
|
||||||
package ch.ethz.seb.sebserver.webservice.servicelayer.client;
|
package ch.ethz.seb.sebserver.webservice.servicelayer.client;
|
||||||
|
|
||||||
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
|
import java.nio.CharBuffer;
|
||||||
import ch.ethz.seb.sebserver.gbl.util.Cryptor;
|
import java.security.SecureRandom;
|
||||||
import ch.ethz.seb.sebserver.gbl.util.Result;
|
|
||||||
import org.apache.commons.lang3.RandomStringUtils;
|
import org.apache.commons.lang3.RandomStringUtils;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
@ -19,9 +19,9 @@ import org.springframework.context.annotation.Lazy;
|
||||||
import org.springframework.core.env.Environment;
|
import org.springframework.core.env.Environment;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
import java.io.UnsupportedEncodingException;
|
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
|
||||||
import java.nio.CharBuffer;
|
import ch.ethz.seb.sebserver.gbl.util.Cryptor;
|
||||||
import java.security.SecureRandom;
|
import ch.ethz.seb.sebserver.gbl.util.Result;
|
||||||
|
|
||||||
@Lazy
|
@Lazy
|
||||||
@Service
|
@Service
|
||||||
|
@ -101,12 +101,12 @@ public class ClientCredentialServiceImpl implements ClientCredentialService {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CharSequence encrypt(final CharSequence text) {
|
public CharSequence encrypt(final CharSequence text) {
|
||||||
return cryptor.encrypt(text);
|
return this.cryptor.encrypt(text);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CharSequence decrypt(final CharSequence text) {
|
public CharSequence decrypt(final CharSequence text) {
|
||||||
return cryptor.decrypt(text);
|
return this.cryptor.decrypt(text);
|
||||||
}
|
}
|
||||||
|
|
||||||
private final static char[] possibleCharacters =
|
private final static char[] possibleCharacters =
|
||||||
|
|
Loading…
Reference in a new issue