From 4bfb162558c7b505202d2bedd1f7c3f92907d5e0 Mon Sep 17 00:00:00 2001 From: Arthur Schiwon Date: Tue, 3 Jun 2014 12:35:18 +0200 Subject: command line tools to see, modify and test existing LDAP configurations --- apps/user_ldap/appinfo/register_command.php | 11 +++++ apps/user_ldap/command/setconfig.php | 69 ++++++++++++++++++++++++++ apps/user_ldap/command/showconfig.php | 77 +++++++++++++++++++++++++++++ apps/user_ldap/command/testconfig.php | 75 ++++++++++++++++++++++++++++ apps/user_ldap/lib/configuration.php | 2 +- 5 files changed, 233 insertions(+), 1 deletion(-) create mode 100644 apps/user_ldap/appinfo/register_command.php create mode 100644 apps/user_ldap/command/setconfig.php create mode 100644 apps/user_ldap/command/showconfig.php create mode 100644 apps/user_ldap/command/testconfig.php (limited to 'apps') diff --git a/apps/user_ldap/appinfo/register_command.php b/apps/user_ldap/appinfo/register_command.php new file mode 100644 index 00000000000..57e0ccbdad4 --- /dev/null +++ b/apps/user_ldap/appinfo/register_command.php @@ -0,0 +1,11 @@ + + * This file is licensed under the Affero General Public License version 3 or + * later. + * See the COPYING-README file. + */ + +$application->add(new OCA\user_ldap\Command\showConfig()); +$application->add(new OCA\user_ldap\Command\setConfig()); +$application->add(new OCA\user_ldap\Command\testConfig()); diff --git a/apps/user_ldap/command/setconfig.php b/apps/user_ldap/command/setconfig.php new file mode 100644 index 00000000000..465537a350f --- /dev/null +++ b/apps/user_ldap/command/setconfig.php @@ -0,0 +1,69 @@ + + * This file is licensed under the Affero General Public License version 3 or + * later. + * See the COPYING-README file. + */ + +namespace OCA\user_ldap\Command; + +use Symfony\Component\Console\Command\Command; +use Symfony\Component\Console\Input\InputArgument; +use Symfony\Component\Console\Input\InputInterface; +use Symfony\Component\Console\Input\InputOption; +use Symfony\Component\Console\Output\OutputInterface; +use \OCA\user_ldap\lib\Helper; +use \OCA\user_ldap\lib\Configuration; + +class SetConfig extends Command { + + protected function configure() { + $this + ->setName('ldap:set-config') + ->setDescription('shows the LDAP configuration') + ->addArgument( + 'configID', + InputArgument::REQUIRED, + 'the configuration ID' + ) + ->addArgument( + 'configKey', + InputArgument::REQUIRED, + 'the configuration key' + ) + ->addArgument( + 'configValue', + InputArgument::REQUIRED, + 'the new configuration value' + ) + ; + } + + protected function execute(InputInterface $input, OutputInterface $output) { + $availableConfigs = Helper::getServerConfigurationPrefixes(); + $configID = $input->getArgument('configID'); + if(!in_array($configID, $availableConfigs)) { + $output->writeln("Invalid configID"); + return; + } + + $this->setValue( + $configID, + $input->getArgument('configKey'), + $input->getArgument('configValue') + ); + } + + /** + * save the configuration value as provided + * @param string configID + * @param string configKey + * @param string configValue + */ + protected function setValue($configID, $key, $value) { + $configHolder = new Configuration($configID); + $configHolder->$key = $value; + $configHolder->saveConfiguration(); + } +} diff --git a/apps/user_ldap/command/showconfig.php b/apps/user_ldap/command/showconfig.php new file mode 100644 index 00000000000..e15ec4a2387 --- /dev/null +++ b/apps/user_ldap/command/showconfig.php @@ -0,0 +1,77 @@ + + * This file is licensed under the Affero General Public License version 3 or + * later. + * See the COPYING-README file. + */ + +namespace OCA\user_ldap\Command; + +use Symfony\Component\Console\Command\Command; +use Symfony\Component\Console\Input\InputArgument; +use Symfony\Component\Console\Input\InputInterface; +use Symfony\Component\Console\Input\InputOption; +use Symfony\Component\Console\Output\OutputInterface; +use \OCA\user_ldap\lib\Helper; +use \OCA\user_ldap\lib\Configuration; + +class ShowConfig extends Command { + + protected function configure() { + $this + ->setName('ldap:show-config') + ->setDescription('shows the LDAP configuration') + ->addArgument( + 'configID', + InputArgument::OPTIONAL, + 'will show the configuration of the specified id' + ) + ; + } + + protected function execute(InputInterface $input, OutputInterface $output) { + $availableConfigs = Helper::getServerConfigurationPrefixes(); + $configID = $input->getArgument('configID'); + if(!is_null($configID)) { + $configIDs[] = $configID; + if(!in_array($configIDs[0], $availableConfigs)) { + $output->writeln("Invalid configID"); + return; + } + } else { + $configIDs = $availableConfigs; + } + + $this->renderConfigs($configIDs, $output); + } + + /** + * prints the LDAP configuration(s) + * @param string[] configID(s) + * @param OutputInterface $output + */ + protected function renderConfigs($configIDs, $output) { + $ldapWrapper = new \OCA\user_ldap\lib\LDAP(); + foreach($configIDs as $id) { + $configHolder = new Configuration($id); + $configuration = $configHolder->getConfiguration(); + ksort($configuration); + + $table = $this->getHelperSet()->get('table'); + $table->setHeaders(array('Configuration', $id)); + $rows = array(); + foreach($configuration as $key => $value) { + if($key === 'ldapAgentPassword') { + $value = '***'; + } + if(is_array($value)) { + $value = implode(';', $value); + } + $rows[] = array($key, $value); + } + $table->setRows($rows); + $table->render($output); + } + } +} diff --git a/apps/user_ldap/command/testconfig.php b/apps/user_ldap/command/testconfig.php new file mode 100644 index 00000000000..3bf91458b5b --- /dev/null +++ b/apps/user_ldap/command/testconfig.php @@ -0,0 +1,75 @@ + + * This file is licensed under the Affero General Public License version 3 or + * later. + * See the COPYING-README file. + */ + +namespace OCA\user_ldap\Command; + +use Symfony\Component\Console\Command\Command; +use Symfony\Component\Console\Input\InputArgument; +use Symfony\Component\Console\Input\InputInterface; +use Symfony\Component\Console\Input\InputOption; +use Symfony\Component\Console\Output\OutputInterface; +use \OCA\user_ldap\lib\Helper; +use \OCA\user_ldap\lib\Connection; + +class TestConfig extends Command { + + protected function configure() { + $this + ->setName('ldap:test-config') + ->setDescription('shows the LDAP configuration') + ->addArgument( + 'configID', + InputArgument::REQUIRED, + 'the configuration ID' + ) + ; + } + + protected function execute(InputInterface $input, OutputInterface $output) { + $availableConfigs = Helper::getServerConfigurationPrefixes(); + $configID = $input->getArgument('configID'); + if(!in_array($configID, $availableConfigs)) { + $output->writeln("Invalid configID"); + return; + } + + $result = $this->testConfig($configID); + if($result === 0) { + $output->writeln('The configuration is valid and the connection could be established!'); + } else if($result === 1) { + $output->writeln('The configuration is invalid. Please have a look at the logs for further details.'); + } else if($result === 2) { + $output->writeln('The configuration is valid, but the Bind failed. Please check the server settings and credentials.'); + } else { + $output->writeln('Your LDAP server was kidnapped by aliens.'); + } + } + + /** + * tests the specified connection + * @param string configID + * @return int + */ + protected function testConfig($configID) { + $lw = new \OCA\user_ldap\lib\LDAP(); + $connection = new Connection($lw, $configID); + + //ensure validation is run before we attempt the bind + $connection->getConfiguration(); + + if(!$connection->setConfiguration(array( + 'ldap_configuration_active' => 1, + ))) { + return 1; + } + if($connection->bind()) { + return 0; + } + return 2; + } +} diff --git a/apps/user_ldap/lib/configuration.php b/apps/user_ldap/lib/configuration.php index 9c455929b4a..4cb00561b3f 100644 --- a/apps/user_ldap/lib/configuration.php +++ b/apps/user_ldap/lib/configuration.php @@ -272,7 +272,7 @@ class Configuration { if(empty($value)) { $value = ''; } else if (!is_array($value)) { - $value = preg_split('/\r\n|\r|\n/', $value); + $value = preg_split('/\r\n|\r|\n|;/', $value); if($value === false) { $value = ''; } -- cgit v1.2.3 From 75d320cc91207d0ee942a09ec61d03b166e26c9c Mon Sep 17 00:00:00 2001 From: Arthur Schiwon Date: Tue, 3 Jun 2014 12:36:42 +0200 Subject: fix description texts --- apps/user_ldap/command/setconfig.php | 2 +- apps/user_ldap/command/testconfig.php | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) (limited to 'apps') diff --git a/apps/user_ldap/command/setconfig.php b/apps/user_ldap/command/setconfig.php index 465537a350f..5326c3a648d 100644 --- a/apps/user_ldap/command/setconfig.php +++ b/apps/user_ldap/command/setconfig.php @@ -21,7 +21,7 @@ class SetConfig extends Command { protected function configure() { $this ->setName('ldap:set-config') - ->setDescription('shows the LDAP configuration') + ->setDescription('modifies an LDAP configuration') ->addArgument( 'configID', InputArgument::REQUIRED, diff --git a/apps/user_ldap/command/testconfig.php b/apps/user_ldap/command/testconfig.php index 3bf91458b5b..e393e5dd9b8 100644 --- a/apps/user_ldap/command/testconfig.php +++ b/apps/user_ldap/command/testconfig.php @@ -21,7 +21,7 @@ class TestConfig extends Command { protected function configure() { $this ->setName('ldap:test-config') - ->setDescription('shows the LDAP configuration') + ->setDescription('tests an LDAP configuration') ->addArgument( 'configID', InputArgument::REQUIRED, -- cgit v1.2.3 From 70ae7fa091cb396f82005e17a849d3d0ac8c9751 Mon Sep 17 00:00:00 2001 From: Thomas Müller Date: Tue, 3 Jun 2014 19:10:18 +0200 Subject: Fix casing and PHPDoc --- apps/user_ldap/appinfo/register_command.php | 6 +++--- apps/user_ldap/command/setconfig.php | 6 +++--- apps/user_ldap/command/showconfig.php | 1 - apps/user_ldap/command/testconfig.php | 2 +- 4 files changed, 7 insertions(+), 8 deletions(-) (limited to 'apps') diff --git a/apps/user_ldap/appinfo/register_command.php b/apps/user_ldap/appinfo/register_command.php index 57e0ccbdad4..10d992531c4 100644 --- a/apps/user_ldap/appinfo/register_command.php +++ b/apps/user_ldap/appinfo/register_command.php @@ -6,6 +6,6 @@ * See the COPYING-README file. */ -$application->add(new OCA\user_ldap\Command\showConfig()); -$application->add(new OCA\user_ldap\Command\setConfig()); -$application->add(new OCA\user_ldap\Command\testConfig()); +$application->add(new OCA\user_ldap\Command\ShowConfig()); +$application->add(new OCA\user_ldap\Command\SetConfig()); +$application->add(new OCA\user_ldap\Command\TestConfig()); diff --git a/apps/user_ldap/command/setconfig.php b/apps/user_ldap/command/setconfig.php index 5326c3a648d..ab1c8d39ead 100644 --- a/apps/user_ldap/command/setconfig.php +++ b/apps/user_ldap/command/setconfig.php @@ -57,9 +57,9 @@ class SetConfig extends Command { /** * save the configuration value as provided - * @param string configID - * @param string configKey - * @param string configValue + * @param string $configID + * @param string $configKey + * @param string $configValue */ protected function setValue($configID, $key, $value) { $configHolder = new Configuration($configID); diff --git a/apps/user_ldap/command/showconfig.php b/apps/user_ldap/command/showconfig.php index e15ec4a2387..f51d641beec 100644 --- a/apps/user_ldap/command/showconfig.php +++ b/apps/user_ldap/command/showconfig.php @@ -52,7 +52,6 @@ class ShowConfig extends Command { * @param OutputInterface $output */ protected function renderConfigs($configIDs, $output) { - $ldapWrapper = new \OCA\user_ldap\lib\LDAP(); foreach($configIDs as $id) { $configHolder = new Configuration($id); $configuration = $configHolder->getConfiguration(); diff --git a/apps/user_ldap/command/testconfig.php b/apps/user_ldap/command/testconfig.php index e393e5dd9b8..00b4acf2f66 100644 --- a/apps/user_ldap/command/testconfig.php +++ b/apps/user_ldap/command/testconfig.php @@ -52,7 +52,7 @@ class TestConfig extends Command { /** * tests the specified connection - * @param string configID + * @param string $configID * @return int */ protected function testConfig($configID) { -- cgit v1.2.3