001 /*
002 * Cumulus4j - Securing your data in the cloud - http://cumulus4j.org
003 * Copyright (C) 2011 NightLabs Consulting GmbH
004 *
005 * This program is free software: you can redistribute it and/or modify
006 * it under the terms of the GNU Affero General Public License as
007 * published by the Free Software Foundation, either version 3 of the
008 * License, or (at your option) any later version.
009 *
010 * This program is distributed in the hope that it will be useful,
011 * but WITHOUT ANY WARRANTY; without even the implied warranty of
012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
013 * GNU Affero General Public License for more details.
014 *
015 * You should have received a copy of the GNU Affero General Public License
016 * along with this program. If not, see <http://www.gnu.org/licenses/>.
017 */
018 package org.cumulus4j.keymanager.cli;
019
020 import org.kohsuke.args4j.Option;
021
022 /**
023 * <p>
024 * Abstract {@link SubCommand} implementation for being subclassed when a key-store and authentication
025 * (user + password) is used.
026 * </p>
027 * @author Marco หงุ่ยตระกูล-Schulze - marco at nightlabs dot de
028 */
029 public abstract class SubCommandWithKeyStoreWithAuth
030 extends SubCommandWithKeyStore
031 {
032 @Option(name="-authUserName", required=true, usage="The authenticated user authorizing this action. If the very first user is created, this value is ignored.")
033 private String authUserName;
034
035 public String getAuthUserName()
036 {
037 return authUserName;
038 }
039
040 @Option(name="-authPassword", required=false, usage="The password for authenticating the user specified by -authUserName. If the very first user is created, this value is ignored. If omitted, the user will be asked interactively (if required, i.e. if not creating the very first user).")
041 private String authPassword;
042
043 public char[] getAuthPasswordAsCharArray()
044 {
045 return authPassword == null ? null : authPassword.toCharArray();
046 }
047
048 public String getAuthPassword()
049 {
050 return authPassword;
051 }
052
053 @Override
054 public void prepare() throws Exception
055 {
056 super.prepare();
057 if (authPassword == null && !getKeyStore().isEmpty())
058 authPassword = promptPassword("authPassword: ");
059 }
060 }