Mercurial > dive4elements > river
view gwt-client/src/main/java/org/dive4elements/river/client/server/auth/was/Authenticator.java @ 9627:f51e23eb036a
zu pos 20
author | dnt_bjoernsen <d.tironi@bjoernsen.de> |
---|---|
date | Mon, 14 Oct 2019 16:27:31 +0200 |
parents | d6d5ca6d4af0 |
children | bc50ecfc58c5 |
line wrap: on
line source
/* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde * Software engineering by Intevation GmbH * * This file is Free Software under the GNU AGPL (>=v3) * and comes with ABSOLUTELY NO WARRANTY! Check out the * documentation coming with Dive4Elements River for details. */ package org.dive4elements.river.client.server.auth.was; import java.io.IOException; import java.security.GeneralSecurityException; import javax.servlet.ServletContext; import org.apache.http.HttpEntity; import org.apache.http.HttpHost; import org.apache.http.HttpResponse; import org.apache.http.StatusLine; import org.apache.http.client.HttpClient; import org.apache.http.conn.params.ConnRoutePNames; import org.apache.http.conn.scheme.Scheme; import org.apache.http.conn.ssl.SSLSocketFactory; import org.apache.http.impl.client.DefaultHttpClient; import org.dive4elements.river.client.server.GGInATrustStrategy; import org.dive4elements.river.client.server.auth.Authentication; import org.dive4elements.river.client.server.auth.AuthenticationException; import org.dive4elements.river.client.server.features.Features; public class Authenticator implements org.dive4elements.river.client.server.auth.Authenticator { @Override public Authentication auth( String username, String password, String encoding, Features features, ServletContext context ) throws AuthenticationException, IOException { try { SSLSocketFactory sf = new SSLSocketFactory( new GGInATrustStrategy()); Scheme https = new Scheme("https", 443, sf); HttpClient httpclient = new DefaultHttpClient(); httpclient.getConnectionManager().getSchemeRegistry().register( https); Request httpget = new Request("https://geoportal.bafg.de/" + "administration/WAS", username, password, encoding); HttpHost proxy = new HttpHost("proxy.bce01.de",8080); httpclient.getParams().setParameter(ConnRoutePNames.DEFAULT_PROXY,proxy); HttpResponse response = httpclient.execute(httpget); StatusLine stline = response.getStatusLine(); if (stline.getStatusCode() != 200) { throw new AuthenticationException("GGInA Server Error. " + "Statuscode: " + stline.getStatusCode() + ". Reason: " + stline.getReasonPhrase()); } HttpEntity entity = response.getEntity(); if (entity == null) { //FIXME throw AuthenticationException return null; } else { String trustedKey = (String)context.getInitParameter("saml-trusted-public-key"); String timeEpsilon = context.getInitParameter( "saml-time-tolerance"); return new Response(entity, password, features, context.getRealPath(trustedKey), timeEpsilon); } } catch(GeneralSecurityException e) { throw new AuthenticationException(e); } } }