1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.opensaml.saml1.core.impl;
18
19 import org.opensaml.saml1.core.Action;
20 import org.opensaml.saml1.core.AuthorizationDecisionStatement;
21 import org.opensaml.saml1.core.DecisionTypeEnumeration;
22 import org.opensaml.saml1.core.Evidence;
23 import org.opensaml.xml.XMLObject;
24 import org.opensaml.xml.io.UnmarshallingException;
25 import org.slf4j.Logger;
26 import org.slf4j.LoggerFactory;
27 import org.w3c.dom.Attr;
28
29
30
31
32 public class AuthorizationDecisionStatementUnmarshaller extends SubjectStatementUnmarshaller {
33
34
35 private final Logger log = LoggerFactory.getLogger(AuthorizationDecisionStatementUnmarshaller.class);
36
37
38 protected void processChildElement(XMLObject parentSAMLObject, XMLObject childSAMLObject)
39 throws UnmarshallingException {
40
41 AuthorizationDecisionStatement authorizationDecisionStatement;
42 authorizationDecisionStatement = (AuthorizationDecisionStatement) parentSAMLObject;
43
44 if (childSAMLObject instanceof Action) {
45 authorizationDecisionStatement.getActions().add((Action) childSAMLObject);
46 } else if (childSAMLObject instanceof Evidence) {
47 authorizationDecisionStatement.setEvidence((Evidence) childSAMLObject);
48 } else {
49 super.processChildElement(parentSAMLObject, childSAMLObject);
50 }
51 }
52
53
54 protected void processAttribute(XMLObject samlObject, Attr attribute) throws UnmarshallingException {
55
56 AuthorizationDecisionStatement authorizationDecisionStatement;
57 authorizationDecisionStatement = (AuthorizationDecisionStatement) samlObject;
58
59 if (AuthorizationDecisionStatement.DECISION_ATTRIB_NAME.equals(attribute.getLocalName())) {
60 String value = attribute.getValue();
61 if (value.equals(DecisionTypeEnumeration.PERMIT.toString())) {
62 authorizationDecisionStatement.setDecision(DecisionTypeEnumeration.PERMIT);
63 } else if (value.equals(DecisionTypeEnumeration.DENY.toString())) {
64 authorizationDecisionStatement.setDecision(DecisionTypeEnumeration.DENY);
65 } else if (value.equals(DecisionTypeEnumeration.INDETERMINATE.toString())) {
66 authorizationDecisionStatement.setDecision(DecisionTypeEnumeration.INDETERMINATE);
67 } else {
68 log.error("Unknown value for DecisionType '" + value + "'");
69 throw new UnmarshallingException("Unknown value for DecisionType '" + value + "'");
70 }
71 } else if (AuthorizationDecisionStatement.RESOURCE_ATTRIB_NAME.equals(attribute.getLocalName())) {
72 authorizationDecisionStatement.setResource(attribute.getValue());
73 } else {
74 super.processAttribute(samlObject, attribute);
75 }
76 }
77 }