Made message signing in Cryptography use SHA512 as the message content for... #1

Closed
netkas wants to merge 421 commits from master into dev
Showing only changes of commit 998a7ad2ec - Show all commits

View file

@ -6,6 +6,8 @@
use Socialbox\Enums\StandardError; use Socialbox\Enums\StandardError;
use Socialbox\Enums\Types\InformationFieldName; use Socialbox\Enums\Types\InformationFieldName;
use Socialbox\Exceptions\DatabaseOperationException; use Socialbox\Exceptions\DatabaseOperationException;
use Socialbox\Exceptions\Standard\InvalidRpcArgumentException;
use Socialbox\Exceptions\Standard\MissingRpcArgumentException;
use Socialbox\Exceptions\Standard\StandardRpcException; use Socialbox\Exceptions\Standard\StandardRpcException;
use Socialbox\Interfaces\SerializableInterface; use Socialbox\Interfaces\SerializableInterface;
use Socialbox\Managers\PeerInformationManager; use Socialbox\Managers\PeerInformationManager;
@ -16,29 +18,30 @@
{ {
/** /**
* @inheritDoc * @inheritDoc
* @noinspection DuplicatedCode
*/ */
public static function execute(ClientRequest $request, RpcRequest $rpcRequest): ?SerializableInterface public static function execute(ClientRequest $request, RpcRequest $rpcRequest): ?SerializableInterface
{ {
// Field parameter is required // Field parameter is required
if(!$rpcRequest->containsParameter('field')) if(!$rpcRequest->containsParameter('field'))
{ {
return $rpcRequest->produceError(StandardError::RPC_INVALID_ARGUMENTS, 'The required field parameter is missing'); throw new MissingRpcArgumentException('field');
} }
$fieldName = InformationFieldName::tryFrom(strtoupper($rpcRequest->getParameter('field'))); $fieldName = InformationFieldName::tryFrom(strtoupper($rpcRequest->getParameter('field')));
if($fieldName === null) if($fieldName === null)
{ {
return $rpcRequest->produceError(StandardError::RPC_INVALID_ARGUMENTS, 'The provided field parameter is invalid'); throw new InvalidRpcArgumentException('field');
} }
// Value parameter is required // Value parameter is required
if(!$rpcRequest->containsParameter('value')) if(!$rpcRequest->containsParameter('value'))
{ {
return $rpcRequest->produceError(StandardError::RPC_INVALID_ARGUMENTS, 'The required value parameter is missing'); throw new MissingRpcArgumentException('value');
} }
$value = $rpcRequest->getParameter('value'); $value = $rpcRequest->getParameter('value');
if(!$fieldName->validate($value)) if(!$fieldName->validate($value))
{ {
return $rpcRequest->produceError(StandardError::RPC_INVALID_ARGUMENTS, 'The provided value parameter is invalid'); throw new InvalidRpcArgumentException('value');
} }
try try
@ -46,7 +49,7 @@
$peer = $request->getPeer(); $peer = $request->getPeer();
if(!PeerInformationManager::fieldExists($peer, $fieldName)) if(!PeerInformationManager::fieldExists($peer, $fieldName))
{ {
return $rpcRequest->produceError(StandardError::FORBIDDEN, 'The information field does not exist'); return $rpcRequest->produceResponse(false);
} }
PeerInformationManager::updateField($peer, $fieldName, $value); PeerInformationManager::updateField($peer, $fieldName, $value);