
* updated dependencies * updated LV version to 5.6 Depends-On: https://review.openstack.org/629495 Depends-On: https://review.openstack.org/629896 Change-Id: Iacf81dd65d71102ad0660c5c2bdd6633bf727ec0
109 lines
3.2 KiB
PHP
109 lines
3.2 KiB
PHP
<?php namespace Services\OAuth2;
|
|
/**
|
|
* Copyright 2016 OpenStack Foundation
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
**/
|
|
|
|
use OAuth2\Models\IAsymmetricKey;
|
|
use OAuth2\Services\IServerPrivateKeyService;
|
|
use OAuth2\Repositories\IServerPrivateKeyRepository;
|
|
use Utils\Db\ITransactionService;
|
|
use Models\OAuth2\ServerPrivateKey;
|
|
use DateTime;
|
|
use phpseclib\Crypt\RSA;
|
|
use Services\Exceptions\ValidationException;
|
|
|
|
/**
|
|
* Class ServerPrivateKeyService
|
|
* @package Services\OAuth2
|
|
*/
|
|
final class ServerPrivateKeyService extends AsymmetricKeyService implements IServerPrivateKeyService
|
|
{
|
|
|
|
/**
|
|
* @var RSA
|
|
*/
|
|
private $rsa;
|
|
|
|
/**
|
|
* ServerPrivateKeyService constructor.
|
|
* @param IServerPrivateKeyRepository $repository
|
|
* @param ITransactionService $tx_service
|
|
*/
|
|
public function __construct
|
|
(
|
|
IServerPrivateKeyRepository $repository,
|
|
ITransactionService $tx_service
|
|
)
|
|
{
|
|
parent::__construct($repository, $tx_service);
|
|
$this->rsa = new RSA();
|
|
}
|
|
|
|
/**
|
|
* @param array $params
|
|
* @return IAsymmetricKey
|
|
* @throws ValidationException
|
|
*/
|
|
public function register(array $params)
|
|
{
|
|
$rsa = $this->rsa;
|
|
$repository = $this->repository;
|
|
|
|
return $this->tx_service->transaction(function() use($params, $rsa, $repository)
|
|
{
|
|
$pem = isset($params['pem_content']) ? trim($params['pem_content']) : '';
|
|
$password = isset($params['password'])? trim($params['password']) : '';
|
|
|
|
$old_active_key = $repository->getByValidityRange
|
|
(
|
|
$params['type'],
|
|
$params['usage'],
|
|
$params['alg'],
|
|
new DateTime($params['valid_from']),
|
|
new DateTime($params['valid_to'])
|
|
)->first();
|
|
|
|
if(empty($pem))
|
|
{
|
|
if(!empty($password))
|
|
$rsa->setPassword($password);
|
|
/**
|
|
* array(
|
|
* 'privatekey' => $privatekey,
|
|
* 'publickey' => $publickey,
|
|
* 'partialkey' => false
|
|
* );
|
|
*/
|
|
$res = $rsa->createKey(2048);
|
|
$pem = $res['privatekey'];
|
|
}
|
|
|
|
$key = ServerPrivateKey::build
|
|
(
|
|
$params['kid'],
|
|
new DateTime($params['valid_from']),
|
|
new DateTime($params['valid_to']),
|
|
$params['type'],
|
|
$params['usage'],
|
|
$params['alg'],
|
|
$old_active_key ? false : $params['active'],
|
|
$pem,
|
|
$password
|
|
);
|
|
|
|
$repository->add($key);
|
|
|
|
return $key;
|
|
});
|
|
}
|
|
|
|
} |