Introduces a new PHP client SDK generated via OpenAPI for the Lethean blockchain, including source code, models, API classes, documentation, tests, and configuration files. Updates Makefile to support PHP SDK generation and modifies php.json package configuration.
531 lines
13 KiB
PHP
Generated
531 lines
13 KiB
PHP
Generated
<?php
|
|
/**
|
|
* Configuration
|
|
* PHP version 8.1
|
|
*
|
|
* @package lthn
|
|
* @author OpenAPI Generator team
|
|
* @link https://openapi-generator.tech
|
|
*/
|
|
|
|
/**
|
|
* Lethean Blockchain API
|
|
*
|
|
* OpenAPI for Lethean Blockchain
|
|
*
|
|
* The version of the OpenAPI document: 6.0.1
|
|
* @generated Generated by: https://openapi-generator.tech
|
|
* Generator version: 7.16.0
|
|
*/
|
|
|
|
/**
|
|
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
|
|
* https://openapi-generator.tech
|
|
* Do not edit the class manually.
|
|
*/
|
|
|
|
namespace lthn;
|
|
|
|
use InvalidArgumentException;
|
|
|
|
/**
|
|
* Configuration Class Doc Comment
|
|
*
|
|
* @package lthn
|
|
* @author OpenAPI Generator team
|
|
* @link https://openapi-generator.tech
|
|
*/
|
|
class Configuration
|
|
{
|
|
public const BOOLEAN_FORMAT_INT = 'int';
|
|
public const BOOLEAN_FORMAT_STRING = 'string';
|
|
|
|
/**
|
|
* @var Configuration|null
|
|
*/
|
|
private static ?Configuration $defaultConfiguration = null;
|
|
|
|
/**
|
|
* Associate array to store API key(s)
|
|
*
|
|
* @var string[]
|
|
*/
|
|
protected array $apiKeys = [];
|
|
|
|
/**
|
|
* Associate array to store API prefix (e.g. Bearer)
|
|
*
|
|
* @var string[]
|
|
*/
|
|
protected array $apiKeyPrefixes = [];
|
|
|
|
/**
|
|
* Access token for OAuth/Bearer authentication
|
|
*
|
|
* @var string
|
|
*/
|
|
protected string $accessToken = '';
|
|
|
|
/**
|
|
* Boolean format for query string
|
|
*
|
|
* @var string
|
|
*/
|
|
protected string $booleanFormatForQueryString = self::BOOLEAN_FORMAT_INT;
|
|
|
|
/**
|
|
* Username for HTTP basic authentication
|
|
*
|
|
* @var string
|
|
*/
|
|
protected string $username = '';
|
|
|
|
/**
|
|
* Password for HTTP basic authentication
|
|
*
|
|
* @var string
|
|
*/
|
|
protected string $password = '';
|
|
|
|
/**
|
|
* The host
|
|
*
|
|
* @var string
|
|
*/
|
|
protected string $host = 'http://127.0.0.1:36943';
|
|
|
|
/**
|
|
* User agent of the HTTP request, set to "OpenAPI-Generator/{version}/PHP" by default
|
|
*
|
|
* @var string
|
|
*/
|
|
protected string $userAgent = 'OpenAPI-Generator/6.0.1/PHP';
|
|
|
|
/**
|
|
* Debug switch (default set to false)
|
|
*
|
|
* @var bool
|
|
*/
|
|
protected bool $debug = false;
|
|
|
|
/**
|
|
* Debug file location (log to STDOUT by default)
|
|
*
|
|
* @var string
|
|
*/
|
|
protected string $debugFile = 'php://output';
|
|
|
|
/**
|
|
* Debug file location (log to STDOUT by default)
|
|
*
|
|
* @var string
|
|
*/
|
|
protected string $tempFolderPath;
|
|
|
|
/**
|
|
* Constructor
|
|
*/
|
|
public function __construct()
|
|
{
|
|
$this->tempFolderPath = sys_get_temp_dir();
|
|
}
|
|
|
|
/**
|
|
* Sets API key
|
|
*
|
|
* @param string $apiKeyIdentifier API key identifier (authentication scheme)
|
|
* @param string $key API key or token
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setApiKey(string $apiKeyIdentifier, string $key): static
|
|
{
|
|
$this->apiKeys[$apiKeyIdentifier] = $key;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Gets API key
|
|
*
|
|
* @param string $apiKeyIdentifier API key identifier (authentication scheme)
|
|
*
|
|
* @return null|string API key or token
|
|
*/
|
|
public function getApiKey(string $apiKeyIdentifier): ?string
|
|
{
|
|
return $this->apiKeys[$apiKeyIdentifier] ?? null;
|
|
}
|
|
|
|
/**
|
|
* Sets the prefix for API key (e.g. Bearer)
|
|
*
|
|
* @param string $apiKeyIdentifier API key identifier (authentication scheme)
|
|
* @param string $prefix API key prefix, e.g. Bearer
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setApiKeyPrefix(string $apiKeyIdentifier, string $prefix): static
|
|
{
|
|
$this->apiKeyPrefixes[$apiKeyIdentifier] = $prefix;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Gets API key prefix
|
|
*
|
|
* @param string $apiKeyIdentifier API key identifier (authentication scheme)
|
|
*
|
|
* @return null|string
|
|
*/
|
|
public function getApiKeyPrefix(string $apiKeyIdentifier): ?string
|
|
{
|
|
return $this->apiKeyPrefixes[$apiKeyIdentifier] ?? null;
|
|
}
|
|
|
|
/**
|
|
* Sets the access token for OAuth
|
|
*
|
|
* @param string $accessToken Token for OAuth
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setAccessToken(string $accessToken): static
|
|
{
|
|
$this->accessToken = $accessToken;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Gets the access token for OAuth
|
|
*
|
|
* @return string Access token for OAuth
|
|
*/
|
|
public function getAccessToken(): string
|
|
{
|
|
return $this->accessToken;
|
|
}
|
|
|
|
/**
|
|
* Sets boolean format for query string.
|
|
*
|
|
* @param string $booleanFormat Boolean format for query string
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setBooleanFormatForQueryString(string $booleanFormat): static
|
|
{
|
|
$this->booleanFormatForQueryString = $booleanFormat;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Gets boolean format for query string.
|
|
*
|
|
* @return string Boolean format for query string
|
|
*/
|
|
public function getBooleanFormatForQueryString(): string
|
|
{
|
|
return $this->booleanFormatForQueryString;
|
|
}
|
|
|
|
/**
|
|
* Sets the username for HTTP basic authentication
|
|
*
|
|
* @param string $username Username for HTTP basic authentication
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setUsername(string $username): static
|
|
{
|
|
$this->username = $username;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Gets the username for HTTP basic authentication
|
|
*
|
|
* @return string Username for HTTP basic authentication
|
|
*/
|
|
public function getUsername(): string
|
|
{
|
|
return $this->username;
|
|
}
|
|
|
|
/**
|
|
* Sets the password for HTTP basic authentication
|
|
*
|
|
* @param string $password Password for HTTP basic authentication
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setPassword(string $password): static
|
|
{
|
|
$this->password = $password;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Gets the password for HTTP basic authentication
|
|
*
|
|
* @return string Password for HTTP basic authentication
|
|
*/
|
|
public function getPassword(): string
|
|
{
|
|
return $this->password;
|
|
}
|
|
|
|
/**
|
|
* Sets the host
|
|
*
|
|
* @param string $host Host
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setHost(string $host): static
|
|
{
|
|
$this->host = $host;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Gets the host
|
|
*
|
|
* @return string Host
|
|
*/
|
|
public function getHost(): string
|
|
{
|
|
return $this->host;
|
|
}
|
|
|
|
/**
|
|
* Sets the user agent of the api client
|
|
*
|
|
* @param string $userAgent the user agent of the api client
|
|
*
|
|
* @throws InvalidArgumentException
|
|
* @return $this
|
|
*/
|
|
public function setUserAgent(string $userAgent): static
|
|
{
|
|
$this->userAgent = $userAgent;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Gets the user agent of the api client
|
|
*
|
|
* @return string user agent
|
|
*/
|
|
public function getUserAgent(): string
|
|
{
|
|
return $this->userAgent;
|
|
}
|
|
|
|
/**
|
|
* Sets debug flag
|
|
*
|
|
* @param bool $debug Debug flag
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setDebug(bool $debug): static
|
|
{
|
|
$this->debug = $debug;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Gets the debug flag
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function getDebug(): bool
|
|
{
|
|
return $this->debug;
|
|
}
|
|
|
|
/**
|
|
* Sets the debug file
|
|
*
|
|
* @param string $debugFile Debug file
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setDebugFile(string $debugFile): static
|
|
{
|
|
$this->debugFile = $debugFile;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Gets the debug file
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getDebugFile(): string
|
|
{
|
|
return $this->debugFile;
|
|
}
|
|
|
|
/**
|
|
* Sets the temp folder path
|
|
*
|
|
* @param string $tempFolderPath Temp folder path
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setTempFolderPath(string $tempFolderPath): static
|
|
{
|
|
$this->tempFolderPath = $tempFolderPath;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Gets the temp folder path
|
|
*
|
|
* @return string Temp folder path
|
|
*/
|
|
public function getTempFolderPath(): string
|
|
{
|
|
return $this->tempFolderPath;
|
|
}
|
|
|
|
/**
|
|
* Gets the default configuration instance
|
|
*
|
|
* @return Configuration
|
|
*/
|
|
public static function getDefaultConfiguration(): Configuration
|
|
{
|
|
if (self::$defaultConfiguration === null) {
|
|
self::$defaultConfiguration = new Configuration();
|
|
}
|
|
|
|
return self::$defaultConfiguration;
|
|
}
|
|
|
|
/**
|
|
* Sets the default configuration instance
|
|
*
|
|
* @param Configuration $config An instance of the Configuration Object
|
|
*
|
|
* @return void
|
|
*/
|
|
public static function setDefaultConfiguration(Configuration $config): void
|
|
{
|
|
self::$defaultConfiguration = $config;
|
|
}
|
|
|
|
/**
|
|
* Gets the essential information for debugging
|
|
*
|
|
* @return string The report for debugging
|
|
*/
|
|
public static function toDebugReport(): string
|
|
{
|
|
$report = 'PHP SDK (lthn) Debug Report:' . PHP_EOL;
|
|
$report .= ' OS: ' . php_uname() . PHP_EOL;
|
|
$report .= ' PHP Version: ' . PHP_VERSION . PHP_EOL;
|
|
$report .= ' The version of the OpenAPI document: 6.0.1' . PHP_EOL;
|
|
$report .= ' SDK Package Version: 6.0.1' . PHP_EOL;
|
|
$report .= ' Temp Folder Path: ' . self::getDefaultConfiguration()->getTempFolderPath() . PHP_EOL;
|
|
|
|
return $report;
|
|
}
|
|
|
|
/**
|
|
* Get API key (with prefix if set)
|
|
*
|
|
* @param string $apiKeyIdentifier name of apikey
|
|
*
|
|
* @return null|string API key with the prefix
|
|
*/
|
|
public function getApiKeyWithPrefix(string $apiKeyIdentifier): ?string
|
|
{
|
|
$prefix = $this->getApiKeyPrefix($apiKeyIdentifier);
|
|
$apiKey = $this->getApiKey($apiKeyIdentifier);
|
|
|
|
if ($apiKey === null) {
|
|
return null;
|
|
}
|
|
|
|
if ($prefix === null) {
|
|
$keyWithPrefix = $apiKey;
|
|
} else {
|
|
$keyWithPrefix = $prefix . ' ' . $apiKey;
|
|
}
|
|
|
|
return $keyWithPrefix;
|
|
}
|
|
|
|
/**
|
|
* Returns an array of host settings
|
|
*
|
|
* @return array an array of host settings
|
|
*/
|
|
public function getHostSettings(): array
|
|
{
|
|
return [
|
|
[
|
|
"url" => "http://127.0.0.1:36943",
|
|
"description" => "Local Daemon",
|
|
],
|
|
[
|
|
"url" => "http://seed.lethean.io:36943",
|
|
"description" => "Seed Server",
|
|
]
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Returns URL based on host settings, index and variables
|
|
*
|
|
* @param array $hostSettings array of host settings, generated from getHostSettings() or equivalent from the API clients
|
|
* @param int $hostIndex index of the host settings
|
|
* @param array|null $variables hash of variable and the corresponding value (optional)
|
|
* @return string URL based on host settings
|
|
*/
|
|
public static function getHostString(array $hostSettings, int $hostIndex, ?array $variables = null): string
|
|
{
|
|
if (null === $variables) {
|
|
$variables = [];
|
|
}
|
|
|
|
// check array index out of bound
|
|
if ($hostIndex < 0 || $hostIndex >= count($hostSettings)) {
|
|
throw new InvalidArgumentException("Invalid index $hostIndex when selecting the host. Must be less than ".count($hostSettings));
|
|
}
|
|
|
|
$host = $hostSettings[$hostIndex];
|
|
$url = $host["url"];
|
|
|
|
// go through variable and assign a value
|
|
foreach ($host["variables"] ?? [] as $name => $variable) {
|
|
if (array_key_exists($name, $variables)) { // check to see if it's in the variables provided by the user
|
|
if (!isset($variable['enum_values']) || in_array($variables[$name], $variable["enum_values"], true)) { // check to see if the value is in the enum
|
|
$url = str_replace("{".$name."}", $variables[$name], $url);
|
|
} else {
|
|
throw new InvalidArgumentException("The variable `$name` in the host URL has invalid value ".$variables[$name].". Must be ".join(',', $variable["enum_values"]).".");
|
|
}
|
|
} else {
|
|
// use default value
|
|
$url = str_replace("{".$name."}", $variable["default_value"], $url);
|
|
}
|
|
}
|
|
|
|
return $url;
|
|
}
|
|
|
|
/**
|
|
* Returns URL based on the index and variables
|
|
*
|
|
* @param int $index index of the host settings
|
|
* @param array|null $variables hash of variable and the corresponding value (optional)
|
|
* @return string URL based on host settings
|
|
*/
|
|
public function getHostFromSettings(int $index, ?array $variables = null): string
|
|
{
|
|
return self::getHostString($this->getHostSettings(), $index, $variables);
|
|
}
|
|
}
|