-
Notifications
You must be signed in to change notification settings - Fork 2.1k
/
Copy pathconsole.php
97 lines (87 loc) · 3.59 KB
/
console.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
<?php
/**
* @author Bart Visscher <[email protected]>
* @author Joas Schilling <[email protected]>
* @author Lukas Reschke <[email protected]>
* @author Morris Jobke <[email protected]>
* @author Patrick Paysant <[email protected]>
* @author Philipp Schaffrath <[email protected]>
* @author RealRancor <[email protected]>
* @author Thomas Müller <[email protected]>
* @author Victor Dubiniuk <[email protected]>
*
* @copyright Copyright (c) 2018, ownCloud GmbH
* @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/>
*
*/
use OC\Console\Application;
use Symfony\Component\Console\Input\ArgvInput;
use Symfony\Component\Console\Output\ConsoleOutput;
\define('OC_CONSOLE', 1);
function exceptionHandler($exception) {
try {
// try to log the exception
\OC::$server->getLogger()->logException($exception, ['app' => 'index']);
} catch (\Throwable $ex) {
// if we can't log normally, use the crashLog
\OC::crashLog($exception);
\OC::crashLog($ex);
} finally {
// always show the exception in the console
echo 'An unhandled exception has been thrown:' . PHP_EOL;
echo $exception;
exit(1);
}
}
try {
require_once __DIR__ . '/lib/base.php';
// set to run indefinitely if needed
\set_time_limit(0);
if (!OC::$CLI) {
echo "This script can be run from the command line only" . PHP_EOL;
exit(1);
}
\set_exception_handler('exceptionHandler');
if (!\function_exists('posix_getuid')) {
echo "The posix extensions are required - see http://php.net/manual/en/book.posix.php" . PHP_EOL;
exit(1);
}
$user = \posix_getpwuid(\posix_getuid());
$configUser = \posix_getpwuid(\fileowner(OC::$configDir . 'config.php'));
if ($user['name'] !== $configUser['name']) {
echo "Console has to be executed with the user that owns the file config/config.php" . PHP_EOL;
echo "Current user: " . $user['name'] . PHP_EOL;
echo "Owner of config.php: " . $configUser['name'] . PHP_EOL;
echo "Try adding 'sudo -u " . $configUser['name'] . " ' to the beginning of the command (without the single quotes)" . PHP_EOL;
exit(1);
}
$oldWorkingDir = \getcwd();
if ($oldWorkingDir === false) {
echo "This script can be run from the ownCloud root directory only." . PHP_EOL;
echo "Can't determine current working dir - the script will continue to work but be aware of the above fact." . PHP_EOL;
} elseif ($oldWorkingDir !== __DIR__ && !\chdir(__DIR__)) {
echo "This script can be run from the ownCloud root directory only." . PHP_EOL;
echo "Can't change to ownCloud root directory." . PHP_EOL;
exit(1);
}
if (!\function_exists('pcntl_signal') && !\in_array('--no-warnings', $argv)) {
echo "The process control (PCNTL) extensions are required in case you want to interrupt long running commands - see http://php.net/manual/en/book.pcntl.php" . PHP_EOL;
}
$application = new Application(\OC::$server->getConfig(), \OC::$server->getEventDispatcher(), \OC::$server->getRequest());
$application->loadCommands(new ArgvInput(), new ConsoleOutput());
$application->run();
} catch (\Throwable $ex) {
exceptionHandler($ex);
}