-
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(contract): add invoice replace settings and new wallet functiona…
…lities - Implemented `invoiceReplaceInvoiceSettings` method in `ContractClient` and `ContractClientImpl`. - Added new customer functionalities: `createRecommendationSuggestion`, `createWallet`, and `getWallet` in `CustomerClient` and `CustomerClientImpl`. - Updated API references and request/response handling for the new features.
- Loading branch information
1 parent
899a0c6
commit b23f31b
Showing
44 changed files
with
6,133 additions
and
0 deletions.
There are no files selected for viewing
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
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
...ontract/InvoiceReplaceInvoiceSettings/InvoiceReplaceInvoiceSettingsBadRequestResponse.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\Contract\InvoiceReplaceInvoiceSettings; | ||
|
||
use InvalidArgumentException; | ||
use JsonSchema\Validator; | ||
use Mittwald\ApiClient\Client\ResponseContainer; | ||
use Mittwald\ApiClient\Generated\V2\Schemas\Commons\ValidationErrors; | ||
use Psr\Http\Message\ResponseInterface; | ||
|
||
class InvoiceReplaceInvoiceSettingsBadRequestResponse 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.ValidationErrors', | ||
], | ||
], | ||
]; | ||
|
||
private ValidationErrors $body; | ||
|
||
private ResponseInterface|null $httpResponse = null; | ||
|
||
public function __construct(ValidationErrors $body) | ||
{ | ||
$this->body = $body; | ||
} | ||
|
||
public function getBody(): ValidationErrors | ||
{ | ||
return $this->body; | ||
} | ||
|
||
public function withBody(ValidationErrors $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 InvoiceReplaceInvoiceSettingsBadRequestResponse Created instance | ||
* @throws InvalidArgumentException | ||
*/ | ||
public static function buildFromInput(array|object $input, bool $validate = true): InvoiceReplaceInvoiceSettingsBadRequestResponse | ||
{ | ||
$input = is_array($input) ? Validator::arrayToObjectRecursive($input) : $input; | ||
if ($validate) { | ||
static::validateInput($input); | ||
} | ||
|
||
$body = ValidationErrors::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; | ||
} | ||
} |
127 changes: 127 additions & 0 deletions
127
...s/Contract/InvoiceReplaceInvoiceSettings/InvoiceReplaceInvoiceSettingsDefaultResponse.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\Contract\InvoiceReplaceInvoiceSettings; | ||
|
||
use InvalidArgumentException; | ||
use JsonSchema\Validator; | ||
use Mittwald\ApiClient\Client\ResponseContainer; | ||
use Mittwald\ApiClient\Generated\V2\Schemas\Commons\Error; | ||
use Psr\Http\Message\ResponseInterface; | ||
|
||
class InvoiceReplaceInvoiceSettingsDefaultResponse 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 InvoiceReplaceInvoiceSettingsDefaultResponse Created instance | ||
* @throws InvalidArgumentException | ||
*/ | ||
public static function buildFromInput(array|object $input, bool $validate = true): InvoiceReplaceInvoiceSettingsDefaultResponse | ||
{ | ||
$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; | ||
} | ||
} |
Oops, something went wrong.