a.treschilov / tinkoff-invest-api-sdk
PHP SDK for Tinkoff invest API V2
v0.3.11
2025-03-12 16:04 UTC
Requires
- php: ^8.3
- ext-grpc: ^1.66
- google/common-protos: ^v4.8.3
- google/protobuf: ^4.29.2
- grpc/grpc: ^1.57.0
Requires (Dev)
- squizlabs/php_codesniffer: ^3.11.2
- dev-main
- v0.3.11
- v0.3.10
- v0.3.9
- v0.3.8
- v0.3.7
- v0.3.6
- v0.3.5
- v0.3.4
- v0.3.3
- v0.3.2
- v0.3.1
- v0.3.0
- v0.2.18
- v0.2.17
- v0.2.16
- v0.2.15
- v0.2.14
- v0.2.13
- v0.2.12
- v0.2.11
- v0.2.10
- v0.2.9
- v0.2.8
- v0.2.7
- v0.2.6
- v0.2.5
- v0.2.4
- v0.2.3
- v0.2.2
- v0.2.1
- v0.2.0
- v0.1.0
- dev-t-invest-api_v1_30
- dev-php84_support
- dev-update_certificate
This package is auto-updated.
Last update: 2025-03-12 16:11:09 UTC
README
Unofficial PHP SDK for Tinkoff invest API V2. See official API documentation
Installation
It's recommended that you use Composer to install.
$ composer require a.treschilov/tinkoff-invest-api-sdk
SDK requires:
- PHP 8.3 or newer
- grpc extension
Install grpc
sudo pecl install grpc
Add to php.ini
extension=grpc.so
How to use
Basic Usage (limited methods support)
<?php declare(strict_types=1); use ATreschilov\TinkoffInvestApiSdk\Exceptions\TIException as TIException; use ATreschilov\TinkoffInvestApiSdk\TIClient; require __DIR__ . '/../vendor/autoload.php'; /** * Your personal Tinkoff Invest token * * @see https://tinkoff.github.io/investAPI/token/ */ $token = '<Your Tinkoff Invest Account Token>'; $options = [ 'isRateLimitRetry' => false ]; $tiClient = new TIClient($token, $options); try { $tiAccounts = $tiClient->getUser()->getAccounts(); $accounts = []; foreach ($tiAccounts as $account) { $accounts[] = [ 'id' => $account->getId(), 'name' => $account->getName(), 'type' => $account->getType(), 'status' => $account->getStatus(), 'openedDate' => $account->getOpenedDate()->getSeconds(), 'closedDate' => $account->getClosedDate()->getSeconds() ]; } echo '<pre>' . print_r($accounts, true) . '</pre>'; } catch (TIException $e) { echo $e->getCode() . '. ' . $e->getMessage(); }
Basic usage methods support
- User
- ✔ getAccounts
- ✖ GetMarginAttributes
- ✖ GetUserTariff
- ✖ GetInfo
- Instruments
- ✖ TradingSchedules
- ✔ BondBy
- ✔ Bonds
- ✔ GetBondCoupons
- ✔ GetBondsEvents
- ✔ CurrencyBy
- ✔ Currencies
- ✖ EtfBy
- ✔ Etfs
- ✔ FutureBy
- ✔ Futures
- ✖ OptionBy
- ✖ Options
- ✖ OptionsBy
- ✔ ShareBy
- ✔ Shares
- ✔ Indicatives
- ✖ GetAccruedInterests
- ✖ GetFuturesMargin
- ✔ GetInstrumentBy
- ✔ GetDividends
- ✖ GetAssetBy
- ✖ GetAssets
- ✖ GetFavorites
- ✖ EditFavorites
- ✖ GetCountries
- ✖ FindInstrument
- ✖ GetBrands
- ✖ GetBrandBy
- ✖ GetAssetFundamentals
- ✖ GetAssetReports
- ✖ GetConsensusForecasts
- ✖ GetForecastBy
- OrdersStream
- ✖ TradesStream
- Orders
- ✖ PostOrder
- ✖ CancelOrder
- ✖ GetOrderState
- ✖ GetOrders
- ✖ ReplaceOrder
- ✖ GetMaxLots
- ✖ GetOrderPrice
- Operations
- ✔ GetOperations
- ✔ GetPortfolio
- ✖ GetPositions
- ✔ GetWithdrawLimits
- ✖ GetBrokerReport
- ✖ GetDividendsForeignIssuer
- ✖ GetOperationsByCursor
- OperationsStream
- ✖ PortfolioStream
- ✖ PositionsStream
- MarketData
- ✔ GetCandles
- ✔ GetLastPrices
- ✖ GetOrderBook
- ✖ GetTradingStatus
- ✖ GetTradingStatuses
- ✖ GetLastTrades
- ✖ GetClosePrice
- ✖ GetTechAnalysis
- MarketDataStream
- ✖ MarketDataStream
- ✖ MarketDataServerSideStream
- StopOrders
- ✖ PostStopOrder
- ✖ GetStopOrders
- ✖ CancelStopOrder
- Signals
- ✖ OpenSandboxAccount
- ✖ GetSandboxAccounts
- Sandbox
- ✖ OpenSandboxAccount
- ✖ GetSandboxAccounts
- ✖ CloseSandboxAccount
- ✖ PostSandboxOrder
- ✖ ReplaceSandboxOrders
- ✖ GetSandboxOrders
- ✖ CancelSandboxOrder
- ✖ GetSandboxOrderState
- ✖ GetSandboxPositions
- ✖ GetSandboxOperations
- ✖ GetSandboxOperationsByCursor
- ✖ GetSandboxPortfolio
- ✖ SandboxPayIn
- ✖ GetSandboxWithdrawLimits
Advance usage (full methods support)
<?php declare(strict_types=1); use ATreschilov\TinkoffInvestApiSdk\TIClient; use Tinkoff\Invest\V1\Account; use Tinkoff\Invest\V1\GetAccountsRequest; use Tinkoff\Invest\V1\GetAccountsResponse; use Tinkoff\Invest\V1\UsersServiceClient; require __DIR__ . '/../vendor/autoload.php'; /** * Your personal Tinkoff Invest token * * @see https://tinkoff.github.io/investAPI/token/ */ $token = '<Your Tinkoff Invest Account Token>'; $tiClient = new TIClient($token); $userServiceClient = new UsersServiceClient($tiClient->getHostname(), $tiClient->getApiConfig()); $request = new GetAccountsRequest(); /** @var GetAccountsResponse $response */ list($response, $status) = $userServiceClient->GetAccounts($request)->wait(); if ($status->code !== 0) { echo '<pre>' . print_r($status, true) . '</pre>'; return; } $accounts = []; /** @var Account $account */ foreach ($response->getAccounts() as $account) { $accounts[] = [ 'id' => $account->getId(), 'name' => $account->getName(), 'type' => $account->getType(), 'status' => $account->getStatus(), 'openedDate' => $account->getOpenedDate()->getSeconds(), 'closedDate' => $account->getClosedDate()->getSeconds() ]; } echo '<pre>' . print_r($accounts, true) . '</pre>';