Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * Licensed to the Apache Software Foundation (ASF) under one
   * or more contributor license agreements.  See the NOTICE file
   * distributed with this work for additional information
   * regarding copyright ownership.  The ASF licenses this file
   * to you under the Apache License, Version 2.0 (the
   * "License"); you may not use this file except in compliance
   * with the License.  You may obtain a copy of the License at
   *
  * http://www.apache.org/licenses/LICENSE-2.0
  *
  * Unless required by applicable law or agreed to in writing,
  * software distributed under the License is distributed on an
  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
  * KIND, either express or implied.  See the License for the
  * specific language governing permissions and limitations
  * under the License.
  */
 package org.apache.flume.channel.file.encryption;
 
 import java.io.File;
 import java.util.Map;
 
 
 
 public class JCEFileKeyProvider extends KeyProvider {
   private static final Logger logger =
       LoggerFactory.getLogger(JCEFileKeyProvider.class);
 
   private KeyStore ks;
   private char[] keyStorePassword;
   private File keyStorePasswordFile;
 
   public JCEFileKeyProvider(File keyStoreFileFile keyStorePasswordFile,
       Map<StringFilealiasPasswordFileMap) {
     super();
     this. = aliasPasswordFileMap;
     this. = keyStorePasswordFile;
     try {
        = KeyStore.getInstance("jceks");
        = Files.toString(keyStorePasswordFile.)
           .trim().toCharArray();
       .load(new FileInputStream(keyStoreFile), );
     } catch(Exception ex) {
       throw Throwables.propagate(ex);
     }
   }
 
   @Override
   public Key getKey(String alias) {
     String passwordFile = .getAbsolutePath();
     try {
       char[] keyPassword = ;
       if(.containsKey(alias)) {
         File keyPasswordFile = .get(alias);
         keyPassword = Files.toString(keyPasswordFile,
             .).trim().toCharArray();
         passwordFile = keyPasswordFile.getAbsolutePath();
       }
       Key key = .getKey(aliaskeyPassword);
       if(key == null) {
         throw new IllegalStateException("KeyStore returned null for " + alias);
       }
       return key;
     } catch (Exception e) {
       String msg = e.getClass().getName() + ": " + e.getMessage() + ". " +
           "Key = " + alias + ", passwordFile = " + passwordFile;
       throw new RuntimeException(msge);
     }
   }
 
   public static class Builder implements KeyProvider.Builder {
     @Override
     public KeyProvider build(Context context) {
       String keyStoreFileName = context.getString(
       String keyStorePasswordFileName = context.getString(
       Preconditions.checkState(!Strings.isNullOrEmpty(keyStoreFileName),
           "KeyStore file not specified");
       Preconditions.checkState(!Strings.isNullOrEmpty(keyStorePasswordFileName),
           "KeyStore password  file not specified");
       Map<StringFilealiasPasswordFileMap = Maps.newHashMap();
       String passwordProtectedKeys = context.getString(
      Preconditions.checkState(!Strings.isNullOrEmpty(passwordProtectedKeys),
          "Keys available to KeyStore was not specified or empty");
      for(String passwordName : passwordProtectedKeys.trim().split("\\s+")) {
        String propertyName = Joiner.on(".").join(.,
            passwordName.);
        String passwordFileName = context.getString(propertyName,
            keyStorePasswordFileName);
        File passwordFile = new File(passwordFileName.trim());
        if(passwordFile.isFile()) {
          aliasPasswordFileMap.put(passwordNamepasswordFile);
        } else {
          .warn("Password file for alias " + passwordName +
              " does not exist");
        }
      }
      File keyStoreFile = new File(keyStoreFileName.trim());
      File keyStorePasswordFile = new File(keyStorePasswordFileName.trim());
      return new JCEFileKeyProvider(keyStoreFilekeyStorePasswordFile,
          aliasPasswordFileMap);
    }
  }
New to GrepCode? Check out our FAQ X