#author("2018-01-14T13:59:11+09:00","","")
#author("2018-01-30T22:30:03+09:00","","")
#navi(../)

* coincheckのレバレッジアカウントの残高サンプルコード(PHP) [#n71fa89f]
&color(red){当サイトに記載されている会社名、製品名などは一般に各社または団体の商標または登録商標です。&br;当サイトの資料により直接的および間接的障害が生じても一切責任を負いません。&br;あらかじめご了承ください。};

#contents
----
以下のバナーは&htmlinsert(coincheck.html);へのリンクです。~
#htmlinsert(coincheck_wide.html)
#htmlinsert(cc-top.html)

* 関連記事 [#sab66530]
-[[API動作環境構築>API/環境構築]]
-[[ティッカー(PHP)>API/coincheck/ティッカー(PHP)]]
-[[全取引履歴(PHP)>API/coincheck/全取引履歴(PHP)]]
-[[板情報(PHP)>API/coincheck/板情報(PHP)]]
-[[レート取得(PHP)>API/coincheck/レート取得(PHP)]]
-[[販売レート取得(PHP)>API/coincheck/販売レート取得(PHP)]]

-[[CoincheckのAPIキー生成手順>API/coincheck/APIキー生成手順]]

-[[アカウントの残高確認(PHP)>API/coincheck/残高確認(PHP)]]
-[[新規注文・現物売買(PHP)>API/coincheck/新規注文・現物売買(PHP)]]

-[[レバレッジアカウントの残高サンプル(PHP)>API/coincheck/レバレッジアカウントの残高取得]]
-[[レバレッジ取引注文サンプルコード(PHP)>API/coincheck/レバレッジ取引注文(PHP)]]
-[[レバレッジ取引のポジション一覧を取得する・positions(PHP)>API/coincheck/ポジション一覧(PHP)]]

-[[最近の取引履歴を取得する(PHP)>API/coincheck/最近の取引履歴の取得(PHP)]]

* レバレッジアカウント残高確認APIの仕様 [#a005d346]
レバレッジアカウント残高確認APIはPrivate APIのため、&htmlinsert(coincheck.html);の口座開設が必要となります。

''レバレッジアカウント残高確認APIの仕様''(Coincheck APIページから抜粋)~
https://coincheck.com/ja/documents/exchange/api#account-leverage-balance

 レバレッジアカウントの残高
 レバレッジアカウントの残高を確認できます。
 
 HTTP REQUEST
 GET /api/accounts/leverage_balance
 
 {
   "success": true,
   "margin": {
     "jpy": "131767.22675655"
   },
   "margin_available": {
     "jpy": "116995.98446494"
   },
   "margin_level": "8.36743"
 }
 RESPONSE ITEMS
 margin[jpy] 証拠金
 margin_available[jpy] 利用可能な証拠金
 margin_level 証拠金維持率

* レバレッジアカウント残高確認APIサンプルソースを使用する前の準備 [#c11dfe01]
本サンプルソースには、$ACCESS_KEY, $SECRET_ACCESS_KEY にAPIキーを設定していません。~
APIキーを準備してください。~
 // Please set ACCESS_KEY and SECRET_ACCESS_KEY
 $ACCESS_KEY = "";
 $SECRET_ACCESS_KEY = "";
APIキーの作成に関しては以下の記事を参考にしてください。~
-[[CoincheckのAPIキー生成手順>API/coincheck/APIキー生成手順]]

本サンプルソースを実行するには、APIキーのパーミッションとして「」にチェックが必要です。~
#ref(01.png)
#br
APIキーを作成すると、以下のスクリーンショットのように「アクセスキー」「アクセスシークレットキー」が作成されるので、~
サンプルソースの $ACCESS_KEY, $SECRET_ACCESS_KEY に設定してください。
#ref(02.png)
#br
----
#htmlinsert(coincheck_wide.html)


* レバレッジアカウント残高確認API PHPサンプルソース [#v2c769bc]
以下に&htmlinsert(coincheck.html);のレバレッジアカウント残高確認APIを呼び出すサンプルソースを記します。~
上記に記述しましたが、「アクセスキー」「アクセスシークレットキー」を準備してください。
#ref(src.zip)

 <?php
 // API doc : https://coincheck.com/ja/documents/exchange/api#account-leverage-balance
 // API url : https://coincheck.com/api/accounts/leverage_balance
 
 // Please set ACCESS_KEY and SECRET_ACCESS_KEY
 $ACCESS_KEY = "";
 $SECRET_ACCESS_KEY = "";
 
 // proxy settings
 $proxy      = ""; 
 $proxy_port = ""; 
 
 // coincheck balance api url
 $url = "https://coincheck.com/api/accounts/leverage_balance";
 
 // create signature
 $nonce = time();
 $message = $nonce . $url;
 $signature = hash_hmac("sha256", $message, $SECRET_ACCESS_KEY);
 // header
 $headers = array(
     "ACCESS-KEY: {$ACCESS_KEY}",
     "ACCESS-SIGNATURE: {$signature}",
     "ACCESS-NONCE: {$nonce}",
     );
 
 $curl = curl_init();
 if ($curl == FALSE) {
     fputs(STDERR, "[ERR] curl_init(): " . curl_error($curl) . PHP_EOL);
     die(1);
 }
 curl_setopt($curl, CURLOPT_URL, $url);
 curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
 curl_setopt($curl, CURLOPT_RETURNTRANSFER, TRUE);
 // set proxy server settings
 if (!empty($proxy) && !empty($proxy_port)) {
     curl_setopt($curl, CURLOPT_HTTPPROXYTUNNEL, 1); 
     curl_setopt($curl, CURLOPT_PROXY, $proxy . ":" . $proxy_port);
     curl_setopt($curl, CURLOPT_PROXYPORT, $proxy_port);
 }
 
 $response = curl_exec($curl);
 if ($response == FALSE) {
     fputs(STDERR, "[ERR] curl_exec(): " . curl_error($curl) . PHP_EOL);
     die(1);
 }
 curl_close($curl);
 
 // json decode
 $json_decode = json_decode($response, true);
 if ($json_decode == NULL) {
     fputs(STDERR, "[ERR] json_decode(): " . json_last_error_msg() . PHP_EOL);
     die(1);
 }
 // output json_decode
 print_r($json_decode);
 
 exit(0);

** 実行結果 [#k71dda4e]
以下のような出力になりました。
 $ php leverage_balance.php
 Array
 (
     [success] => 1
     [margin] => Array
         (
             [jpy] => 5963.5963
         )
 
     [margin_available] => Array
         (
             [jpy] => 5963.5963
         )
 
     [margin_level] => 
 )

 margin[jpy] 証拠金
 margin_available[jpy] 利用可能な証拠金
 margin_level 証拠金維持率

** invalid authentication エラーになった場合 [#kc9a61ee]
以下のようにERRORが出た場合は、APIキーの設定に誤りがないか確認してください。
 $ php balance.php
 [ERROR] : invalid authentication

** This api is not permitted... エラーになった場合 [#z1127d3c]
APIキーの設定を確認してください。~
レバレッジアカウント残高にチェックが入っていないためパーミッションエラーとなっています。
 $ php balance.php
 [ERROR] : This api is not permitted, Please set permission. https://coincheck.com/api_settings


以上、&htmlinsert(coincheck.html);のレバレッジアカウント残高を呼び出すサンプルソースおよび実行結果でした。
----
#htmlinsert(coincheck_wide.html)

#htmlinsert(cc-btm.html)


トップ   編集 差分 バックアップ 添付 複製 名前変更 リロード   新規 一覧 検索 最終更新   ヘルプ   最終更新のRSS