Compare commits

..

2 Commits

Author SHA1 Message Date
moltox b3be7a1f22 Merge pull request 'Done' (#2) from 1.2.4 into main
Reviewed-on: #2
2026-05-19 14:37:37 +00:00
Maik Müller 351289dcdc Done 2026-05-19 16:28:49 +02:00
3 changed files with 67 additions and 12 deletions

View File

@ -18,26 +18,38 @@ use Msr\LaravelBitunixApi\Requests\Header;
use Msr\LaravelBitunixApi\Requests\PlaceOrderRequestContract;
use Msr\LaravelBitunixApi\Requests\PlacePositionTpSlOrderRequestContract;
use Msr\LaravelBitunixApi\Requests\PlaceTpSlOrderRequestContract;
use Msr\LaravelBitunixApi\Support\BitunixAccountConfig;
use Psr\Http\Message\ResponseInterface;
class LaravelBitunixApi implements ChangeLeverageRequestContract, ChangeMarginModeRequestContract, FlashClosePositionRequestContract, FutureKLineRequestContract, GetHistoryPositionsRequestContract, GetHistoryTradesRequestContract, GetPendingPositionsRequestContract, GetSingleAccountRequestContract, GetTradingPairsRequestContract, PlaceOrderRequestContract, PlacePositionTpSlOrderRequestContract, PlaceTpSlOrderRequestContract
{
private Client $publicFutureClient;
protected BitunixAccountConfig $config;
public function __construct(protected RateLimiter $rateLimiter)
{
$this->config = BitunixAccountConfig::fromConfig();
$this->publicFutureClient = new Client([
'base_uri' => config('bitunix-api.future_base_uri').'/api/v1/futures/market/',
'base_uri' => ($this->config->baseUrl ?? config('bitunix-api.future_base_uri')).'/api/v1/futures/market/',
]);
}
public function forAccount(BitunixAccountConfig $config): self
{
$this->config = $config;
return $this;
}
protected function getPrivateFutureClient(array $queryParams = [], array $body = []): Client
{
$bodyString = count($body) ? json_encode($body) : '';
$headers = Header::generateHeaders($queryParams, $bodyString);
$headers = Header::generateHeaders($queryParams, $bodyString, $this->config);
return new Client([
'base_uri' => config('bitunix-api.future_base_uri').'/api/v1/futures/',
'base_uri' => ($this->config->baseUrl ?? config('bitunix-api.future_base_uri')).'/api/v1/futures/',
'headers' => $headers,
]);
}
@ -409,6 +421,6 @@ class LaravelBitunixApi implements ChangeLeverageRequestContract, ChangeMarginMo
protected function resolveRateLimitIdentity(): string
{
return (string) config('bitunix-api.api_key');
return (string) ($this->config->accountKey ?? $this->config->apiKey);
}
}

View File

@ -2,6 +2,8 @@
namespace Msr\LaravelBitunixApi\Requests;
use Msr\LaravelBitunixApi\Support\BitunixAccountConfig;
class Header
{
/**
@ -64,13 +66,13 @@ class Header
* 3. Create digest: SHA256(nonce + timestamp + api-key + queryParams + body)
* 4. Create sign: SHA256(digest + secretKey)
*/
public static function generateSignValue(array $queryParams = [], string $body = '', string $nonce = '', string $timestamp = ''): string
public static function generateSignValue(array $queryParams, string $body, string $nonce, string $timestamp, BitunixAccountConfig $config): string
{
$apiKey = config('bitunix-api.api_key');
$apiSecret = config('bitunix-api.api_secret');
$apiKey = $config->apiKey;
$apiSecret = $config->apiSecret;
if (empty($apiKey) || empty($apiSecret)) {
throw new \InvalidArgumentException('API key and secret must be configured');
throw new \InvalidArgumentException('API key and secret must be provided in config');
}
// Step 1: Sort query parameters in ascending ASCII order
@ -97,18 +99,18 @@ class Header
/**
* Generate complete headers for authenticated requests
*/
public static function generateHeaders(array $queryParams = [], string $body = ''): array
public static function generateHeaders(array $queryParams, string $body, BitunixAccountConfig $config): array
{
$nonce = self::generateNonce();
$timestamp = self::generateTimestamp();
$sign = self::generateSignValue($queryParams, $body, $nonce, $timestamp);
$sign = self::generateSignValue($queryParams, $body, $nonce, $timestamp, $config);
return [
'api-key' => config('bitunix-api.api_key'),
'api-key' => $config->apiKey,
'sign' => $sign,
'nonce' => $nonce,
'timestamp' => $timestamp,
'language' => config('bitunix-api.language', 'en-US'),
'language' => $config->language, //config('bitunix-api.language', 'en-US'),
'Content-Type' => 'application/json',
];
}

View File

@ -0,0 +1,41 @@
<?php
namespace Msr\LaravelBitunixApi\Support;
class BitunixAccountConfig
{
public function __construct(
public readonly string $apiKey,
public readonly string $apiSecret,
public readonly ?string $accountKey = null,
public readonly ?string $baseUrl = null,
public readonly ?string $language = 'en-US',
) {
}
public static function fromConfig(): self
{
return new self(
apiKey: config('bitunix-api.api_key'),
apiSecret: config('bitunix-api.api_secret'),
accountKey: config('bitunix-api.account_key', 'default'),
baseUrl: config('bitunix-api.future_base_uri'),
language: config('bitunix-api.language', 'en-US'),
);
}
}