summaryrefslogtreecommitdiffstats
path: root/core/Command
diff options
context:
space:
mode:
authorJoas Schilling <coding@schilljs.com>2016-06-09 14:49:53 +0200
committerJoas Schilling <coding@schilljs.com>2016-07-13 18:43:36 +0200
commitb96f0c99b0cf20b6997e1019c624c1848c006434 (patch)
tree3109aa7cbf7709ca8e1ba22c5a7516eec3de31aa /core/Command
parentc04e7b13c342ee9c1d57cf117f6bb14a157d6b4e (diff)
downloadnextcloud-server-b96f0c99b0cf20b6997e1019c624c1848c006434.tar.gz
nextcloud-server-b96f0c99b0cf20b6997e1019c624c1848c006434.zip
Add a occ command to list/get user preferences
Diffstat (limited to 'core/Command')
-rw-r--r--core/Command/User/Setting.php160
1 files changed, 160 insertions, 0 deletions
diff --git a/core/Command/User/Setting.php b/core/Command/User/Setting.php
new file mode 100644
index 00000000000..887439ba2e0
--- /dev/null
+++ b/core/Command/User/Setting.php
@@ -0,0 +1,160 @@
+<?php
+/**
+ * @author Joas Schilling <nickvergessen@owncloud.com>
+ * @author Laurens Post <lkpost@scept.re>
+ *
+ * @copyright Copyright (c) 2016, ownCloud, Inc.
+ * @license AGPL-3.0
+ *
+ * This code is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License, version 3,
+ * as published by the Free Software Foundation.
+ *
+ * This program 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 Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License, version 3,
+ * along with this program. If not, see <http://www.gnu.org/licenses/>
+ *
+ */
+
+namespace OC\Core\Command\User;
+
+use OC\Core\Command\Base;
+use OCP\IConfig;
+use OCP\IDBConnection;
+use OCP\IUserManager;
+use Symfony\Component\Console\Input\InputInterface;
+use Symfony\Component\Console\Input\InputOption;
+use Symfony\Component\Console\Output\OutputInterface;
+use Symfony\Component\Console\Input\InputArgument;
+
+class Setting extends Base {
+ /** @var IUserManager */
+ protected $userManager;
+
+ /** @var IConfig */
+ protected $config;
+
+ /** @var IDBConnection */
+ protected $connection;
+
+ /**
+ * @param IUserManager $userManager
+ * @param IConfig $config
+ * @param IDBConnection $connection
+ */
+ public function __construct(IUserManager $userManager, IConfig $config, IDBConnection $connection) {
+ parent::__construct();
+ $this->userManager = $userManager;
+ $this->config = $config;
+ $this->connection = $connection;
+ }
+
+ protected function configure() {
+ parent::configure();
+ $this
+ ->setName('user:setting')
+ ->setDescription('adds a user')
+ ->addArgument(
+ 'uid',
+ InputArgument::REQUIRED,
+ 'User ID used to login'
+ )
+ ->addArgument(
+ 'app',
+ InputArgument::OPTIONAL,
+ 'Restrict the preferences to a given app',
+ ''
+ )
+ ->addArgument(
+ 'key',
+ InputArgument::OPTIONAL,
+ 'Setting key to set, get or delete',
+ ''
+ )
+ ->addOption(
+ 'default-value',
+ null,
+ InputOption::VALUE_REQUIRED,
+ '(Only applicable on get) If no default value is set and the config does not exist, the command will exit with 1'
+ )
+ ->addOption(
+ 'ignore-missing-user',
+ null,
+ InputOption::VALUE_NONE,
+ 'Use this option to ignore errors when the user does not exist'
+ )
+ ;
+ }
+
+ protected function checkInput(InputInterface $input) {
+ $uid = $input->getArgument('uid');
+ if (!$input->getOption('ignore-missing-user') && !$this->userManager->userExists($uid)) {
+ throw new \InvalidArgumentException('The user "' . $uid . '" does not exists.');
+ }
+
+ if ($input->getArgument('key') === '' && $input->hasParameterOption('--default-value')) {
+ throw new \InvalidArgumentException('The default-value option can only be used when getting a single setting.');
+ }
+ }
+
+ protected function execute(InputInterface $input, OutputInterface $output) {
+ try {
+ $this->checkInput($input);
+ } catch (\InvalidArgumentException $e) {
+ $output->writeln('<error>' . $e->getMessage() . '</error>');
+ return 1;
+ }
+
+ $uid = $input->getArgument('uid');
+ $app = $input->getArgument('app');
+ $key = $input->getArgument('key');
+
+ if ($key !== '') {
+ $value = $this->config->getUserValue($uid, $app, $key, null);
+ if ($value !== null) {
+ $output->writeln($value);
+ } else {
+ if ($input->hasParameterOption('--default-value')) {
+ $output->writeln($input->getOption('default-value'));
+ } else {
+ $output->writeln('<error>The setting does not exist for user "' . $uid . '".</error>');
+ return 1;
+ }
+ }
+ } else {
+ $this->listUserSettings($input, $output, $uid, $app);
+ }
+
+ return 0;
+ }
+
+ protected function listUserSettings(InputInterface $input, OutputInterface $output, $uid, $app) {
+ $settings = $this->getUserSettings($uid, $app);
+
+ $this->writeArrayInOutputFormat($input, $output, $settings);
+ }
+
+ protected function getUserSettings($uid, $app) {
+ $query = $this->connection->getQueryBuilder();
+ $query->select('*')
+ ->from('preferences')
+ ->where($query->expr()->eq('userid', $query->createNamedParameter($uid)));
+
+ if ($app !== '') {
+ $query->andWhere($query->expr()->eq('appid', $query->createNamedParameter($app)));
+ }
+
+ $result = $query->execute();
+ $settings = [];
+ while ($row = $result->fetch()) {
+ $settings[$row['appid']][$row['configkey']] = $row['configvalue'];
+ }
+ $result->closeCursor();
+
+ return $settings;
+ }
+}