Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
  * JBoss, Home of Professional Open Source
  * Copyright 2005, JBoss Inc., and individual contributors as indicated
  * by the @authors tag. See the copyright.txt 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 GNU Lesser General Public License as
  * published by the Free Software Foundation; either version 2.1 of
 * the License, or (at your option) any later version.
 *
 * 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 GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General 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.jboss.security.auth.callback;
 
 
 
 import  org.jboss.security.util.MBeanServerLocator;

PriviledgedActions used by login modules for decoding passwords

Author(s):
Scott.Stark@jboss.org
Version:
$Revision: 2 $
 
 {
   
The permission required to access decode, decode64
 
    private static final RuntimePermission decodePermission =
       new RuntimePermission("org.jboss.security.auth.spi.DecodeAction.decode"); 
    
    String password;
 
    DecodeAction(String passwordObjectName serviceName)
    {
       this. = password;
       this. = serviceName;
    }

   

Returns:
Throws:
Exception
 
    public Object run() throws Exception
    {  
       // Invoke the decodeb64 op
       byte[] secret = decode64();
       // Convert to UTF-8 base char array
       String secretPassword = new String(secret"UTF-8");
       return secretPassword.toCharArray();
    }
   
   
Decrypt the secret using the cipherKey.

Parameters:
secret - the encrypted secret to decrypt.
Returns:
the decrypted secret
Throws:
Exception
 
   private byte[] decode64(String secret)
      throws Exception
   {
      SecurityManager sm = System.getSecurityManager();
      ifsm != null )
         sm.checkPermission();
 
      MBeanServer server = MBeanServerLocator.locateJBoss();
      return (byte[]) server.invoke("decode64"new Object[] {secret}, 
            new String[] {String.class.getName()});
   }
   
    static char[] decode(String passwordObjectName serviceName)
       throws Exception
    {
       DecodeAction action = new DecodeAction(passwordserviceName);
       try
       {
          char[] decode = (char[]) AccessController.doPrivileged(action);
          return decode;
       }
       catch(PrivilegedActionException e)
       {
          throw e.getException();
       }
    }
New to GrepCode? Check out our FAQ X