- Implementado servicio backend [PaymentIntentService](cci:2://file:///home/unms/data/ucrm/ucrm/data/plugins/siip-stripe-payment_intents/src/PaymentIntentService.php:8:0-152:1) para manejar interacciones con API de UCRM y Stripe. - Creado frontend moderno y responsivo en HTML/JS dentro de [public.php](cci:7://file:///home/unms/data/ucrm/ucrm/data/plugins/siip-stripe-payment_intents/public.php:0:0-0:0). - Agregada búsqueda con autocompletado para clientes. - Agregada validación para Stripe Customer ID y monto mínimo. - Integrada la creación de Payment Intents de Stripe para fondos tipo `customer_balance`. - Agregada documentación (README.md, CHANGELOG.md) y limpieza de archivos legado.
112 lines
3.0 KiB
PHP
112 lines
3.0 KiB
PHP
<?php
|
|
|
|
namespace Stripe\Service;
|
|
|
|
/**
|
|
* Abstract base class for all services.
|
|
*/
|
|
abstract class AbstractService
|
|
{
|
|
/**
|
|
* @var \Stripe\StripeClientInterface
|
|
*/
|
|
protected $client;
|
|
|
|
/**
|
|
* @var \Stripe\StripeStreamingClientInterface
|
|
*/
|
|
protected $streamingClient;
|
|
|
|
/**
|
|
* Initializes a new instance of the {@link AbstractService} class.
|
|
*
|
|
* @param \Stripe\StripeClientInterface $client
|
|
*/
|
|
public function __construct($client)
|
|
{
|
|
$this->client = $client;
|
|
$this->streamingClient = $client;
|
|
}
|
|
|
|
/**
|
|
* Gets the client used by this service to send requests.
|
|
*
|
|
* @return \Stripe\StripeClientInterface
|
|
*/
|
|
public function getClient()
|
|
{
|
|
return $this->client;
|
|
}
|
|
|
|
/**
|
|
* Gets the client used by this service to send requests.
|
|
*
|
|
* @return \Stripe\StripeStreamingClientInterface
|
|
*/
|
|
public function getStreamingClient()
|
|
{
|
|
return $this->streamingClient;
|
|
}
|
|
|
|
/**
|
|
* Translate null values to empty strings. For service methods,
|
|
* we interpret null as a request to unset the field, which
|
|
* corresponds to sending an empty string for the field to the
|
|
* API.
|
|
*
|
|
* @param null|array $params
|
|
*/
|
|
private static function formatParams($params)
|
|
{
|
|
if (null === $params) {
|
|
return null;
|
|
}
|
|
\array_walk_recursive($params, function (&$value, $key) {
|
|
if (null === $value) {
|
|
$value = '';
|
|
}
|
|
});
|
|
|
|
return $params;
|
|
}
|
|
|
|
protected function request($method, $path, $params, $opts)
|
|
{
|
|
return $this->getClient()->request($method, $path, self::formatParams($params), $opts);
|
|
}
|
|
|
|
protected function requestStream($method, $path, $readBodyChunkCallable, $params, $opts)
|
|
{
|
|
// TODO (MAJOR): Add this method to StripeClientInterface
|
|
// @phpstan-ignore-next-line
|
|
return $this->getStreamingClient()->requestStream($method, $path, $readBodyChunkCallable, self::formatParams($params), $opts);
|
|
}
|
|
|
|
protected function requestCollection($method, $path, $params, $opts)
|
|
{
|
|
// TODO (MAJOR): Add this method to StripeClientInterface
|
|
// @phpstan-ignore-next-line
|
|
return $this->getClient()->requestCollection($method, $path, self::formatParams($params), $opts);
|
|
}
|
|
|
|
protected function requestSearchResult($method, $path, $params, $opts)
|
|
{
|
|
// TODO (MAJOR): Add this method to StripeClientInterface
|
|
// @phpstan-ignore-next-line
|
|
return $this->getClient()->requestSearchResult($method, $path, self::formatParams($params), $opts);
|
|
}
|
|
|
|
protected function buildPath($basePath, ...$ids)
|
|
{
|
|
foreach ($ids as $id) {
|
|
if (null === $id || '' === \trim($id)) {
|
|
$msg = 'The resource ID cannot be null or whitespace.';
|
|
|
|
throw new \Stripe\Exception\InvalidArgumentException($msg);
|
|
}
|
|
}
|
|
|
|
return \sprintf($basePath, ...\array_map('\urlencode', $ids));
|
|
}
|
|
}
|