/webservices/server-integration/src/main/java/org/jboss/as/webservices/security/SecurityDomainContextAdaptor.java

https://github.com/kylape/jboss-as · Java · 121 lines · 67 code · 16 blank · 38 comment · 2 complexity · 7b9eab52bd7af438dd7b21345c914f85 MD5 · raw file

  1. /*
  2. * JBoss, Home of Professional Open Source.
  3. * Copyright 2011, Red Hat Middleware LLC, and individual contributors
  4. * as indicated by the @author tags. See the copyright.txt file in the
  5. * distribution for a full listing of individual contributors.
  6. *
  7. * This is free software; you can redistribute it and/or modify it
  8. * under the terms of the GNU Lesser General Public License as
  9. * published by the Free Software Foundation; either version 2.1 of
  10. * the License, or (at your option) any later version.
  11. *
  12. * This software is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * Lesser General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Lesser General Public
  18. * License along with this software; if not, write to the Free
  19. * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
  20. * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
  21. */
  22. package org.jboss.as.webservices.security;
  23. import java.security.AccessController;
  24. import java.security.Principal;
  25. import java.security.PrivilegedAction;
  26. import java.util.Set;
  27. import javax.security.auth.Subject;
  28. import org.jboss.as.security.plugins.SecurityDomainContext;
  29. import org.jboss.security.SecurityContext;
  30. import org.jboss.security.SecurityContextAssociation;
  31. import org.jboss.security.SecurityContextFactory;
  32. /**
  33. * Adaptor of org.jboss.as.security.plugins.SecurityDomainContext to org.jboss.wsf.spi.security.SecurityDomainContext
  34. *
  35. * @author alessio.soldano@jboss.com
  36. * @since 13-May-2011
  37. */
  38. public final class SecurityDomainContextAdaptor implements org.jboss.wsf.spi.security.SecurityDomainContext {
  39. private final SecurityDomainContext context;
  40. public SecurityDomainContextAdaptor(SecurityDomainContext context) {
  41. this.context = context;
  42. }
  43. @Override
  44. public boolean isValid(Principal principal, Object credential, Subject activeSubject) {
  45. return context.getAuthenticationManager().isValid(principal, credential, activeSubject);
  46. }
  47. @Override
  48. public boolean doesUserHaveRole(Principal principal, Set<Principal> roles) {
  49. return context.getAuthorizationManager().doesUserHaveRole(principal, roles);
  50. }
  51. @Override
  52. public String getSecurityDomain() {
  53. return context.getAuthenticationManager().getSecurityDomain();
  54. }
  55. @Override
  56. public Set<Principal> getUserRoles(Principal principal) {
  57. return context.getAuthorizationManager().getUserRoles(principal);
  58. }
  59. @Override
  60. public void pushSubjectContext(final Subject subject, final Principal principal, final Object credential) {
  61. AccessController.doPrivileged(new PrivilegedAction<Void>() {
  62. public Void run() {
  63. SecurityContext securityContext = SecurityContextAssociation.getSecurityContext();
  64. if (securityContext == null) {
  65. securityContext = createSecurityContext(getSecurityDomain());
  66. setSecurityContextOnAssociation(securityContext);
  67. }
  68. securityContext.getUtil().createSubjectInfo(principal, credential, subject);
  69. return null;
  70. }
  71. });
  72. }
  73. /**
  74. * Create a JBoss Security Context with the given security domain name
  75. *
  76. * @param domain the security domain name (such as "other" )
  77. * @return an instanceof {@code SecurityContext}
  78. */
  79. private static SecurityContext createSecurityContext(final String domain) {
  80. return AccessController.doPrivileged(new PrivilegedAction<SecurityContext>() {
  81. @Override
  82. public SecurityContext run() {
  83. try {
  84. return SecurityContextFactory.createSecurityContext(domain);
  85. } catch (Exception e) {
  86. throw new RuntimeException(e);
  87. }
  88. }
  89. });
  90. }
  91. /**
  92. * Set the {@code SecurityContext} on the {@code SecurityContextAssociation}
  93. *
  94. * @param sc the security context
  95. */
  96. private static void setSecurityContextOnAssociation(final SecurityContext sc) {
  97. AccessController.doPrivileged(new PrivilegedAction<Void>() {
  98. @Override
  99. public Void run() {
  100. SecurityContextAssociation.setSecurityContext(sc);
  101. return null;
  102. }
  103. });
  104. }
  105. }