<%--
The contents of this file are subject to the terms
of the Common Development and Distribution License
(the License). You may not use this file except in
compliance with the License.
You can obtain a copy of the License at
https://opensso.dev.java.net/public/CDDLv1.0.html or
opensso/legal/CDDLv1.0.txt
See the License for the specific language governing
permission and limitations under the License.
When distributing Covered Code, include this CDDL
Header Notice in each file and include the License file
at opensso/legal/CDDLv1.0.txt.
If applicable, add the following below the CDDL Header,
with the fields enclosed by brackets [] replaced by
your own identifying information:
"Portions Copyrighted [year] [name of copyright owner]"
Copyright 2009 Sun Microsystems Inc. All Rights Reserved
--%>
<%--
Portions Copyrighted 2013 ForgeRock AS
--%>
<%--
fedletXACMLResp.jsp
This JSP used by the Fedlet performs the following:
1) Retrieves the list of attributes from fedletXACMLQuery.jsp
2) Invokes the method to retrieve the policy decision for the Resource URL.
3) Displays the Result.
--%>
<%@ page import="com.sun.identity.saml2.common.SAML2Utils" %>
<%@ page import="com.sun.identity.saml2.profile.XACMLQueryUtil" %>
<%@ page import="org.owasp.esapi.ESAPI" %>
<%
String deployuri = request.getRequestURI();
int slashLoc = deployuri.indexOf("/", 1);
if (slashLoc != -1) {
deployuri = deployuri.substring(0, slashLoc);
}
%>
<html>
<head>
<title>Sample Fedlet XACML Query Application</title>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<link rel="stylesheet" type="text/css" href="<%= deployuri %>/com_sun_web_ui/css/css_ns6up.css" />
</head>
<body>
<div class="MstDiv"><table width="100%" border="0" cellpadding="0" cellspacing="0" class="MstTblTop" title="">
<tbody><tr>
<td nowrap="nowrap">&nbsp;</td>
<td nowrap="nowrap">&nbsp;</td>
</tr></tbody></table>
<table width="100%" border="0" cellpadding="0" cellspacing="0" class="MstTblBot" title="">
<tbody><tr>
<td class="MstTdTtl" width="99%">
<div class="MstDivTtl"><img name="ProdName" src="<%= deployuri %>/console/images/PrimaryProductName.png" alt="" /></div></td><td class="MstTdLogo" width="1%"><img name="RMRealm.mhCommon.BrandLogo" src="<%= deployuri %>/com_sun_web_ui/images/other/javalogo.gif" alt="Java(TM) Logo" border="0" height="55" width="31" /></td></tr></tbody></table>
<table class="MstTblEnd" border="0" cellpadding="0" cellspacing="0" width="100%"><tbody><tr><td><img name="RMRealm.mhCommon.EndorserLogo" src="<%= deployuri %>/com_sun_web_ui/images/masthead/masthead-sunname.gif" alt="Sun(TM) Microsystems,
Inc." align="right" border="0" height="10" width="108" /></td></tr></tbody></table></div><div class="SkpMedGry1"><a name="SkipAnchor2089" id="SkipAnchor2089"></a></div>
<div class="SkpMedGry1"><a href="#SkipAnchor4928"><img src="<%= deployuri %>/com_sun_web_ui/images/other/dot.gif" alt="Jump Over Tab Navigation Area. Current Selection is: Access Control" border="0" height="1" width="1" /></a></div>
<%
try {
String idpEntityID = request.getParameter("idpEntityID");
if ((idpEntityID == null) ||
(idpEntityID.length() == 0)) {
response.sendError(response.SC_BAD_REQUEST,
SAML2Utils.bundle.getString("nullIDPEntityID"));
return;
}
String spEntityID = request.getParameter("spEntityID");
if ((spEntityID == null) ||
(spEntityID.length() == 0)) {
response.sendError(response.SC_BAD_REQUEST,
SAML2Utils.bundle.getString("nullSPEntityID"));
return;
}
String nameIDValue = request.getParameter("nameIDValue");
String newNameIDValue = nameIDValue.replace("%2F","/");
String resource = request.getParameter("resource");
if (!ESAPI.validator().isValidInput("HTTP Parameter Value: " + resource,
resource, "HTTPParameterValue", 2000, false)){
resource = "";
}
String action = request.getParameter("action");
String serviceName = "iPlanetAMWebAgentService";
String policy_decision = XACMLQueryUtil.getPolicyDecisionForFedlet(
request,
spEntityID,
idpEntityID,
newNameIDValue,
serviceName,
resource,
action);
%>
<h2> Fedlet XACML Query Response </h2>
<table border="2" cellspacing="0" cellpadding="7">
<tr>
<th>Resource</th>
<th>Policy Decision</th>
</tr>
<%
if(resource!=null) resource = ESAPI.encoder().encodeForHTML(resource);
out.println("<tr>");
out.println("<td>");
out.println(resource);
out.println("</td>");
out.println("<td>");
out.println(policy_decision);
out.println("</td>");
%>
</table>
<%
} catch (Exception ex) {
SAML2Utils.debug.error("Error sending XACML Query " , ex);
}
%>
</body>
</html>