Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
  * JBoss, Home of Professional Open Source.
  * Copyright 2011, Red Hat Middleware LLC, 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 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.as.security.vault;
 
 import java.util.Map;
 

Author(s):
Kabir Khan
 
 public class RuntimeVaultReader extends AbstractVaultReader {
 
     private static final Pattern VAULT_PATTERN = Pattern.compile("VAULT::.*::.*::.*");
 
     private volatile SecurityVault vault;


    
This constructor should remain protected to keep the vault as invisible as possible, but it needs to be exposed for service plug-ability.
 
     public RuntimeVaultReader() {
     }
 
     protected void createVault(final String fqnfinal Map<StringObjectoptionsthrows VaultReaderException {
         Map<StringObjectvaultOptions = new HashMap<StringObject>(options);
         SecurityVault vault = null;
         try {
             vault = AccessController.doPrivileged(new PrivilegedExceptionAction<SecurityVault>() {
                 @Override
                 public SecurityVault run() throws Exception {
                     if (fqn == null || fqn.isEmpty()) {
                         return SecurityVaultFactory.get();
                     } else {
                         return SecurityVaultFactory.get(fqn);
                     }
                 }
             });
         } catch (PrivilegedActionException e) {
             Throwable t = e.getCause();
             if (t instanceof SecurityVaultException) {
                 throw ..vaultReaderException(t);
             }
             if (t instanceof RuntimeException) {
                 throw ..runtimeException(t);
             }
             throw ..runtimeException(t);
         }
         try {
             vault.init(vaultOptions);
         } catch (SecurityVaultException e) {
             throw ..vaultReaderException(e);
         }
         this. = vault;
     }
 
     protected void destroyVault() {
         //TODO - there are no cleanup methods in the vault itself
          = null;
     }
 
     public String retrieveFromVault(final String passwordthrows SecurityException {
         if (isVaultFormat(password)) {
 
             if ( == null) {
                 throw ..vaultNotInitializedException();
             }
            try {
                return getValueAsString(password);
            } catch (SecurityVaultException e) {
                throw ..securityException(e);
            }
        }
        return password;
    }
    private String getValueAsString(String vaultStringthrows SecurityVaultException {
        char[] val = getValue(vaultString);
        if (val != null)
            return new String(val);
        return null;
    }
    public boolean isVaultFormat(String str) {
        return str != null && .matcher(str).matches();
    }
    private char[] getValue(String vaultStringthrows SecurityVaultException {
        String[] tokens = tokens(vaultString);
        byte[] sharedKey = null;
        if (tokens.length > 2) {
            // only in case of conversion of old vault implementation
            sharedKey = tokens[3].getBytes(.);
        }
        return .retrieve(tokens[1], tokens[2], sharedKey);
    }
    private String[] tokens(String vaultString) {
        StringTokenizer tokenizer = new StringTokenizer(vaultString"::");
        int length = tokenizer.countTokens();
        String[] tokens = new String[length];
        int index = 0;
        while (tokenizer != null && tokenizer.hasMoreTokens()) {
            tokens[index++] = tokenizer.nextToken();
        }
        return tokens;
    }
New to GrepCode? Check out our FAQ X