-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: add precondition failed response handling for domain deletion a…
…nd email resend operations
- Loading branch information
1 parent
7afa5fe
commit 66a4f43
Showing
3 changed files
with
258 additions
and
0 deletions.
There are no files selected for viewing
127 changes: 127 additions & 0 deletions
127
src/Generated/V2/Clients/Domain/DeleteDomain/DeleteDomainPreconditionFailedResponse.php
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,127 @@ | ||
<?php | ||
|
||
declare(strict_types=1); | ||
|
||
namespace Mittwald\ApiClient\Generated\V2\Clients\Domain\DeleteDomain; | ||
|
||
use InvalidArgumentException; | ||
use JsonSchema\Validator; | ||
use Mittwald\ApiClient\Client\ResponseContainer; | ||
use Mittwald\ApiClient\Generated\V2\Schemas\Commons\Error; | ||
use Psr\Http\Message\ResponseInterface; | ||
|
||
class DeleteDomainPreconditionFailedResponse implements ResponseContainer | ||
{ | ||
/** | ||
* Schema used to validate input for creating instances of this class | ||
*/ | ||
private static array $schema = [ | ||
'type' => 'object', | ||
'required' => [ | ||
'body', | ||
], | ||
'properties' => [ | ||
'body' => [ | ||
'$ref' => '#/components/schemas/de.mittwald.v1.commons.Error', | ||
], | ||
], | ||
]; | ||
|
||
private Error $body; | ||
|
||
private ResponseInterface|null $httpResponse = null; | ||
|
||
public function __construct(Error $body) | ||
{ | ||
$this->body = $body; | ||
} | ||
|
||
public function getBody(): Error | ||
{ | ||
return $this->body; | ||
} | ||
|
||
public function withBody(Error $body): self | ||
{ | ||
$clone = clone $this; | ||
$clone->body = $body; | ||
|
||
return $clone; | ||
} | ||
|
||
/** | ||
* Builds a new instance from an input array | ||
* | ||
* @param array|object $input Input data | ||
* @param bool $validate Set this to false to skip validation; use at own risk | ||
* @return DeleteDomainPreconditionFailedResponse Created instance | ||
* @throws InvalidArgumentException | ||
*/ | ||
public static function buildFromInput(array|object $input, bool $validate = true): DeleteDomainPreconditionFailedResponse | ||
{ | ||
$input = is_array($input) ? Validator::arrayToObjectRecursive($input) : $input; | ||
if ($validate) { | ||
static::validateInput($input); | ||
} | ||
|
||
$body = Error::buildFromInput($input->{'body'}, validate: $validate); | ||
|
||
$obj = new self($body); | ||
|
||
return $obj; | ||
} | ||
|
||
/** | ||
* Converts this object back to a simple array that can be JSON-serialized | ||
* | ||
* @return array Converted array | ||
*/ | ||
public function toJson(): array | ||
{ | ||
$output = []; | ||
$output['body'] = $this->body->toJson(); | ||
|
||
return $output; | ||
} | ||
|
||
/** | ||
* Validates an input array | ||
* | ||
* @param array|object $input Input data | ||
* @param bool $return Return instead of throwing errors | ||
* @return bool Validation result | ||
* @throws InvalidArgumentException | ||
*/ | ||
public static function validateInput(array|object $input, bool $return = false): bool | ||
{ | ||
$validator = new \Mittwald\ApiClient\Validator\Validator(); | ||
$input = is_array($input) ? Validator::arrayToObjectRecursive($input) : $input; | ||
$validator->validate($input, static::$schema); | ||
|
||
if (!$validator->isValid() && !$return) { | ||
$errors = array_map(function (array $e): string { | ||
return $e["property"] . ": " . $e["message"]; | ||
}, $validator->getErrors()); | ||
throw new InvalidArgumentException(join(", ", $errors)); | ||
} | ||
|
||
return $validator->isValid(); | ||
} | ||
|
||
public function __clone() | ||
{ | ||
} | ||
|
||
public static function fromResponse(ResponseInterface $httpResponse): self | ||
{ | ||
$parsedBody = json_decode($httpResponse->getBody()->getContents(), associative: true); | ||
$response = static::buildFromInput(['body' => $parsedBody], validate: false); | ||
$response->httpResponse = $httpResponse; | ||
return $response; | ||
} | ||
|
||
public function getResponse(): ResponseInterface|null | ||
{ | ||
return $this->httpResponse; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
127 changes: 127 additions & 0 deletions
127
...rated/V2/Clients/Domain/ResendDomainEmail/ResendDomainEmailPreconditionFailedResponse.php
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,127 @@ | ||
<?php | ||
|
||
declare(strict_types=1); | ||
|
||
namespace Mittwald\ApiClient\Generated\V2\Clients\Domain\ResendDomainEmail; | ||
|
||
use InvalidArgumentException; | ||
use JsonSchema\Validator; | ||
use Mittwald\ApiClient\Client\ResponseContainer; | ||
use Mittwald\ApiClient\Generated\V2\Schemas\Commons\Error; | ||
use Psr\Http\Message\ResponseInterface; | ||
|
||
class ResendDomainEmailPreconditionFailedResponse implements ResponseContainer | ||
{ | ||
/** | ||
* Schema used to validate input for creating instances of this class | ||
*/ | ||
private static array $schema = [ | ||
'type' => 'object', | ||
'required' => [ | ||
'body', | ||
], | ||
'properties' => [ | ||
'body' => [ | ||
'$ref' => '#/components/schemas/de.mittwald.v1.commons.Error', | ||
], | ||
], | ||
]; | ||
|
||
private Error $body; | ||
|
||
private ResponseInterface|null $httpResponse = null; | ||
|
||
public function __construct(Error $body) | ||
{ | ||
$this->body = $body; | ||
} | ||
|
||
public function getBody(): Error | ||
{ | ||
return $this->body; | ||
} | ||
|
||
public function withBody(Error $body): self | ||
{ | ||
$clone = clone $this; | ||
$clone->body = $body; | ||
|
||
return $clone; | ||
} | ||
|
||
/** | ||
* Builds a new instance from an input array | ||
* | ||
* @param array|object $input Input data | ||
* @param bool $validate Set this to false to skip validation; use at own risk | ||
* @return ResendDomainEmailPreconditionFailedResponse Created instance | ||
* @throws InvalidArgumentException | ||
*/ | ||
public static function buildFromInput(array|object $input, bool $validate = true): ResendDomainEmailPreconditionFailedResponse | ||
{ | ||
$input = is_array($input) ? Validator::arrayToObjectRecursive($input) : $input; | ||
if ($validate) { | ||
static::validateInput($input); | ||
} | ||
|
||
$body = Error::buildFromInput($input->{'body'}, validate: $validate); | ||
|
||
$obj = new self($body); | ||
|
||
return $obj; | ||
} | ||
|
||
/** | ||
* Converts this object back to a simple array that can be JSON-serialized | ||
* | ||
* @return array Converted array | ||
*/ | ||
public function toJson(): array | ||
{ | ||
$output = []; | ||
$output['body'] = $this->body->toJson(); | ||
|
||
return $output; | ||
} | ||
|
||
/** | ||
* Validates an input array | ||
* | ||
* @param array|object $input Input data | ||
* @param bool $return Return instead of throwing errors | ||
* @return bool Validation result | ||
* @throws InvalidArgumentException | ||
*/ | ||
public static function validateInput(array|object $input, bool $return = false): bool | ||
{ | ||
$validator = new \Mittwald\ApiClient\Validator\Validator(); | ||
$input = is_array($input) ? Validator::arrayToObjectRecursive($input) : $input; | ||
$validator->validate($input, static::$schema); | ||
|
||
if (!$validator->isValid() && !$return) { | ||
$errors = array_map(function (array $e): string { | ||
return $e["property"] . ": " . $e["message"]; | ||
}, $validator->getErrors()); | ||
throw new InvalidArgumentException(join(", ", $errors)); | ||
} | ||
|
||
return $validator->isValid(); | ||
} | ||
|
||
public function __clone() | ||
{ | ||
} | ||
|
||
public static function fromResponse(ResponseInterface $httpResponse): self | ||
{ | ||
$parsedBody = json_decode($httpResponse->getBody()->getContents(), associative: true); | ||
$response = static::buildFromInput(['body' => $parsedBody], validate: false); | ||
$response->httpResponse = $httpResponse; | ||
return $response; | ||
} | ||
|
||
public function getResponse(): ResponseInterface|null | ||
{ | ||
return $this->httpResponse; | ||
} | ||
} |