// TODO: This method can be removed when runOutInterceptorAndValidateSamlTokenAttached
// is cleaned up.
private void verifySignatureCoversAssertion(Document signedDoc, String assertionId) throws Exception {
XPathFactory factory = XPathFactory.newInstance();
XPath xpath = factory.newXPath();
final NamespaceContext nsContext = this.getNamespaceContext();
xpath.setNamespaceContext(nsContext);
// Find the SecurityTokenReference for the assertion
final XPathExpression strExpr = xpath.compile(
"/s:Envelope/s:Header/wsse:Security/wsse:SecurityTokenReference/wsse:KeyIdentifier");
final NodeList strKeyIdNodes =
(NodeList) strExpr.evaluate(signedDoc, XPathConstants.NODESET);
String strId = null;
for (int i = 0; i < strKeyIdNodes.getLength(); i++) {
Node keyIdNode = (Node) strKeyIdNodes.item(i);
String strKey = keyIdNode.getTextContent();
if (strKey.equals(assertionId)) {
Node strNode = (Node) keyIdNode.getParentNode();
strId = strNode.getAttributes().
getNamedItemNS(nsContext.getNamespaceURI("wsu"), "Id").getNodeValue();
break;
}
}
assertNotNull("SecurityTokenReference for " + assertionId + " not found in security header.", strId);