SecurityActions.java

/*
 * IronJacamar, a Java EE Connector Architecture implementation
 * Copyright 2015, Red Hat Inc, and individual contributors
 * as indicated by the @author tags. See the copyright.txt file in the
 * distribution for a full listing of individual contributors.
 *
 * This is free software; you can redistribute it and/or modify it
 * under the terms of the Eclipse Public License 1.0 as
 * published by the Free Software Foundation.
 *
 * This software is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the Eclipse
 * Public License for more details.
 *
 * You should have received a copy of the Eclipse Public License 
 * along with this software; if not, write to the Free
 * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
 */

package org.ironjacamar.core.tx.narayana;

import org.ironjacamar.core.security.SimplePrincipal;
import org.ironjacamar.core.spi.security.SubjectFactory;

import java.security.AccessController;
import java.security.Principal;
import java.security.PrivilegedAction;
import java.util.HashSet;
import java.util.Set;

import javax.resource.spi.ManagedConnectionFactory;
import javax.resource.spi.security.PasswordCredential;
import javax.security.auth.Subject;

/**
 * Privileged Blocks
 * @author <a href="mailto:jesper.pedersen@ironjacamar.org">Jesper Pedersen</a>
 */
class SecurityActions
{ 
   /**
    * Constructor
    */
   private SecurityActions()
   {
   }

   /**
    * Get a Subject instance
    * @param recoverUserName The user name
    * @param recoverPassword The password
    * @param mcf The ManagedConnectionFactory
    * @return The instance
    */
   static Subject createSubject(final String recoverUserName, final String recoverPassword,
                                final ManagedConnectionFactory mcf)
   {
      if (System.getSecurityManager() == null)
      {
         Set<Principal> principals = new HashSet<Principal>();
         Set<Object> pubCredentials = new HashSet<Object>();
         Set<Object> privCredentials = new HashSet<Object>();

         // Principals
         Principal p = new SimplePrincipal(recoverUserName);
         principals.add(p);

         // PublicCredentials
         // None

         // PrivateCredentials
         PasswordCredential pc = new PasswordCredential(recoverUserName, recoverPassword.toCharArray());
         pc.setManagedConnectionFactory(mcf);
         privCredentials.add(pc);

         return new Subject(false, principals, pubCredentials, privCredentials);
      }

      return AccessController.doPrivileged(new PrivilegedAction<Subject>() 
      {
         public Subject run()
         {
            Set<Principal> principals = new HashSet<Principal>();
            Set<Object> pubCredentials = new HashSet<Object>();
            Set<Object> privCredentials = new HashSet<Object>();

            // Principals
            Principal p = new SimplePrincipal(recoverUserName);
            principals.add(p);

            // PublicCredentials
            // None

            // PrivateCredentials
            PasswordCredential pc = new PasswordCredential(recoverUserName, recoverPassword.toCharArray());
            pc.setManagedConnectionFactory(mcf);
            privCredentials.add(pc);

            return new Subject(false, principals, pubCredentials, privCredentials);
         }
      });
   }

   /**
    * Get a Subject instance
    * @param subjectFactory The subject factory
    * @param domain The domain
    * @return The instance
    */
   static Subject createSubject(final SubjectFactory subjectFactory, final String domain)
   {
      if (System.getSecurityManager() == null)
         return subjectFactory.createSubject(domain);

      return AccessController.doPrivileged(new PrivilegedAction<Subject>() 
      {
         public Subject run()
         {
            return subjectFactory.createSubject(domain);
         }
      });
   }

   /**
    * Get the PasswordCredential from the Subject
    * @param subject The subject
    * @return The instances
    */
   static Set<PasswordCredential> getPasswordCredentials(final Subject subject)
   {
      if (System.getSecurityManager() == null)
         return subject.getPrivateCredentials(PasswordCredential.class);

      return AccessController.doPrivileged(new PrivilegedAction<Set<PasswordCredential>>() 
      {
         public Set<PasswordCredential> run()
         {
            return subject.getPrivateCredentials(PasswordCredential.class);
         }
      });
   }
}