當前位置: 首頁>>代碼示例>>Java>>正文


Java SSOAgentConstants類代碼示例

本文整理匯總了Java中org.wso2.carbon.identity.sso.agent.SSOAgentConstants的典型用法代碼示例。如果您正苦於以下問題:Java SSOAgentConstants類的具體用法?Java SSOAgentConstants怎麽用?Java SSOAgentConstants使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


SSOAgentConstants類屬於org.wso2.carbon.identity.sso.agent包,在下文中一共展示了SSOAgentConstants類的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: processResponse

import org.wso2.carbon.identity.sso.agent.SSOAgentConstants; //導入依賴的package包/類
public void processResponse(HttpServletRequest request, HttpServletResponse response)
        throws SSOAgentException {

    String saml2SSOResponse = request.getParameter(SSOAgentConstants.SAML2SSO.HTTP_POST_PARAM_SAML2_RESP);

    if (saml2SSOResponse != null) {
        String decodedResponse = new String(Base64.decode(saml2SSOResponse), Charset.forName("UTF-8"));
        XMLObject samlObject = SSOAgentUtils.unmarshall(decodedResponse);
        if (samlObject instanceof LogoutResponse) {
            //This is a SAML response for a single logout request from the SP
            doSLO(request);
        } else {
            processSSOResponse(request);
        }
        String relayState = request.getParameter(RelayState.DEFAULT_ELEMENT_LOCAL_NAME);

        if (relayState != null && !relayState.isEmpty() && !"null".equalsIgnoreCase(relayState)) { //additional
            // checks for incompetent IdPs
            ssoAgentConfig.getSAML2().setRelayState(relayState);
        }

    } else {
        throw new SSOAgentException("Invalid SAML2 Response. SAML2 Response can not be null.");
    }
}
 
開發者ID:wso2-extensions,項目名稱:identity-agent-sso,代碼行數:26,代碼來源:SAML2SSOManager.java

示例2: invalidateSession

import org.wso2.carbon.identity.sso.agent.SSOAgentConstants; //導入依賴的package包/類
public static void invalidateSession(HttpSession session) {
    LoggedInSessionBean sessionBean = (LoggedInSessionBean) session.getAttribute(
            SSOAgentConstants.SESSION_BEAN_NAME);
    if (sessionBean != null && sessionBean.getSAML2SSO() != null) {
        String sessionIndex = sessionBean.getSAML2SSO().getSessionIndex();
        if (sessionIndex != null) {
            Set<HttpSession> sessions = ssoSessionsMap.get(sessionIndex);
            if (sessions != null) {
                sessions.remove(session);
            }
        }
    }
}
 
開發者ID:wso2-extensions,項目名稱:identity-agent-sso,代碼行數:14,代碼來源:SSOAgentSessionManager.java

示例3: invalidateAllSessions

import org.wso2.carbon.identity.sso.agent.SSOAgentConstants; //導入依賴的package包/類
public static Set<HttpSession> invalidateAllSessions(HttpSession session) {
    LoggedInSessionBean sessionBean = (LoggedInSessionBean) session.getAttribute(
            SSOAgentConstants.SESSION_BEAN_NAME);
    Set<HttpSession> sessions = new HashSet<HttpSession>();
    if (sessionBean != null && sessionBean.getSAML2SSO() != null) {
        String sessionIndex = sessionBean.getSAML2SSO().getSessionIndex();
        if (sessionIndex != null) {
            sessions = ssoSessionsMap.remove(sessionIndex);
        }
    }
    if (sessions == null) {
        sessions = new HashSet<HttpSession>();
    }
    return sessions;
}
 
開發者ID:wso2-extensions,項目名稱:identity-agent-sso,代碼行數:16,代碼來源:SSOAgentSessionManager.java

示例4: addAuthenticatedSession

import org.wso2.carbon.identity.sso.agent.SSOAgentConstants; //導入依賴的package包/類
public static void addAuthenticatedSession(HttpSession session) {
    String sessionIndex = ((LoggedInSessionBean) session.getAttribute(
            SSOAgentConstants.SESSION_BEAN_NAME)).getSAML2SSO().getSessionIndex();
    if (ssoSessionsMap.get(sessionIndex) != null) {
        ssoSessionsMap.get(sessionIndex).add(session);
    } else {
        Set<HttpSession> sessions = new HashSet<HttpSession>();
        sessions.add(session);
        ssoSessionsMap.put(sessionIndex, sessions);
    }
}
 
開發者ID:wso2-extensions,項目名稱:identity-agent-sso,代碼行數:12,代碼來源:SSOAgentSessionManager.java

示例5: sessionCreated

import org.wso2.carbon.identity.sso.agent.SSOAgentConstants; //導入依賴的package包/類
@Override
public void sessionCreated(HttpSessionEvent httpSessionEvent) {
    if (httpSessionEvent.getSession().getAttribute(SSOAgentConstants.SESSION_BEAN_NAME) == null) {
        // This log is not accurate, since we depend on request.getSession() to create new session
        // if there is no existing session. After that only we set the Session-Bean.
        // Thus in this listener the session always does not contain a Session-Bean Attribute.
        LOGGER.log(Level.WARNING, "HTTP Session created without LoggedInSessionBean");
    }
}
 
開發者ID:wso2-extensions,項目名稱:identity-agent-sso,代碼行數:10,代碼來源:SSOAgentHttpSessionListener.java

示例6: getAccessToken

import org.wso2.carbon.identity.sso.agent.SSOAgentConstants; //導入依賴的package包/類
public void getAccessToken(HttpServletRequest request, HttpServletResponse response)
        throws SSOAgentException {


    String samlAssertionString = ((LoggedInSessionBean) request.getSession(false).
            getAttribute(SSOAgentConstants.SESSION_BEAN_NAME)).getSAML2SSO().
            getAssertionString();

    String clientLogin = ssoAgentConfig.getOAuth2().getClientId() + ":" +
            ssoAgentConfig.getOAuth2().getClientSecret();
    String queryParam = "grant_type=" + SSOAgentConstants.OAuth2.SAML2_BEARER_GRANT_TYPE + "&assertion=" +
                        URLEncoder.encode(Base64.encodeBytes(
                                samlAssertionString.getBytes(Charset.forName("UTF-8"))).replaceAll("\n", ""));
    String additionalQueryParam = ssoAgentConfig.getRequestQueryParameters();
    if (additionalQueryParam != null) {
        queryParam = queryParam + additionalQueryParam;
    }
    String accessTokenResponse = executePost(queryParam,
                                             Base64.encodeBytes(clientLogin.getBytes(Charset.forName("UTF-8")))
                                                   .replace("\n", ""));

    Gson gson = new Gson();
    LoggedInSessionBean.AccessTokenResponseBean accessTokenResp =
            gson.fromJson(accessTokenResponse, LoggedInSessionBean.AccessTokenResponseBean.class);

    ((LoggedInSessionBean) request.getSession(false).getAttribute(
            SSOAgentConstants.SESSION_BEAN_NAME)).getSAML2SSO()
            .setAccessTokenResponseBean(accessTokenResp);
}
 
開發者ID:wso2-extensions,項目名稱:identity-agent-sso,代碼行數:30,代碼來源:SAML2GrantManager.java

示例7: invalidateSession

import org.wso2.carbon.identity.sso.agent.SSOAgentConstants; //導入依賴的package包/類
public static void invalidateSession(HttpSession session) {
    LoggedInSessionBean sessionBean = (LoggedInSessionBean) session.getAttribute(
            SSOAgentConstants.SESSION_BEAN_NAME);
    if (sessionBean != null && sessionBean.getSAML2SSO() != null) {
        String sessionIndex = sessionBean.getSAML2SSO().getSessionIndex();
        if (sessionIndex != null) {
            Set<HttpSession> sessions = ssoSessionsMap.get(sessionIndex);
            sessions.remove(session);
        }
    }
}
 
開發者ID:wso2-attic,項目名稱:carbon-identity,代碼行數:12,代碼來源:SSOAgentSessionManager.java

示例8: sessionDestroyed

import org.wso2.carbon.identity.sso.agent.SSOAgentConstants; //導入依賴的package包/類
@Override
public void sessionDestroyed(HttpSessionEvent httpSessionEvent) {
    // No need to invalidate session here, as it is going to be invalidated soon
    SSOAgentSessionManager.invalidateSession(httpSessionEvent.getSession());
    httpSessionEvent.getSession().removeAttribute(SSOAgentConstants.SESSION_BEAN_NAME);
}
 
開發者ID:wso2-extensions,項目名稱:identity-agent-sso,代碼行數:7,代碼來源:SSOAgentHttpSessionListener.java

示例9: buildRedirectRequest

import org.wso2.carbon.identity.sso.agent.SSOAgentConstants; //導入依賴的package包/類
/**
 * Returns the redirection URL with the appended SAML2
 * Request message
 *
 * @param request SAML 2 request
 * @return redirectionUrl
 */
public String buildRedirectRequest(HttpServletRequest request, boolean isLogout) throws SSOAgentException {

    RequestAbstractType requestMessage = null;
    if (!isLogout) {
        requestMessage = buildAuthnRequest(request);
    } else {
        HttpSession httpSession = request.getSession(false);
        if (httpSession == null) {
            throw new InvalidSessionException("Session is expired or user already logged out.");
        }

        LoggedInSessionBean sessionBean = (LoggedInSessionBean) httpSession.getAttribute(SSOAgentConstants
                .SESSION_BEAN_NAME);
        if (sessionBean != null) {
            requestMessage = buildLogoutRequest(sessionBean.getSAML2SSO().getSubjectId(),
                    sessionBean.getSAML2SSO().getSessionIndex());
        } else {
            throw new SSOAgentException("SLO Request can not be built. SSO Session is NULL");
        }
    }
    String idpUrl = null;

    String encodedRequestMessage = encodeRequestMessage(
            requestMessage, SAMLConstants.SAML2_REDIRECT_BINDING_URI);
    StringBuilder httpQueryString = new StringBuilder(
            SSOAgentConstants.SAML2SSO.HTTP_POST_PARAM_SAML2_AUTH_REQ +
                    "=" + encodedRequestMessage);

    String relayState = request.getParameter(RelayState.DEFAULT_ELEMENT_LOCAL_NAME);
    if (StringUtils.isNotEmpty(relayState)) {
        relayState = ssoAgentConfig.getSAML2().getRelayState();
    }
    if (relayState != null) {
        try {
            httpQueryString.append("&" + RelayState.DEFAULT_ELEMENT_LOCAL_NAME + "=" +
                    URLEncoder.encode(relayState, "UTF-8").trim());
        } catch (UnsupportedEncodingException e) {
            throw new SSOAgentException("Error occurred while URLEncoding " +
                    RelayState.DEFAULT_ELEMENT_LOCAL_NAME, e);
        }
    }

    if (ssoAgentConfig.getSAML2().isRequestSigned()) {
        SSOAgentUtils.addDeflateSignatureToHTTPQueryString(httpQueryString,
                new X509CredentialImpl(ssoAgentConfig.getSAML2().getSSOAgentX509Credential()));
    }

    if (ssoAgentConfig.getQueryParams() != null && !ssoAgentConfig.getQueryParams().isEmpty()) {
        StringBuilder builder = new StringBuilder();
        for (Map.Entry<String, String[]> entry : ssoAgentConfig.getQueryParams().entrySet()) {
            if (entry.getKey() != null && entry.getValue() != null && entry.getValue().length > 0) {
                for (String param : entry.getValue()) {
                    builder.append("&").append(entry.getKey()).append("=").append(param);
                }
            }
        }
        httpQueryString.append(builder);
    }



    if (ssoAgentConfig.getSAML2().getIdPURL().indexOf("?") > -1) {
        idpUrl = ssoAgentConfig.getSAML2().getIdPURL().concat("&").concat(httpQueryString.toString());
    } else {
        idpUrl = ssoAgentConfig.getSAML2().getIdPURL().concat("?").concat(httpQueryString.toString());
    }
    return idpUrl;
}
 
開發者ID:wso2-extensions,項目名稱:identity-agent-sso,代碼行數:76,代碼來源:SAML2SSOManager.java

示例10: doFilter

import org.wso2.carbon.identity.sso.agent.SSOAgentConstants; //導入依賴的package包/類
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse,
                     FilterChain filterChain) throws IOException, ServletException {

    String httpBinding = servletRequest.getParameter(
            SSOAgentConstants.SSOAgentConfig.SAML2.HTTP_BINDING);
    if (httpBinding != null && !httpBinding.isEmpty()) {
        if ("HTTP-POST".equals(httpBinding)) {
            httpBinding = "urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST";
        } else if ("HTTP-Redirect".equals(httpBinding)) {
            httpBinding = "urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect";
        } else {
            LOGGER.log(Level.INFO, "Unknown SAML2 HTTP Binding. Defaulting to HTTP-POST");
            httpBinding = "urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST";
        }
    } else {
        LOGGER.log(Level.INFO, "SAML2 HTTP Binding not found in request. Defaulting to HTTP-POST");
        httpBinding = "urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST";
    }
    SSOAgentConfig config = (SSOAgentConfig) filterConfig.getServletContext().
            getAttribute(SSOAgentConstants.CONFIG_BEAN_NAME);
    config.getSAML2().setHttpBinding(httpBinding);
    config.getOpenId().setClaimedId(servletRequest.getParameter(
            SSOAgentConstants.SSOAgentConfig.OpenID.CLAIMED_ID));
    config.getOpenId().setMode(servletRequest.getParameter(
            SSOAgentConstants.OpenID.OPENID_MODE));

    if (StringUtils.isNotEmpty(servletRequest.getParameter(USERNAME)) &&
            StringUtils.isNotEmpty(servletRequest.getParameter(PASSWORD))) {

        String authorization = servletRequest.getParameter(USERNAME) + ":" + servletRequest.getParameter(PASSWORD);
        // Base64 encoded username:password value
        authorization = Base64.encode(authorization.getBytes(CHARACTER_ENCODING));
        String htmlPayload = "<html>\n" +
                "<body>\n" +
                "<p>You are now redirected back to " + properties.getProperty("SAML2.IdPURL") + " \n" +
                "If the redirection fails, please click the post button.</p>\n" +
                "<form method='post' action='" + properties.getProperty("SAML2.IdPURL") + "'>\n" +
                "<input type='hidden' name='sectoken' value='" + authorization + "'/>\n" +
                "<p>\n" +
                "<!--$saml_params-->\n" +
                "<button type='submit'>POST</button>\n" +
                "</p>\n" +
                "</form>\n" +
                "<script type='text/javascript'>\n" +
                "document.forms[0].submit();\n" +
                "</script>\n" +
                "</body>\n" +
                "</html>";
        config.getSAML2().setPostBindingRequestHTMLPayload(htmlPayload);
    } else {
        // Reset previously sent HTML payload
        config.getSAML2().setPostBindingRequestHTMLPayload(null);
    }
    servletRequest.setAttribute(SSOAgentConstants.CONFIG_BEAN_NAME, config);
    super.doFilter(servletRequest, servletResponse, filterChain);
}
 
開發者ID:wso2,項目名稱:msf4j,代碼行數:58,代碼來源:SSOAgentSampleFilter.java

示例11: sessionCreated

import org.wso2.carbon.identity.sso.agent.SSOAgentConstants; //導入依賴的package包/類
@Override
public void sessionCreated(HttpSessionEvent httpSessionEvent) {
    if (httpSessionEvent.getSession().getAttribute(SSOAgentConstants.SESSION_BEAN_NAME) == null) {
        LOGGER.log(Level.WARNING, "HTTP Session created without LoggedInSessionBean");
    }
}
 
開發者ID:wso2-attic,項目名稱:carbon-identity,代碼行數:7,代碼來源:SSOAgentHttpSessionListener.java

示例12: buildRedirectRequest

import org.wso2.carbon.identity.sso.agent.SSOAgentConstants; //導入依賴的package包/類
/**
 * Returns the redirection URL with the appended SAML2
 * Request message
 *
 * @param request SAML 2 request
 * @return redirectionUrl
 */
public String buildRedirectRequest(HttpServletRequest request, boolean isLogout) throws SSOAgentException {

    RequestAbstractType requestMessage = null;
    if (!isLogout) {
        requestMessage = buildAuthnRequest(request);
    } else {
        LoggedInSessionBean sessionBean = (LoggedInSessionBean) request.getSession(false).
                getAttribute(SSOAgentConstants.SESSION_BEAN_NAME);
        if (sessionBean != null) {
            requestMessage = buildLogoutRequest(sessionBean.getSAML2SSO().getSubjectId(),
                    sessionBean.getSAML2SSO().getSessionIndex());
        } else {
            throw new SSOAgentException("SLO Request can not be built. SSO Session is NULL");
        }
    }
    String idpUrl = null;

    String encodedRequestMessage = encodeRequestMessage(
            requestMessage, SAMLConstants.SAML2_REDIRECT_BINDING_URI);
    StringBuilder httpQueryString = new StringBuilder(
            SSOAgentConstants.SAML2SSO.HTTP_POST_PARAM_SAML2_AUTH_REQ +
                    "=" + encodedRequestMessage);

    String relayState = ssoAgentConfig.getSAML2().getRelayState();
    if (relayState != null) {
        try {
            httpQueryString.append("&" + RelayState.DEFAULT_ELEMENT_LOCAL_NAME + "=" +
                    URLEncoder.encode(relayState, "UTF-8").trim());
        } catch (UnsupportedEncodingException e) {
            throw new SSOAgentException("Error occurred while URLEncoding " +
                    RelayState.DEFAULT_ELEMENT_LOCAL_NAME, e);
        }
    }

    if (ssoAgentConfig.getSAML2().isRequestSigned()) {
        SSOAgentUtils.addDeflateSignatureToHTTPQueryString(httpQueryString,
                new X509CredentialImpl(ssoAgentConfig.getSAML2().getSSOAgentX509Credential()));
    }

    if (ssoAgentConfig.getQueryParams() != null && !ssoAgentConfig.getQueryParams().isEmpty()) {
        StringBuilder builder = new StringBuilder();
        for (Map.Entry<String, String[]> entry : ssoAgentConfig.getQueryParams().entrySet()) {
            if (entry.getKey() != null && entry.getValue() != null && entry.getValue().length > 0) {
                for (String param : entry.getValue()) {
                    builder.append("&").append(entry.getKey()).append("=").append(param);
                }
            }
        }
        httpQueryString.append(builder);
    }



    if (ssoAgentConfig.getSAML2().getIdPURL().indexOf("?") > -1) {
        idpUrl = ssoAgentConfig.getSAML2().getIdPURL().concat("&").concat(httpQueryString.toString());
    } else {
        idpUrl = ssoAgentConfig.getSAML2().getIdPURL().concat("?").concat(httpQueryString.toString());
    }
    return idpUrl;
}
 
開發者ID:wso2-attic,項目名稱:carbon-identity,代碼行數:68,代碼來源:SAML2SSOManager.java


注:本文中的org.wso2.carbon.identity.sso.agent.SSOAgentConstants類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。