From 490929f18c46b5acb48077fc90f1945a303dc7fe Mon Sep 17 00:00:00 2001 From: Tom Robertshaw Date: Wed, 23 Sep 2015 21:20:12 +0100 Subject: [PATCH] Change configure command to be options so it can be customised how it's configured. --- .../Magedbm/Command/ConfigureCommand.php | 91 ++++++++++++------- 1 file changed, 56 insertions(+), 35 deletions(-) diff --git a/src/Meanbee/Magedbm/Command/ConfigureCommand.php b/src/Meanbee/Magedbm/Command/ConfigureCommand.php index faf768a..73e6081 100644 --- a/src/Meanbee/Magedbm/Command/ConfigureCommand.php +++ b/src/Meanbee/Magedbm/Command/ConfigureCommand.php @@ -18,26 +18,30 @@ protected function configure() { $this ->setName('configure') - ->setDescription('Configure with Amazon Credentials') - ->addArgument( - 'key', - InputArgument::REQUIRED, - 'AWS Key' + ->setDescription('Configure with Amazon Credentials.') + ->addOption( + '--key', + '-k', + InputOption::VALUE_REQUIRED, + 'AWS Access Key ID' ) - ->addArgument( - 'secret', - InputArgument::REQUIRED, - 'AWS Secret' + ->addOption( + '--secret', + '-s', + InputOption::VALUE_REQUIRED, + 'AWS Secret Access Key' ) - ->addArgument( + ->addOption( 'region', - InputArgument::REQUIRED, - 'Default Region' + '-r', + InputOption::VALUE_REQUIRED, + 'Default AWS Region' ) - ->addArgument( + ->addOption( 'bucket', - InputArgument::REQUIRED, - 'Default Bucket' + '-b', + InputOption::VALUE_REQUIRED, + 'Default AWS S3 Bucket' ) ->addOption( '--force', @@ -83,28 +87,45 @@ protected function execute(InputInterface $input, OutputInterface $output) exit; } - $credentials = array( - 'default' => array( - 'aws_access_key_id' => $input->getArgument('key'), - 'aws_secret_access_key' => $input->getArgument('secret') - ) - ); - $config = array( - 'default' => array( - 'region' => $input->getArgument('region') - ) - ); - $magedbmconfig = array( - 'default' => array( - 'bucket' => $input->getArgument('bucket') - ) - ); + if ($input->getOption('key') && $input->getOption('secret')) { + $credentials = array( + 'default' => array( + 'aws_access_key_id' => $input->getOption('key'), + 'aws_secret_access_key' => $input->getOption('secret') + ) + ); - $writer->writeToFile($this->getAwsCredentialsPath(), $credentials); - $writer->writeToFile($this->getAwsConfigPath(), $config); - $writer->writeToFile($this->getAppConfigPath(), $magedbmconfig); + $writer->writeToFile($this->getAwsCredentialsPath(), $credentials); + $this->getOutput()->writeln('Successfully configured AWS credentials.'); + } elseif (!file_exists($this->getAwsCredentialsPath())) { + $this->getOutput()->writeln('No AWS credentials were found, nor provided.'); + } + + if ($input->getOption('region')) { + $config = array( + 'default' => array( + 'region' => $input->getOption('region') + ) + ); + + $writer->writeToFile($this->getAwsConfigPath(), $config); + $this->getOutput()->writeln('Successfully configured AWS region config.'); + } else if (!file_exists($this->getAwsConfigPath())) { + $this->getOutput()->writeln('No AWS config was found, nor provided.'); + } + + if ($input->getOption('bucket')) { + $magedbmconfig = array( + 'default' => array( + 'bucket' => $input->getOption('bucket') + ) + ); - $this->getOutput()->writeln('Successfully configured.'); + $writer->writeToFile($this->getAppConfigPath(), $magedbmconfig); + $this->getOutput()->writeln('Successfully configured magedbm config.'); + } elseif (!file_exists($this->getAppConfigPath())) { + $this->getOutput()->writeln('No MageDBM was found, nor provided.'); + } } /**