Browse Source
Certain tokens can expire
Certain tokens can expire
However due to the nature of what we store in the token (encrypted passwords etc). We can't just delete the tokens because that would make the oauth refresh useless. Signed-off-by: Roeland Jago Douma <roeland@famdouma.nl>pull/9491/head
No known key found for this signature in database
GPG Key ID: F941078878347C0C
11 changed files with 220 additions and 6 deletions
-
56core/Migrations/Version14000Date20180516101403.php
-
2lib/composer/composer/autoload_classmap.php
-
2lib/composer/composer/autoload_static.php
-
41lib/private/Authentication/Exceptions/ExpiredTokenException.php
-
15lib/private/Authentication/Token/DefaultToken.php
-
6lib/private/Authentication/Token/DefaultTokenMapper.php
-
18lib/private/Authentication/Token/DefaultTokenProvider.php
-
2lib/private/Authentication/Token/IProvider.php
-
7lib/private/Authentication/Token/IToken.php
-
75tests/lib/Authentication/Token/DefaultTokenProviderTest.php
-
2version.php
@ -0,0 +1,56 @@ |
|||
<?php |
|||
/** |
|||
* @copyright Copyright (c) 2018 Roeland Jago Douma <roeland@famdouma.nl> |
|||
* |
|||
* @author Roeland Jago Douma <roeland@famdouma.nl> |
|||
* |
|||
* @license GNU AGPL version 3 or any later version |
|||
* |
|||
* This program is free software: you can redistribute it and/or modify |
|||
* it under the terms of the GNU Affero General Public License as |
|||
* published by the Free Software Foundation, either version 3 of the |
|||
* License, or (at your option) any later version. |
|||
* |
|||
* 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 |
|||
* along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
* |
|||
*/ |
|||
|
|||
namespace OC\Core\Migrations; |
|||
|
|||
use OCP\DB\ISchemaWrapper; |
|||
use OCP\Migration\SimpleMigrationStep; |
|||
use OCP\Migration\IOutput; |
|||
|
|||
class Version14000Date20180516101403 extends SimpleMigrationStep { |
|||
|
|||
/** |
|||
* @param IOutput $output |
|||
* @param \Closure $schemaClosure The `\Closure` returns a `ISchemaWrapper` |
|||
* @param array $options |
|||
* @return null|ISchemaWrapper |
|||
*/ |
|||
public function changeSchema(IOutput $output, \Closure $schemaClosure, array $options) { |
|||
/** @var ISchemaWrapper $schema */ |
|||
$schema = $schemaClosure(); |
|||
|
|||
$table = $schema->getTable('authtoken'); |
|||
|
|||
if (!$table->hasColumn('expires')) { |
|||
$table->addColumn('expires', 'integer', [ |
|||
'notnull' => false, |
|||
'length' => 4, |
|||
'default' => null, |
|||
'unsigned' => true, |
|||
]); |
|||
|
|||
return $schema; |
|||
} |
|||
return null; |
|||
} |
|||
} |
|||
@ -0,0 +1,41 @@ |
|||
<?php |
|||
declare(strict_types=1); |
|||
/** |
|||
* @copyright Copyright (c) 2018 Roeland Jago Douma <roeland@famdouma.nl> |
|||
* |
|||
* @author Roeland Jago Douma <roeland@famdouma.nl> |
|||
* |
|||
* @license GNU AGPL version 3 or any later version |
|||
* |
|||
* This program is free software: you can redistribute it and/or modify |
|||
* it under the terms of the GNU Affero General Public License as |
|||
* published by the Free Software Foundation, either version 3 of the |
|||
* License, or (at your option) any later version. |
|||
* |
|||
* 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 |
|||
* along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
* |
|||
*/ |
|||
namespace OC\Authentication\Token; |
|||
|
|||
use OC\Authentication\Exceptions\InvalidTokenException; |
|||
|
|||
class ExpiredTokenException extends InvalidTokenException { |
|||
/** @var IToken */ |
|||
private $token; |
|||
|
|||
public function __construct(IToken $token) { |
|||
parent::__construct(); |
|||
|
|||
$this->token = $token; |
|||
} |
|||
|
|||
public function getToken(): IToken { |
|||
return $this->token; |
|||
} |
|||
} |
|||
Write
Preview
Loading…
Cancel
Save
Reference in new issue