mirror of
https://github.com/nextcloud/server.git
synced 2025-02-07 09:59:46 +00:00
103 lines
2.7 KiB
PHP
103 lines
2.7 KiB
PHP
<?php
|
|
/**
|
|
* SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
|
*/
|
|
namespace OC\Core\Command\User\AuthTokens;
|
|
|
|
use DateTimeImmutable;
|
|
use OC\Authentication\Token\IProvider;
|
|
use OC\Core\Command\Base;
|
|
use Symfony\Component\Console\Command\Command;
|
|
use Symfony\Component\Console\Exception\RuntimeException;
|
|
use Symfony\Component\Console\Input\InputArgument;
|
|
use Symfony\Component\Console\Input\InputInterface;
|
|
use Symfony\Component\Console\Input\InputOption;
|
|
use Symfony\Component\Console\Output\OutputInterface;
|
|
|
|
class Delete extends Base {
|
|
public function __construct(
|
|
protected IProvider $tokenProvider,
|
|
) {
|
|
parent::__construct();
|
|
}
|
|
|
|
protected function configure(): void {
|
|
$this
|
|
->setName('user:auth-tokens:delete')
|
|
->setDescription('Deletes an authentication token')
|
|
->addArgument(
|
|
'uid',
|
|
InputArgument::REQUIRED,
|
|
'ID of the user to delete tokens for'
|
|
)
|
|
->addArgument(
|
|
'id',
|
|
InputArgument::OPTIONAL,
|
|
'ID of the auth token to delete'
|
|
)
|
|
->addOption(
|
|
'last-used-before',
|
|
null,
|
|
InputOption::VALUE_REQUIRED,
|
|
'Delete tokens last used before a given date.'
|
|
);
|
|
}
|
|
|
|
protected function execute(InputInterface $input, OutputInterface $output): int {
|
|
$uid = $input->getArgument('uid');
|
|
$id = (int)$input->getArgument('id');
|
|
$before = $input->getOption('last-used-before');
|
|
|
|
if ($before) {
|
|
if ($id) {
|
|
throw new RuntimeException('Option --last-used-before cannot be used with [<id>]');
|
|
}
|
|
|
|
return $this->deleteLastUsedBefore($uid, $before);
|
|
}
|
|
|
|
if (!$id) {
|
|
throw new RuntimeException('Not enough arguments. Specify the token <id> or use the --last-used-before option.');
|
|
}
|
|
return $this->deleteById($uid, $id);
|
|
}
|
|
|
|
protected function deleteById(string $uid, int $id): int {
|
|
$this->tokenProvider->invalidateTokenById($uid, $id);
|
|
|
|
return Command::SUCCESS;
|
|
}
|
|
|
|
protected function deleteLastUsedBefore(string $uid, string $before): int {
|
|
$date = $this->parseDateOption($before);
|
|
if (!$date) {
|
|
throw new RuntimeException('Invalid date format. Acceptable formats are: ISO8601 (w/o fractions), "YYYY-MM-DD" and Unix time in seconds.');
|
|
}
|
|
|
|
$this->tokenProvider->invalidateLastUsedBefore($uid, $date->getTimestamp());
|
|
|
|
return Command::SUCCESS;
|
|
}
|
|
|
|
/**
|
|
* @return \DateTimeImmutable|false
|
|
*/
|
|
protected function parseDateOption(string $input) {
|
|
$date = false;
|
|
|
|
// Handle Unix timestamp
|
|
if (filter_var($input, FILTER_VALIDATE_INT)) {
|
|
return new DateTimeImmutable('@' . $input);
|
|
}
|
|
|
|
// ISO8601
|
|
$date = DateTimeImmutable::createFromFormat(DateTimeImmutable::ATOM, $input);
|
|
if ($date) {
|
|
return $date;
|
|
}
|
|
|
|
// YYYY-MM-DD
|
|
return DateTimeImmutable::createFromFormat('!Y-m-d', $input);
|
|
}
|
|
}
|