1
1
Fork 0
mirror of https://code.mensbeam.com/MensBeam/Arsse.git synced 2025-01-24 12:00:33 +00:00
Arsse/lib/CLI.php

175 lines
6 KiB
PHP
Raw Normal View History

<?php
/** @license MIT
* Copyright 2017 J. King, Dustin Wilson et al.
* See LICENSE and AUTHORS files for details */
declare(strict_types=1);
namespace JKingWeb\Arsse;
2019-03-25 10:45:05 -04:00
use JKingWeb\Arsse\REST\Fever\User as Fever;
class CLI {
2018-11-06 12:32:28 -05:00
const USAGE = <<<USAGE_TEXT
Usage:
2018-11-06 12:32:28 -05:00
arsse.php daemon
arsse.php feed refresh-all
2018-11-06 12:32:28 -05:00
arsse.php feed refresh <n>
arsse.php conf save-defaults [<file>]
arsse.php user [list]
arsse.php user add <username> [<password>]
arsse.php user remove <username>
2019-03-25 10:45:05 -04:00
arsse.php user set-pass <username> [<password>]
[--oldpass=<pass>] [--fever]
arsse.php user unset-pass <username>
[--oldpass=<pass>] [--fever]
arsse.php user auth <username> <password> [--fever]
2018-11-06 12:32:28 -05:00
arsse.php --version
arsse.php --help | -h
The Arsse command-line interface currently allows you to start the refresh
daemon, refresh all feeds or a specific feed by numeric ID, manage users,
or save default configuration to a sample file.
USAGE_TEXT;
2018-11-06 12:32:28 -05:00
protected function usage($prog): string {
$prog = basename($prog);
return str_replace("arsse.php", $prog, self::USAGE);
}
protected function command(array $options, $args): string {
foreach ($options as $cmd) {
foreach (explode(" ", $cmd) as $part) {
if (!$args[$part]) {
continue 2;
}
}
return $cmd;
}
return "";
}
protected function loadConf(): bool {
2018-06-18 10:09:43 -04:00
$conf = file_exists(BASE."config.php") ? new Conf(BASE."config.php") : new Conf;
Arsse::load($conf);
return true;
}
2018-11-06 12:32:28 -05:00
public function dispatch(array $argv = null) {
$argv = $argv ?? $_SERVER['argv'];
$argv0 = array_shift($argv);
$args = \Docopt::handle($this->usage($argv0), [
'argv' => $argv,
'help' => false,
]);
try {
switch ($this->command(["--help", "--version", "daemon", "feed refresh", "feed refresh-all", "conf save-defaults", "user"], $args)) {
2018-11-06 12:32:28 -05:00
case "--help":
echo $this->usage($argv0).\PHP_EOL;
return 0;
case "--version":
echo Arsse::VERSION.\PHP_EOL;
return 0;
case "daemon":
$this->loadConf();
2018-11-06 12:32:28 -05:00
$this->getService()->watch(true);
return 0;
case "feed refresh":
$this->loadConf();
2018-11-06 12:32:28 -05:00
return (int) !Arsse::$db->feedUpdate((int) $args['<n>'], true);
case "feed refresh-all":
$this->loadConf();
$this->getService()->watch(false);
return 0;
case "conf save-defaults":
2018-11-06 12:32:28 -05:00
$file = $args['<file>'];
$file = ($file === "-" ? null : $file) ?? "php://output";
2018-11-06 12:32:28 -05:00
return (int) !($this->getConf())->exportFile($file, true);
case "user":
$this->loadConf();
return $this->userManage($args);
}
} catch (AbstractException $e) {
$this->logError($e->getMessage());
return $e->getCode();
}
}
/** @codeCoverageIgnore */
protected function logError(string $msg) {
2019-01-23 16:34:54 -05:00
fwrite(STDERR, $msg.\PHP_EOL);
}
2018-11-06 12:32:28 -05:00
/** @codeCoverageIgnore */
protected function getService(): Service {
return new Service;
}
2018-11-06 12:32:28 -05:00
/** @codeCoverageIgnore */
protected function getConf(): Conf {
return new Conf;
}
2019-03-25 10:45:05 -04:00
/** @codeCoverageIgnore */
protected function getFever(): Fever {
return new Fever;
}
2018-11-06 12:32:28 -05:00
protected function userManage($args): int {
2019-03-25 17:07:28 -04:00
switch ($this->command(["add", "remove", "set-pass", "unset-pass", "list", "auth"], $args)) {
case "add":
return $this->userAddOrSetPassword("add", $args["<username>"], $args["<password>"]);
case "set-pass":
2019-03-25 10:45:05 -04:00
if ($args['--fever']) {
$passwd = $this->getFever()->register($args["<username>"], $args["<password>"]);
if (is_null($args["<password>"])) {
echo $passwd.\PHP_EOL;
}
return 0;
} else {
return $this->userAddOrSetPassword("passwordSet", $args["<username>"], $args["<password>"], $args["--oldpass"]);
}
case "unset-pass":
if ($args['--fever']) {
2019-03-25 17:07:28 -04:00
$this->getFever()->unregister($args["<username>"]);
2019-03-25 10:45:05 -04:00
} else {
Arsse::$user->passwordUnset($args["<username>"], $args["--oldpass"]);
}
return 0;
case "remove":
return (int) !Arsse::$user->remove($args["<username>"]);
case "auth":
2019-03-25 10:45:05 -04:00
return $this->userAuthenticate($args["<username>"], $args["<password>"], $args["--fever"]);
case "list":
case "":
return $this->userList();
}
}
protected function userAddOrSetPassword(string $method, string $user, string $password = null, string $oldpass = null): int {
2018-11-06 12:32:28 -05:00
$passwd = Arsse::$user->$method(...array_slice(func_get_args(), 1));
2017-08-29 10:50:31 -04:00
if (is_null($password)) {
2017-09-28 19:25:31 -04:00
echo $passwd.\PHP_EOL;
}
return 0;
}
protected function userList(): int {
$list = Arsse::$user->list();
if ($list) {
echo implode(\PHP_EOL, $list).\PHP_EOL;
}
return 0;
}
2019-03-25 10:45:05 -04:00
protected function userAuthenticate(string $user, string $password, bool $fever = false): int {
$result = $fever ? $this->getFever()->authenticate($user, $password) : Arsse::$user->auth($user, $password);
if ($result) {
echo Arsse::$lang->msg("CLI.Auth.Success").\PHP_EOL;
return 0;
} else {
echo Arsse::$lang->msg("CLI.Auth.Failure").\PHP_EOL;
return 1;
}
}
2017-08-29 10:50:31 -04:00
}