2013-09-01 14:40:50 +00:00
|
|
|
<?php
|
2013-09-19 17:12:16 +00:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2013 Thomas Müller <thomas.mueller@tmit.eu>
|
|
|
|
* Copyright (c) 2013 Bart Visscher <bartv@thisnet.nl>
|
|
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
|
|
* later.
|
|
|
|
* See the COPYING-README file.
|
|
|
|
*/
|
2013-09-01 14:40:50 +00:00
|
|
|
|
|
|
|
namespace OCA\Files\Command;
|
|
|
|
|
2014-06-25 13:22:49 +00:00
|
|
|
use OC\ForbiddenException;
|
2013-09-01 14:40:50 +00:00
|
|
|
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;
|
|
|
|
|
2013-09-02 16:18:12 +00:00
|
|
|
class Scan extends Command {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var \OC\User\Manager $userManager
|
|
|
|
*/
|
|
|
|
private $userManager;
|
|
|
|
|
|
|
|
public function __construct(\OC\User\Manager $userManager) {
|
|
|
|
$this->userManager = $userManager;
|
|
|
|
parent::__construct();
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function configure() {
|
2013-09-01 14:40:50 +00:00
|
|
|
$this
|
|
|
|
->setName('files:scan')
|
|
|
|
->setDescription('rescan filesystem')
|
|
|
|
->addArgument(
|
2014-06-25 13:22:49 +00:00
|
|
|
'user_id',
|
|
|
|
InputArgument::OPTIONAL | InputArgument::IS_ARRAY,
|
|
|
|
'will rescan all files of the given user(s)'
|
|
|
|
)
|
2013-09-01 14:40:50 +00:00
|
|
|
->addOption(
|
2014-06-25 13:22:49 +00:00
|
|
|
'all',
|
|
|
|
null,
|
|
|
|
InputOption::VALUE_NONE,
|
|
|
|
'will rescan all files of all known users'
|
|
|
|
);
|
2013-09-01 14:40:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
protected function scanFiles($user, OutputInterface $output) {
|
|
|
|
$scanner = new \OC\Files\Utils\Scanner($user);
|
2014-06-25 13:22:49 +00:00
|
|
|
$scanner->listen('\OC\Files\Utils\Scanner', 'scanFile', function ($path) use ($output) {
|
2013-09-01 14:40:50 +00:00
|
|
|
$output->writeln("Scanning <info>$path</info>");
|
|
|
|
});
|
2014-06-25 13:22:49 +00:00
|
|
|
$scanner->listen('\OC\Files\Utils\Scanner', 'scanFolder', function ($path) use ($output) {
|
2013-09-01 14:40:50 +00:00
|
|
|
$output->writeln("Scanning <info>$path</info>");
|
|
|
|
});
|
2014-06-25 13:22:49 +00:00
|
|
|
try {
|
|
|
|
$scanner->scan('');
|
|
|
|
} catch (ForbiddenException $e) {
|
|
|
|
$output->writeln("<error>Home storage for user $user not writable</error>");
|
|
|
|
$output->writeln("Make sure you're running the scan command only as the user the web server runs as");
|
|
|
|
}
|
2013-09-01 14:40:50 +00:00
|
|
|
}
|
|
|
|
|
2013-09-02 16:18:12 +00:00
|
|
|
protected function execute(InputInterface $input, OutputInterface $output) {
|
2013-09-01 14:40:50 +00:00
|
|
|
if ($input->getOption('all')) {
|
2013-09-02 16:18:12 +00:00
|
|
|
$users = $this->userManager->search('');
|
2013-09-01 14:40:50 +00:00
|
|
|
} else {
|
|
|
|
$users = $input->getArgument('user_id');
|
|
|
|
}
|
|
|
|
|
2014-06-26 09:58:38 +00:00
|
|
|
if (count($users) === 0) {
|
|
|
|
$output->writeln("<error>Please specify the user id to scan or \"--all\" to scan for all users</error>");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2013-09-01 14:40:50 +00:00
|
|
|
foreach ($users as $user) {
|
2013-09-02 16:18:12 +00:00
|
|
|
if (is_object($user)) {
|
|
|
|
$user = $user->getUID();
|
|
|
|
}
|
2013-09-01 14:40:50 +00:00
|
|
|
$this->scanFiles($user, $output);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|