Commit accc1a5c authored by shajiaiming's avatar shajiaiming

Merge branch 'master' into feature/issue_coin

parents cf53079d 894eb0ac
...@@ -131,7 +131,7 @@ class CoinController extends BaseController ...@@ -131,7 +131,7 @@ class CoinController extends BaseController
if ($recommend) { if ($recommend) {
$condition['recommend'] = $recommend; $condition['recommend'] = $recommend;
} }
$select = ['id', 'sid', 'icon', 'name', 'optional_name', 'nickname', 'platform', 'chain', 'treaty']; $select = ['id', 'sid', 'icon', 'name', 'introduce', 'optional_name', 'nickname', 'platform', 'chain', 'treaty'];
$order_by = ['sort' => SORT_ASC]; $order_by = ['sort' => SORT_ASC];
$datas = CoinRecommend::getList($page, $limit, $condition, $order_by, $select); $datas = CoinRecommend::getList($page, $limit, $condition, $order_by, $select);
//获取详细信息 //获取详细信息
...@@ -143,6 +143,8 @@ class CoinController extends BaseController ...@@ -143,6 +143,8 @@ class CoinController extends BaseController
foreach ($coin_infos as $key => &$val) { foreach ($coin_infos as $key => &$val) {
$nickname = json_decode($val['nickname'], true); $nickname = json_decode($val['nickname'], true);
$val['nickname'] = $nickname[$this->lang]; $val['nickname'] = $nickname[$this->lang];
$introduce = json_decode($val['introduce'], true);
$val['introduce'] = $introduce[$this->lang];
} }
//获取行情信息 //获取行情信息
$coin_names = array_column($coin_infos, 'name'); $coin_names = array_column($coin_infos, 'name');
...@@ -243,7 +245,9 @@ class CoinController extends BaseController ...@@ -243,7 +245,9 @@ class CoinController extends BaseController
} }
foreach ($result['data'] as $key => &$value) { foreach ($result['data'] as $key => &$value) {
$nickname = json_decode($value['nickname'], true); $nickname = json_decode($value['nickname'], true);
$introduce = json_decode($value['introduce'], true);
$value['nickname'] = $nickname[$this->lang]; $value['nickname'] = $nickname[$this->lang];
$value['introduce'] = $introduce[$this->lang];
$value['chain_quotation'] = $chain_quotation[$value['chain']] ?: null; $value['chain_quotation'] = $chain_quotation[$value['chain']] ?: null;
$value['chain_rmb'] = isset($value['chain_quotation']['rmb']) ? $value['chain_quotation']['rmb'] : 0; $value['chain_rmb'] = isset($value['chain_quotation']['rmb']) ? $value['chain_quotation']['rmb'] : 0;
$value['chain_usd'] = isset($value['chain_quotation']['usd']) ? $value['chain_quotation']['usd'] : 0; $value['chain_usd'] = isset($value['chain_quotation']['usd']) ? $value['chain_quotation']['usd'] : 0;
......
<?php
namespace api\controllers;
use linslin\yii2\curl\Curl;
use Yii;
use api\base\BaseController;
class CoinDogController extends BaseController
{
public function actionArticle()
{
$coindog = Yii::$app->params['coindog'];
$accessKey = $coindog['accessKey'];
$secretKey = $coindog['secretKey'];
$httpParams = array(
'access_key' => $accessKey,
'date' => time()
);
$signParams = array_merge($httpParams, array('secret_key' => $secretKey));
ksort($signParams);
$signString = http_build_query($signParams);
$httpParams['sign'] = strtolower(md5($signString));
$url = $coindog['article'] . '?' . http_build_query($httpParams);
$curl = new Curl();
$resp = $curl->get($url, false);
return ['code' => 200, 'data' => $resp, 'msg' => 'ok'];
}
public function actionLive()
{
$limit = Yii::$app->request->get('limit', 20);
$id = Yii::$app->request->get('id', 0);
$flag = Yii::$app->request->get('flag', 'down');
$coindog = Yii::$app->params['coindog'];
$accessKey = $coindog['accessKey'];
$secretKey = $coindog['secretKey'];
$httpParams = array(
'access_key' => $accessKey,
'date' => time()
);
$signParams = array_merge($httpParams, array('secret_key' => $secretKey));
ksort($signParams);
$signString = http_build_query($signParams);
$httpParams = [
'sign' => strtolower(md5($signString)),
'limit' => $limit,
'id' => $id,
'flag' => $flag
];
$url = $coindog['live'] . '?' . http_build_query($httpParams);
$curl = new Curl();
$resp = $curl->get($url, false);
if (!isset($resp['list'])) {
$msg = '数据不存在';
$code = -1;
$data = null;
goto doEnd;
}
$list = $resp['list'][0]['lives'];
foreach ($list as &$item) {
preg_match_all("/\【(.+?)\】/", $item['content'], $match);
$item['title'] = $match[1][0];
}
$code = 0;
$msg = 'success';
doEnd :
return ['code' => $code, 'data' => $list, 'msg' => $msg];
}
}
\ No newline at end of file
...@@ -51,6 +51,8 @@ class CrossChainController extends BaseController ...@@ -51,6 +51,8 @@ class CrossChainController extends BaseController
$model = new CoinCrossChain(); $model = new CoinCrossChain();
$data['txhex'] = $val['tx']; $data['txhex'] = $val['tx'];
$data['transfer_url'] = $val['url']; $data['transfer_url'] = $val['url'];
$data['step'] = $val['step'];
$data['amount'] = isset($val['amount']) ? $val['amount'] : 0;
$model->load($data, ''); $model->load($data, '');
$model->save(); $model->save();
} }
...@@ -61,12 +63,68 @@ class CrossChainController extends BaseController ...@@ -61,12 +63,68 @@ class CrossChainController extends BaseController
return ['code' => $code, 'msg' => $msg]; return ['code' => $code, 'msg' => $msg];
} }
public function actionFixTransfer()
{
$code = -1;
$request = Yii::$app->request;
if (!$request->isPost) {
$msg = '请求错误!';
goto doEnd;
}
$post = $request->post();
$data['is_with_draw'] = (false == $post['isWithdraw']) ? 0 : 1;
$data['address'] = $post['address'];
foreach ($post['txs'] as $key => $val) {
$model = CoinCrossChain::find()->where(['is_with_draw' => $data['is_with_draw']])
->andWhere(['address' => $data['address']])
->andWhere(['step' => $val['step']])
->andWhere(['<>', 'msg', 'success'])
->one();
if(false == $model) continue;
$node_params = $model->transfer_url;
$node_params = explode(':', $node_params);
$node_params = [
'scheme' => $node_params[0],
'host' => str_replace('//', '', $node_params[1]),
'port' => isset($node_params[2]) ? $node_params[2] : ''
];
$service = new Chain33Service($node_params);
$send_result = $model->send_result;
$result = $service->QueryTransaction($send_result);
if (isset($result['result']['actionName']) && 'unknown' == $result['result']['actionName']) {
$model->query_result = 'success';
$model->msg = 'success';
$model->save();
continue;
} else if (isset($result['result']['receipt']['ty']) && 2 == $result['result']['receipt']['ty']) {
$model->query_result = 'success';
$model->msg = 'success';
$model->save();
continue;
} else {
$model->txhex = $val['tx'];
$model->transfer_url = $val['url'];
$model->send_result = 0;
$model->query_result = 0;
$model->msg = 0;
$model->save();
continue;
}
}
$code = 0;
$msg = 'success';
doEnd :
return ['code' => $code, 'msg' => $msg];
}
public function actionTransferStatus() public function actionTransferStatus()
{ {
$code = -1; $code = -1;
$msg = 'fail'; $msg = 'fail';
$data = null; $data = null;
$step = 0; $step = $amount = 0;
$request = Yii::$app->request; $request = Yii::$app->request;
if (!$request->isGet) { if (!$request->isGet) {
$msg = '请求错误!'; $msg = '请求错误!';
...@@ -83,11 +141,13 @@ class CrossChainController extends BaseController ...@@ -83,11 +141,13 @@ class CrossChainController extends BaseController
$model = CoinCrossChain::find()->where(['address' => $address, 'is_with_draw' => $is_with_draw])->orderBy("id desc")->limit(3)->asArray()->all(); $model = CoinCrossChain::find()->where(['address' => $address, 'is_with_draw' => $is_with_draw])->orderBy("id desc")->limit(3)->asArray()->all();
if (empty($model)) { if (empty($model)) {
$msg = '数据不存在!'; $msg = '数据不存在!';
$code = 0;
goto doEnd; goto doEnd;
} }
sort($model); sort($model);
foreach ($model as $key => $val) { foreach ($model as $key => $val) {
$amount = $val['amount'];
//未交易 //未交易
if ('0' == $val['send_result'] && '0' == $val['query_result'] && '0' == $val['msg']) { if ('0' == $val['send_result'] && '0' == $val['query_result'] && '0' == $val['msg']) {
$step = $key + 1; $step = $key + 1;
...@@ -111,7 +171,7 @@ class CrossChainController extends BaseController ...@@ -111,7 +171,7 @@ class CrossChainController extends BaseController
goto doEnd; goto doEnd;
} }
//交易成功,查询失败 //交易成功,查询失败
if (true == $val['send_result'] && 'fail' == $val['query_result']) { if (true == $val['send_result'] && 'success' != $val['query_result']) {
$step = $key + 1; $step = $key + 1;
$code = -1; $code = -1;
$msg = $val['msg']; $msg = $val['msg'];
...@@ -119,7 +179,7 @@ class CrossChainController extends BaseController ...@@ -119,7 +179,7 @@ class CrossChainController extends BaseController
} }
//交易成功,查询成功 //交易成功,查询成功
if (true == $val['send_result'] && 'success' == $val['query_result'] && 'success' == $val['msg']) { if (true == $val['send_result'] && 'success' == $val['query_result'] && 'success' == $val['msg']) {
if (2 == $key){ if (2 == $key) {
$step = (2 == $key) ? 4 : ($key + 2); $step = (2 == $key) ? 4 : ($key + 2);
$code = 0; $code = 0;
$msg = $val['send_result']; $msg = $val['send_result'];
...@@ -131,7 +191,8 @@ class CrossChainController extends BaseController ...@@ -131,7 +191,8 @@ class CrossChainController extends BaseController
doEnd : doEnd :
$data = [ $data = [
'step' => $step 'step' => $step,
'amount' => (int)$amount
]; ];
return ['code' => $code, 'msg' => $msg, 'data' => $data]; return ['code' => $code, 'msg' => $msg, 'data' => $data];
} }
......
...@@ -23,10 +23,10 @@ class GameBetController extends BaseController ...@@ -23,10 +23,10 @@ class GameBetController extends BaseController
} }
$query = CoinGameBet::find() $query = CoinGameBet::find()
->select('round, player, amount, height, guess_num, guess_num, rand_num, player_win, platform') ->select('round, player, amount, height, guess_num, valid, rand_num, player_win, platform')
->where('player= :player',[':player' => $player]) ->where('player= :player',[':player' => $player])
->andWhere(['platform' => $platform]) ->andWhere(['platform' => $platform])
#->andWhere(['valid' => CoinGameBet::VAILD_TRUE]) //->andWhere(['valid' => CoinGameBet::VAILD_TRUE])
->orderBy('update_time desc'); ->orderBy('update_time desc');
$count = $query->count(); $count = $query->count();
......
...@@ -5,6 +5,7 @@ ...@@ -5,6 +5,7 @@
* Date: 2018/12/29 * Date: 2018/12/29
* Time: 16:26 * Time: 16:26
*/ */
namespace api\controllers; namespace api\controllers;
use api\base\BaseController; use api\base\BaseController;
...@@ -34,22 +35,22 @@ class ServiceController extends BaseController ...@@ -34,22 +35,22 @@ class ServiceController extends BaseController
{ {
$request = Yii::$app->request; $request = Yii::$app->request;
$coinItems = $request->post('names'); $coinItems = $request->post('names');
if(!$coinItems){ if (!$coinItems) {
return ['code' => 1,'data' => [],'msg' => '币种不能为空']; return ['code' => 1, 'data' => [], 'msg' => '币种不能为空'];
} }
if(!is_array($coinItems)){ if (!is_array($coinItems)) {
$coinItems = [$coinItems]; $coinItems = [$coinItems];
} }
$tol_coins = ['ETC']; $tol_coins = ['ETC'];
$tickerData = []; $tickerData = [];
if($coinItems){ if ($coinItems) {
foreach($coinItems as $item){ foreach ($coinItems as $item) {
$item = strtoupper($item); $item = strtoupper($item);
if(in_array($item,$tol_coins)){ if (in_array($item, $tol_coins)) {
$exchange = ExchangeFactory::createExchange('HuoBi'); $exchange = ExchangeFactory::createExchange('HuoBi');
if ($exchange->symbolExists($item)) { if ($exchange->symbolExists($item)) {
$quotation = $exchange->getTicker($item); $quotation = $exchange->getTicker($item);
if($quotation){ if ($quotation) {
//格式化行情数据 //格式化行情数据
foreach ($quotation as $key => $value) { foreach ($quotation as $key => $value) {
$quotation[$key] = (float)sprintf("%0.4f", (double)$value); $quotation[$key] = (float)sprintf("%0.4f", (double)$value);
...@@ -58,7 +59,7 @@ class ServiceController extends BaseController ...@@ -58,7 +59,7 @@ class ServiceController extends BaseController
$quotation['rmb'] = (float)sprintf("%0.4f", $rate * $quotation['last']); $quotation['rmb'] = (float)sprintf("%0.4f", $rate * $quotation['last']);
} }
} }
}else{ } else {
$quotation = ExchangeBusiness::getquatation($item); $quotation = ExchangeBusiness::getquatation($item);
} }
if (!$quotation) { if (!$quotation) {
...@@ -69,19 +70,23 @@ class ServiceController extends BaseController ...@@ -69,19 +70,23 @@ class ServiceController extends BaseController
$tickerData[$item]['last'] = $coinServer->getDollar(); $tickerData[$item]['last'] = $coinServer->getDollar();
$tickerData[$item]['low'] = $coinServer->getLow(); $tickerData[$item]['low'] = $coinServer->getLow();
$tickerData[$item]['high'] = $coinServer->getHigh(); $tickerData[$item]['high'] = $coinServer->getHigh();
$tickerData[$item]['open'] = $coinServer->getDollar();
$tickerData[$item]['usd'] = $coinServer->getDollar();
$coinServer->__destruct(); $coinServer->__destruct();
} catch (\Exception $exception) { } catch (\Exception $exception) {
$tickerData[$item]['rmb'] = 0; $tickerData[$item]['rmb'] = 0;
$tickerData[$item]['last'] = 0; $tickerData[$item]['last'] = 0;
$tickerData[$item]['low'] = 0; $tickerData[$item]['low'] = 0;
$tickerData[$item]['high'] = 0; $tickerData[$item]['high'] = 0;
$tickerData[$item]['open'] = 0;
$tickerData[$item]['usd'] = 0;
\Yii::error($exception->getMessage()); \Yii::error($exception->getMessage());
} }
}else{ } else {
$tickerData[$item] = $quotation; $tickerData[$item] = $quotation;
} }
} }
return ['code' => 0,'data' => $tickerData,'msg' => '行情获取成功']; return ['code' => 0, 'data' => $tickerData, 'msg' => '行情获取成功'];
} }
} }
...@@ -94,13 +99,13 @@ class ServiceController extends BaseController ...@@ -94,13 +99,13 @@ class ServiceController extends BaseController
$platform_id = Yii::$app->request->get('platform_id', 6); $platform_id = Yii::$app->request->get('platform_id', 6);
$type = Yii::$app->request->get('type', 1); $type = Yii::$app->request->get('type', 1);
$coin_recommendItems = $this->coinRecommendList($platform_id, $type); $coin_recommendItems = $this->coinRecommendList($platform_id, $type);
$fields =['id', 'sid', 'icon', 'name', 'nickname','chain','platform']; $fields = ['id', 'sid', 'icon', 'name', 'nickname', 'chain', 'platform'];
$rows = Coin::getSelectList(1, 999, $fields,[['in','id',$coin_recommendItems]]); $rows = Coin::getSelectList(1, 999, $fields, [['in', 'id', $coin_recommendItems]]);
foreach ($rows['data'] as $key => &$value) { foreach ($rows['data'] as $key => &$value) {
$nickname = json_decode($value['nickname'], true); $nickname = json_decode($value['nickname'], true);
$value['nickname'] = $nickname[$this->lang]; $value['nickname'] = $nickname[$this->lang];
} }
return ['code' => 0,'data' => $rows,'msg' => '币种列表获取成功']; return ['code' => 0, 'data' => $rows, 'msg' => '币种列表获取成功'];
} }
/** /**
...@@ -109,9 +114,9 @@ class ServiceController extends BaseController ...@@ -109,9 +114,9 @@ class ServiceController extends BaseController
*/ */
private function coinRecommendList($platform_id, $type = 1) private function coinRecommendList($platform_id, $type = 1)
{ {
$recommend_list = CoinRecommend::find()->select('cid')->where(['platform_id' => $platform_id ,'type' => $type])->all(); $recommend_list = CoinRecommend::find()->select('cid')->where(['platform_id' => $platform_id, 'type' => $type])->all();
if($recommend_list){ if ($recommend_list) {
$coin_ids = array_column($recommend_list,'cid'); $coin_ids = array_column($recommend_list, 'cid');
return $coin_ids; return $coin_ids;
} }
return []; return [];
...@@ -125,14 +130,14 @@ class ServiceController extends BaseController ...@@ -125,14 +130,14 @@ class ServiceController extends BaseController
{ {
$request = Yii::$app->request; $request = Yii::$app->request;
$coin = $request->post('name'); $coin = $request->post('name');
if(!$coin){ if (!$coin) {
return ['code' => 1,'data' => [],'msg' => '币种不能为空']; return ['code' => 1, 'data' => [], 'msg' => '币种不能为空'];
} }
$fee = MinerFee::find()->where(['platform' => $coin,'type' => 2])->select('id,platform,type,fee,create_at,update_at')->asArray()->one(); $fee = MinerFee::find()->where(['platform' => $coin, 'type' => 2])->select('id,platform,type,fee,create_at,update_at')->asArray()->one();
if(!$fee){ if (!$fee) {
return ['code' => 1,'data' => [],'msg' => '旷工费未设置']; return ['code' => 1, 'data' => [], 'msg' => '旷工费未设置'];
} }
return ['code' => 0,'data' => $fee,'msg' => '旷工费获取成功']; return ['code' => 0, 'data' => $fee, 'msg' => '旷工费获取成功'];
} }
/** /**
...@@ -153,12 +158,12 @@ class ServiceController extends BaseController ...@@ -153,12 +158,12 @@ class ServiceController extends BaseController
public function actionChain() public function actionChain()
{ {
$request = Yii::$app->request; $request = Yii::$app->request;
$currency = $request->post('currency',''); $currency = $request->post('currency', '');
$coin = Coin::find()->where(['name' => $currency])->select('name,nickname,chain')->asArray()->one(); $coin = Coin::find()->where(['name' => $currency])->select('name,nickname,chain')->asArray()->one();
if($coin){ if ($coin) {
return ['code' => 0,'data' => $coin]; return ['code' => 0, 'data' => $coin];
} }
return ['code' => -1,'msg' => '币种不存在']; return ['code' => -1, 'msg' => '币种不存在'];
} }
} }
...@@ -92,7 +92,7 @@ class CoinController extends BaseController ...@@ -92,7 +92,7 @@ class CoinController extends BaseController
if (isset($data['optional_name'])) { if (isset($data['optional_name'])) {
$data['optional_name'] = strtoupper($data['optional_name']); $data['optional_name'] = strtoupper($data['optional_name']);
} }
$data['name'] = strtoupper($data['name']); $data['name'] = strtoupper(trim($data['name']));
$data['platform'] = strtolower($data['platform']); $data['platform'] = strtolower($data['platform']);
$data['chain'] = strtoupper($data['chain']); $data['chain'] = strtoupper($data['chain']);
$lang = [ $lang = [
...@@ -105,7 +105,7 @@ class CoinController extends BaseController ...@@ -105,7 +105,7 @@ class CoinController extends BaseController
$nickname = []; $nickname = [];
$introduce = []; $introduce = [];
foreach ($nickname_arr as $key => $val) { foreach ($nickname_arr as $key => $val) {
$nickname[$lang[$key]] = $val; $nickname[$lang[$key]] = trim($val);
} }
foreach ($introduce_arr as $key => $val) { foreach ($introduce_arr as $key => $val) {
$introduce[$lang[$key]] = $val; $introduce[$lang[$key]] = $val;
......
...@@ -103,11 +103,24 @@ class Curl ...@@ -103,11 +103,24 @@ class Curl
* *
* @return mixed response * @return mixed response
*/ */
protected $connect_timeout_ms;
protected $timeout_ms;
public function __construct($config = [])
{
if (!empty($config)) {
$this->connect_timeout_ms = isset($config['connect_timeout']) ? $config['connect_timeout'] : 10;
$this->timeout_ms = isset($config['timeout_ms']) ? $config['timeout_ms'] : 100;
}
}
public function get($url, $raw = true) public function get($url, $raw = true)
{ {
$this->_baseUrl = $url; $this->_baseUrl = $url;
return $this->_httpRequest('GET', $raw); return $this->_httpRequest('GET', $raw);
} }
/** /**
* Start performing HEAD-HTTP-Request * Start performing HEAD-HTTP-Request
* *
...@@ -120,6 +133,7 @@ class Curl ...@@ -120,6 +133,7 @@ class Curl
$this->_baseUrl = $url; $this->_baseUrl = $url;
return $this->_httpRequest('HEAD'); return $this->_httpRequest('HEAD');
} }
/** /**
* Start performing POST-HTTP-Request * Start performing POST-HTTP-Request
* *
...@@ -133,6 +147,7 @@ class Curl ...@@ -133,6 +147,7 @@ class Curl
$this->_baseUrl = $url; $this->_baseUrl = $url;
return $this->_httpRequest('POST', $raw); return $this->_httpRequest('POST', $raw);
} }
/** /**
* Start performing PUT-HTTP-Request * Start performing PUT-HTTP-Request
* *
...@@ -146,6 +161,7 @@ class Curl ...@@ -146,6 +161,7 @@ class Curl
$this->_baseUrl = $url; $this->_baseUrl = $url;
return $this->_httpRequest('PUT', $raw); return $this->_httpRequest('PUT', $raw);
} }
/** /**
* Start performing PATCH-HTTP-Request * Start performing PATCH-HTTP-Request
* *
...@@ -160,8 +176,9 @@ class Curl ...@@ -160,8 +176,9 @@ class Curl
$this->setHeaders([ $this->setHeaders([
'X-HTTP-Method-Override' => 'PATCH' 'X-HTTP-Method-Override' => 'PATCH'
]); ]);
return $this->_httpRequest('POST',$raw); return $this->_httpRequest('POST', $raw);
} }
/** /**
* Start performing DELETE-HTTP-Request * Start performing DELETE-HTTP-Request
* *
...@@ -175,6 +192,7 @@ class Curl ...@@ -175,6 +192,7 @@ class Curl
$this->_baseUrl = $url; $this->_baseUrl = $url;
return $this->_httpRequest('DELETE', $raw); return $this->_httpRequest('DELETE', $raw);
} }
/** /**
* Set curl option * Set curl option
* *
...@@ -194,6 +212,7 @@ class Curl ...@@ -194,6 +212,7 @@ class Curl
//return self //return self
return $this; return $this;
} }
/** /**
* Set get params * Set get params
* *
...@@ -210,6 +229,7 @@ class Curl ...@@ -210,6 +229,7 @@ class Curl
//return self //return self
return $this; return $this;
} }
/** /**
* Set get params * Set get params
* *
...@@ -227,6 +247,7 @@ class Curl ...@@ -227,6 +247,7 @@ class Curl
//return self //return self
return $this; return $this;
} }
/** /**
* Set raw post data allows you to post any data format. * Set raw post data allows you to post any data format.
* *
...@@ -242,6 +263,7 @@ class Curl ...@@ -242,6 +263,7 @@ class Curl
//return self //return self
return $this; return $this;
} }
/** /**
* Set get params * Set get params
* *
...@@ -259,6 +281,7 @@ class Curl ...@@ -259,6 +281,7 @@ class Curl
//return self //return self
return $this; return $this;
} }
/** /**
* Get URL - return URL parsed with given params * Get URL - return URL parsed with given params
* *
...@@ -267,11 +290,12 @@ class Curl ...@@ -267,11 +290,12 @@ class Curl
public function getUrl() public function getUrl()
{ {
if (Count($this->_getParams) > 0) { if (Count($this->_getParams) > 0) {
return $this->_baseUrl.'?'.http_build_query($this->_getParams); return $this->_baseUrl . '?' . http_build_query($this->_getParams);
} else { } else {
return $this->_baseUrl; return $this->_baseUrl;
} }
} }
/** /**
* Set curl options * Set curl options
* *
...@@ -284,6 +308,7 @@ class Curl ...@@ -284,6 +308,7 @@ class Curl
$this->_options = $options + $this->_options; $this->_options = $options + $this->_options;
return $this; return $this;
} }
/** /**
* Set multiple headers for request. * Set multiple headers for request.
* *
...@@ -298,11 +323,11 @@ class Curl ...@@ -298,11 +323,11 @@ class Curl
$parsedHeader = []; $parsedHeader = [];
//collect currently set headers //collect currently set headers
foreach ($this->getRequestHeaders() as $header => $value) { foreach ($this->getRequestHeaders() as $header => $value) {
array_push($parsedHeader, $header.':'.$value); array_push($parsedHeader, $header . ':' . $value);
} }
//parse header into right format key:value //parse header into right format key:value
foreach ($headers as $header => $value) { foreach ($headers as $header => $value) {
array_push($parsedHeader, $header.':'.$value); array_push($parsedHeader, $header . ':' . $value);
} }
//set headers //set headers
$this->setOption( $this->setOption(
...@@ -312,6 +337,7 @@ class Curl ...@@ -312,6 +337,7 @@ class Curl
} }
return $this; return $this;
} }
/** /**
* Set a single header for request. * Set a single header for request.
* *
...@@ -326,11 +352,11 @@ class Curl ...@@ -326,11 +352,11 @@ class Curl
$parsedHeader = []; $parsedHeader = [];
//collect currently set headers //collect currently set headers
foreach ($this->getRequestHeaders() as $headerToSet => $valueToSet) { foreach ($this->getRequestHeaders() as $headerToSet => $valueToSet) {
array_push($parsedHeader, $headerToSet.':'.$valueToSet); array_push($parsedHeader, $headerToSet . ':' . $valueToSet);
} }
//add override new header //add override new header
if (strlen($header) > 0) { if (strlen($header) > 0) {
array_push($parsedHeader, $header.':'.$value); array_push($parsedHeader, $header . ':' . $value);
} }
//set headers //set headers
$this->setOption( $this->setOption(
...@@ -339,6 +365,7 @@ class Curl ...@@ -339,6 +365,7 @@ class Curl
); );
return $this; return $this;
} }
/** /**
* Unset a single header. * Unset a single header.
* *
...@@ -353,7 +380,7 @@ class Curl ...@@ -353,7 +380,7 @@ class Curl
//collect currently set headers and filter "unset" header param. //collect currently set headers and filter "unset" header param.
foreach ($this->getRequestHeaders() as $headerToSet => $valueToSet) { foreach ($this->getRequestHeaders() as $headerToSet => $valueToSet) {
if ($header !== $headerToSet) { if ($header !== $headerToSet) {
array_push($parsedHeader, $headerToSet.':'.$valueToSet); array_push($parsedHeader, $headerToSet . ':' . $valueToSet);
} }
} }
//set headers //set headers
...@@ -363,6 +390,7 @@ class Curl ...@@ -363,6 +390,7 @@ class Curl
); );
return $this; return $this;
} }
/** /**
* Get all request headers as key:value array * Get all request headers as key:value array
* *
...@@ -381,6 +409,7 @@ class Curl ...@@ -381,6 +409,7 @@ class Curl
} }
return $parsedRequestHeaders; return $parsedRequestHeaders;
} }
/** /**
* Get specific request header as key:value array * Get specific request header as key:value array
* *
...@@ -394,6 +423,7 @@ class Curl ...@@ -394,6 +423,7 @@ class Curl
$parsedRequestHeaders = $this->getRequestHeaders(); $parsedRequestHeaders = $this->getRequestHeaders();
return isset($parsedRequestHeaders[$headerKey]) ? $parsedRequestHeaders[$headerKey] : null; return isset($parsedRequestHeaders[$headerKey]) ? $parsedRequestHeaders[$headerKey] : null;
} }
/** /**
* Unset a single curl option * Unset a single curl option
* *
...@@ -409,6 +439,7 @@ class Curl ...@@ -409,6 +439,7 @@ class Curl
} }
return $this; return $this;
} }
/** /**
* Unset all curl option, excluding default options. * Unset all curl option, excluding default options.
* *
...@@ -422,6 +453,7 @@ class Curl ...@@ -422,6 +453,7 @@ class Curl
} }
return $this; return $this;
} }
/** /**
* Total reset of options, responses, etc. * Total reset of options, responses, etc.
* *
...@@ -449,6 +481,7 @@ class Curl ...@@ -449,6 +481,7 @@ class Curl
$this->_getParams = []; $this->_getParams = [];
return $this; return $this;
} }
/** /**
* Return a single option * Return a single option
* *
...@@ -462,6 +495,7 @@ class Curl ...@@ -462,6 +495,7 @@ class Curl
//return value or false if key is not set. //return value or false if key is not set.
return isset($mergesOptions[$key]) ? $mergesOptions[$key] : false; return isset($mergesOptions[$key]) ? $mergesOptions[$key] : false;
} }
/** /**
* Return merged curl options and keep keys! * Return merged curl options and keep keys!
* *
...@@ -471,6 +505,7 @@ class Curl ...@@ -471,6 +505,7 @@ class Curl
{ {
return $this->_options + $this->_defaultOptions; return $this->_options + $this->_defaultOptions;
} }
/** /**
* Get curl info according to http://php.net/manual/de/function.curl-getinfo.php * Get curl info according to http://php.net/manual/de/function.curl-getinfo.php
* *
...@@ -487,6 +522,7 @@ class Curl ...@@ -487,6 +522,7 @@ class Curl
return []; return [];
} }
} }
/** /**
* Performs HTTP request * Performs HTTP request
* *
...@@ -508,8 +544,8 @@ class Curl ...@@ -508,8 +544,8 @@ class Curl
} }
//setup error reporting and profiling //setup error reporting and profiling
if (YII_DEBUG) { if (YII_DEBUG) {
Yii::trace('Start sending cURL-Request: '.$this->getUrl().'\n', __METHOD__); Yii::trace('Start sending cURL-Request: ' . $this->getUrl() . '\n', __METHOD__);
Yii::beginProfile($method.' '.$this->_baseUrl.'#'.md5(serialize($this->getOption(CURLOPT_POSTFIELDS))), __METHOD__); Yii::beginProfile($method . ' ' . $this->_baseUrl . '#' . md5(serialize($this->getOption(CURLOPT_POSTFIELDS))), __METHOD__);
} }
/** /**
* proceed curl * proceed curl
...@@ -517,7 +553,12 @@ class Curl ...@@ -517,7 +553,12 @@ class Curl
$curlOptions = $this->getOptions(); $curlOptions = $this->getOptions();
$this->curl = curl_init($this->getUrl()); $this->curl = curl_init($this->getUrl());
curl_setopt_array($this->curl, $curlOptions); curl_setopt_array($this->curl, $curlOptions);
curl_setopt($this->curl, CURLOPT_TIMEOUT,40); if (true == $this->timeout_ms && true == $this->connect_timeout_ms) {
curl_setopt($this->curl, CURLOPT_TIMEOUT_MS, $this->timeout_ms);
curl_setopt($this->curl, CURLOPT_CONNECTTIMEOUT, $this->timeout_ms);
curl_setopt($this->curl, CURLOPT_CONNECTTIMEOUT_MS, $this->connect_timeout_ms);
}
//curl_setopt($this->curl, CURLOPT_TIMEOUT,40);
$response = curl_exec($this->curl); $response = curl_exec($this->curl);
//check if curl was successful //check if curl was successful
if ($response === false) { if ($response === false) {
...@@ -547,7 +588,7 @@ class Curl ...@@ -547,7 +588,7 @@ class Curl
$this->_extractAdditionalCurlParameter(); $this->_extractAdditionalCurlParameter();
//end yii debug profile //end yii debug profile
if (YII_DEBUG) { if (YII_DEBUG) {
Yii::endProfile($method.' '.$this->getUrl().'#'.md5(serialize($this->getOption(CURLOPT_POSTFIELDS))), __METHOD__); Yii::endProfile($method . ' ' . $this->getUrl() . '#' . md5(serialize($this->getOption(CURLOPT_POSTFIELDS))), __METHOD__);
} }
//check responseCode and return data/status //check responseCode and return data/status
if ($this->getOption(CURLOPT_CUSTOMREQUEST) === 'HEAD') { if ($this->getOption(CURLOPT_CUSTOMREQUEST) === 'HEAD') {
...@@ -557,10 +598,11 @@ class Curl ...@@ -557,10 +598,11 @@ class Curl
return $this->response; return $this->response;
} }
} }
/** /**
* Extract additional curl params protected class helper * Extract additional curl params protected class helper
*/ */
protected function _extractAdditionalCurlParameter () protected function _extractAdditionalCurlParameter()
{ {
/** /**
* retrieve response code * retrieve response code
...@@ -581,27 +623,29 @@ class Curl ...@@ -581,27 +623,29 @@ class Curl
* try extract response length * try extract response length
*/ */
$this->responseLength = curl_getinfo($this->curl, CURLINFO_CONTENT_LENGTH_DOWNLOAD); $this->responseLength = curl_getinfo($this->curl, CURLINFO_CONTENT_LENGTH_DOWNLOAD);
if((int)$this->responseLength == -1) { if ((int)$this->responseLength == -1) {
$this->responseLength = strlen($this->response); $this->responseLength = strlen($this->response);
} }
} }
/** /**
* Extract body curl data from response * Extract body curl data from response
* *
* @param string $response * @param string $response
* @return string * @return string
*/ */
protected function _extractCurlBody ($response) protected function _extractCurlBody($response)
{ {
return substr($response, $this->getInfo(CURLINFO_HEADER_SIZE)); return substr($response, $this->getInfo(CURLINFO_HEADER_SIZE));
} }
/** /**
* Extract header curl data from response * Extract header curl data from response
* *
* @param string $response * @param string $response
* @return array * @return array
*/ */
protected function _extractCurlHeaders ($response) protected function _extractCurlHeaders($response)
{ {
//Init //Init
$headers = []; $headers = [];
......
...@@ -10,6 +10,9 @@ class CoinCrossChain extends BaseActiveRecord ...@@ -10,6 +10,9 @@ class CoinCrossChain extends BaseActiveRecord
const WITHDRAW = 0; const WITHDRAW = 0;
const RECHARGE = 1; const RECHARGE = 1;
const CROSS_CHAIN_TRANSFERING = 'cross_chain_transfering';
const CROSS_CHAIN_CACHE_FAIL = 'cross_chain_fail';
public static function getDb() public static function getDb()
{ {
return Yii::$app->get('p_sources'); return Yii::$app->get('p_sources');
...@@ -28,14 +31,14 @@ class CoinCrossChain extends BaseActiveRecord ...@@ -28,14 +31,14 @@ class CoinCrossChain extends BaseActiveRecord
{ {
return [ return [
[['is_with_draw', 'address', 'txhex', 'transfer_url'], 'required'], [['is_with_draw', 'address', 'txhex', 'transfer_url'], 'required'],
['transfer_number', 'safe'] [['transfer_number', 'amount', 'step', 'send_result', 'query_result', 'msg'], 'safe']
]; ];
} }
public function scenarios() public function scenarios()
{ {
$scenarios = [ $scenarios = [
self:: SCENARIOS_CREATE => ['is_with_draw', 'address', 'txhex', 'transfer_url', 'transfer_number'], self:: SCENARIOS_CREATE => ['is_with_draw', 'address', 'txhex', 'transfer_url', 'transfer_number', 'amount', 'step', 'send_result', 'query_result', 'msg'],
]; ];
return array_merge(parent:: scenarios(), $scenarios); return array_merge(parent:: scenarios(), $scenarios);
} }
......
...@@ -20,7 +20,7 @@ class Chain33Service ...@@ -20,7 +20,7 @@ class Chain33Service
public function __construct($parameter = []) public function __construct($parameter = [])
{ {
if(empty($parameter)){ if (empty($parameter)) {
$this->node_params = Yii::$app->params['chain33']; $this->node_params = Yii::$app->params['chain33'];
} else { } else {
$this->node_params = $parameter; $this->node_params = $parameter;
...@@ -56,7 +56,11 @@ class Chain33Service ...@@ -56,7 +56,11 @@ class Chain33Service
public function send($params = [], $method = 'Chain33.Query') public function send($params = [], $method = 'Chain33.Query')
{ {
$ch = new Curl(); $timeout = [
'connect_timeout' => 50000,
'timeout_ms' => 40000
];
$ch = new Curl($timeout);
$jsonrpc = self::jsonRpcBuild($params, $method); $jsonrpc = self::jsonRpcBuild($params, $method);
$ch->setHeader('Content-Type', 'application/json'); $ch->setHeader('Content-Type', 'application/json');
$ch->setRawPostData($jsonrpc); $ch->setRawPostData($jsonrpc);
...@@ -203,7 +207,7 @@ class Chain33Service ...@@ -203,7 +207,7 @@ class Chain33Service
return $this->send($params, 'Chain33.CreateRawTransaction'); return $this->send($params, 'Chain33.CreateRawTransaction');
} }
public function createRawTransaction($to, $amount, $fee, $note,$execer) public function createRawTransaction($to, $amount, $fee, $note, $execer)
{ {
$params = [ $params = [
"to" => $to, "to" => $to,
...@@ -294,6 +298,15 @@ class Chain33Service ...@@ -294,6 +298,15 @@ class Chain33Service
return $this->send($params, 'Chain33.SignRawTx'); return $this->send($params, 'Chain33.SignRawTx');
} }
public function getBlock2MainInfo($start, $end)
{
$params = [
"Start" => $start,
"End" => $end,
];
return $this->send($params, 'paracross.GetBlock2MainInfo');
}
public function sendTrade($data) public function sendTrade($data)
{ {
$params = [ $params = [
...@@ -302,6 +315,14 @@ class Chain33Service ...@@ -302,6 +315,14 @@ class Chain33Service
return $this->send($params, 'Chain33.SendTransaction'); return $this->send($params, 'Chain33.SendTransaction');
} }
public function getHeight($params = [])
{
$params = [
"data" => 'user.p.game.',
];
return $this->send($params, 'paracross.GetHeight');
}
/** /**
* 获取最新的区块 * 获取最新的区块
*/ */
......
...@@ -14,14 +14,17 @@ class CrossChainController extends Controller ...@@ -14,14 +14,17 @@ class CrossChainController extends Controller
* *
* @return array * @return array
*/ */
public function actionAutoTransfer() public function actionAutoTransfer($step, $is_with_draw)
{ {
$model = CoinCrossChain::find()->where(['send_result' => "0"])->limit(20)->groupBy('transfer_number')->orderBy('id')->asArray()->all(); $redis = Yii::$app->redis;
$model = CoinCrossChain::find()->where(['send_result' => "0", 'step' => (int)$step, 'is_with_draw' => (int)$is_with_draw, 'query_result' => '0'])->asArray()->all();
if (empty($model)) { if (empty($model)) {
echo date('Y-m-d H:i:s') . '暂无跨链交易计划' . PHP_EOL; echo date('Y-m-d H:i:s') . ' STEP: ' . $step . '暂无跨链交易计划' . PHP_EOL;
return 0; return 0;
} }
$current_time = time();
foreach ($model as $val) { foreach ($model as $val) {
if ($step > 1) {
$isExist = CoinCrossChain::find() $isExist = CoinCrossChain::find()
->where(['transfer_number' => $val['transfer_number']]) ->where(['transfer_number' => $val['transfer_number']])
->andWhere(['<', 'id', (int)$val['id']]) ->andWhere(['<', 'id', (int)$val['id']])
...@@ -32,53 +35,74 @@ class CrossChainController extends Controller ...@@ -32,53 +35,74 @@ class CrossChainController extends Controller
if ('success' != $isExist['query_result'] && !empty($isExist)) { if ('success' != $isExist['query_result'] && !empty($isExist)) {
continue; continue;
} }
}
$cache_transfering_time = $redis->hget(CoinCrossChain::CROSS_CHAIN_TRANSFERING, $val['address'] . ':' . $val['is_with_draw'] . ':' . $val['id']);
if (true == $cache_transfering_time) {
continue;
}
$redis->hmset(CoinCrossChain::CROSS_CHAIN_TRANSFERING, $val['address'] . ':' . $val['is_with_draw'] . ':' . $val['id'], $current_time);
//go(function () use ($val) { go(function () use ($val, $redis) {
// \Co::sleep(0.5); \Co::sleep(0.5);
$transfer_url = $val['transfer_url']; $transfer_url = $val['transfer_url'];
$transfer_url = explode(':', $transfer_url); $transfer_url = explode(':', $transfer_url);
$node_params = [ $node_params = [
'scheme' => $transfer_url[0], 'scheme' => $transfer_url[0],
'host' => str_replace('//', '', $transfer_url[1]), 'host' => str_replace('//', '', $transfer_url[1]),
'port' => isset($transfer_url[2]) ? $transfer_url[2] : '' 'port' => isset($transfer_url[2]) ? $transfer_url[2] : '',
]; ];
$service = new Chain33Service($node_params); $service = new Chain33Service($node_params);
$sign_str = $val['txhex']; $sign_str = $val['txhex'];
$result = $service->sendTransaction($sign_str); $result = $service->sendTransaction($sign_str);
if (0 != $result['code']) { if (0 == $result['code']) {
$msg = $result['msg'];
goto doEnd;
}
$send_result = $result['result']; $send_result = $result['result'];
doEnd :
$currentModel = CoinCrossChain::findOne($val['id']); $currentModel = CoinCrossChain::findOne($val['id']);
if (isset($msg)) {
$currentModel->msg = $msg;
}
if (isset($send_result)) {
$currentModel->send_result = $send_result; $currentModel->send_result = $send_result;
$currentModel->msg = 0;
$currentModel->save();
$redis->hdel(CoinCrossChain::CROSS_CHAIN_TRANSFERING, $val['address'] . ':' . $val['is_with_draw'] . ':' . $val['id']);
} }
if (0 != $result['code'] && (true == strstr($result['msg'], 'Balance'))) {
$currentModel = CoinCrossChain::findOne($val['id']);
$currentModel->msg = $result['msg'];
$currentModel->save(); $currentModel->save();
$redis->hdel(CoinCrossChain::CROSS_CHAIN_TRANSFERING, $val['address'] . ':' . $val['is_with_draw'] . ':' . $val['id']);
} else if (0 != $result['code'] && (false == strstr($result['msg'], 'ErrDupTx'))) {
$redis->hdel(CoinCrossChain::CROSS_CHAIN_TRANSFERING, $val['address'] . ':' . $val['is_with_draw'] . ':' . $val['id']);
} else {
//});
} }
echo date('Y-m-d H:i:s') . '跨链交易成功' . PHP_EOL; });
}
echo date('Y-m-d H:i:s') . ' STEP: ' . $step . '跨链交易成功' . PHP_EOL;
return 0; return 0;
} }
public function actionQueryTransaction() public function actionQueryTransaction()
{ {
$model = CoinCrossChain::find()->where(['<>', 'send_result', '0'])->andWhere(['msg' => '0'])->limit(20)->asArray()->all(); $redis = Yii::$app->redis;
$model = CoinCrossChain::find()->where(['<>', 'send_result', '0'])->andWhere(['msg' => '0'])->asArray()->all();
if (empty($model)) { if (empty($model)) {
echo date('Y-m-d H:i:s') . '暂无跨链交易计划' . PHP_EOL; echo date('Y-m-d H:i:s') . '暂无跨链交易计划' . PHP_EOL;
return 0; return 0;
} }
//查询共识高度
$node_params = [
'scheme' => 'https',
'host' => 'jiedian1.bityuan.com',
'port' => 8801
];
$service = new Chain33Service($node_params);
$result = $service->getHeight();
$consensHeight = $result['result']['consensHeight'];
$current_time = time();
foreach ($model as $val) { foreach ($model as $val) {
$node_params = $val['transfer_url']; $node_params = $val['transfer_url'];
$node_params = explode(':', $node_params); $node_params = explode(':', $node_params);
...@@ -90,30 +114,53 @@ class CrossChainController extends Controller ...@@ -90,30 +114,53 @@ class CrossChainController extends Controller
$service = new Chain33Service($node_params); $service = new Chain33Service($node_params);
$send_result = $val['send_result']; $send_result = $val['send_result'];
$result = $service->QueryTransaction($send_result); $result = $service->QueryTransaction($send_result);
if (-1 == $result['code']) { $switch = true;
if('tx not exist' == $result['msg']) continue;
$msg = $result['msg'];
$query_result = $result['code'];
goto doEnd;
// echo date('Y-m-d H:i:s') . 'ID:' . $val['id'] . '查询错误' . PHP_EOL;
// continue;
}
if (isset($result['result']['actionName']) && 'unknown' == $result['result']['actionName']) { if (isset($result['result']['actionName']) && 'unknown' == $result['result']['actionName']) {
$redis->hdel(CoinCrossChain::CROSS_CHAIN_CACHE_FAIL, $val['address'] . ':' . $val['is_with_draw']);
$query_result = 'success'; $query_result = 'success';
$msg = 'success'; $msg = 'success';
$height = isset($result['result']['height']) ? $result['result']['height'] : 0;
goto doEnd;
} else if (isset($result['result']['receipt']['ty']) && 2 == $result['result']['receipt']['ty']) { } else if (isset($result['result']['receipt']['ty']) && 2 == $result['result']['receipt']['ty']) {
$redis->hdel(CoinCrossChain::CROSS_CHAIN_CACHE_FAIL, $val['address'] . ':' . $val['is_with_draw']);
$query_result = 'success'; $query_result = 'success';
$msg = 'success'; $msg = 'success';
$height = isset($result['result']['height']) ? $result['result']['height'] : 0;
goto doEnd;
} else {
$cache_error_time = $redis->hget(CoinCrossChain::CROSS_CHAIN_CACHE_FAIL, $val['address'] . ':' . $val['is_with_draw']);
if (false == $cache_error_time) {
$redis->hmset(CoinCrossChain::CROSS_CHAIN_CACHE_FAIL, $val['address'] . ':' . $val['is_with_draw'], $current_time);
continue;
}
if (($current_time - $cache_error_time) < 60) {
continue;
}
$redis->hdel(CoinCrossChain::CROSS_CHAIN_CACHE_FAIL, $val['address'] . ':' . $val['is_with_draw']);
if (-1 == $result['code']) {
$msg = $result['msg'];
$query_result = $result['code'];
$switch = false;
goto doEnd;
} else { } else {
$query_result = 'fail'; $query_result = 'fail';
foreach ($result['result']['receipt']['logs'] as $log) { foreach ($result['result']['receipt']['logs'] as $log) {
if (is_array($log['log'])) continue; if (is_array($log['log'])) continue;
$msg = isset($log['log']) ? $log['log'] : '查询错误'; $msg = isset($log['log']) ? $log['log'] : '查询错误';
} }
$switch = false;
goto doEnd;
}
} }
doEnd : doEnd :
if (CoinCrossChain::RECHARGE == $val['is_with_draw'] && $val['step'] == 2 && $switch && isset($height) && ($consensHeight < $height)) {
continue;
}
$currentModel = CoinCrossChain::findOne($val['id']); $currentModel = CoinCrossChain::findOne($val['id']);
$currentModel->query_result = $query_result; $currentModel->query_result = $query_result;
$currentModel->msg = $msg; $currentModel->msg = $msg;
...@@ -121,7 +168,6 @@ class CrossChainController extends Controller ...@@ -121,7 +168,6 @@ class CrossChainController extends Controller
$count = CoinCrossChain::find()->where(['transfer_number' => $val['transfer_number']])->andWhere(['query_result' => 'success'])->count(); $count = CoinCrossChain::find()->where(['transfer_number' => $val['transfer_number']])->andWhere(['query_result' => 'success'])->count();
if (3 == $count) { if (3 == $count) {
$redis = Yii::$app->redis;
$key = $val['address'] . '_' . $val['is_with_draw']; $key = $val['address'] . '_' . $val['is_with_draw'];
if ($redis->exists($key)) { if ($redis->exists($key)) {
$redis->del($key); $redis->del($key);
......
...@@ -4,6 +4,7 @@ namespace console\controllers; ...@@ -4,6 +4,7 @@ namespace console\controllers;
use common\business\Chain33Business; use common\business\Chain33Business;
use common\models\psources\CoinGameBet; use common\models\psources\CoinGameBet;
use common\service\chain33\Chain33Service;
use yii\console\Controller; use yii\console\Controller;
use Yii; use Yii;
...@@ -17,47 +18,46 @@ class GameBetController extends Controller ...@@ -17,47 +18,46 @@ class GameBetController extends Controller
public function actionGameStatus() public function actionGameStatus()
{ {
$nodes = \Yii::$app->params['chain_parallel']['wasm']; $nodes = \Yii::$app->params['chain_parallel']['wasm'];
if(empty($nodes)){ if (empty($nodes)) {
echo date('Y-m-d H:i:s') . '无节点'.PHP_EOL; echo date('Y-m-d H:i:s') . '无节点' . PHP_EOL;
return 0; return 0;
} }
foreach ($nodes as $key => $node) { foreach ($nodes as $key => $node) {
$service = new Chain33Business(); $service = new Chain33Business();
$result = $service->getGameStatus($node); $result = $service->getGameStatus($node);
if (0 !== $result['code']) { if (0 !== $result['code']) {
echo $key.':'.date('Y-m-d H:i:s') . $result['msg'].PHP_EOL; echo $key . ':' . date('Y-m-d H:i:s') . $result['msg'] . PHP_EOL;
continue; continue;
} }
$queryResultItems = $result['result'] ?? []; $queryResultItems = $result['result'] ?? [];
if (empty($queryResultItems)) { if (empty($queryResultItems)) {
echo $key.':'.date('Y-m-d H:i:s') . 'error'.PHP_EOL; echo $key . ':' . date('Y-m-d H:i:s') . 'error' . PHP_EOL;
continue; continue;
} }
$resultJSON = json_decode($queryResultItems['queryResultItems'][0]['resultJSON'], true); $resultJSON = json_decode($queryResultItems['queryResultItems'][0]['resultJSON'], true);
$current_round = $resultJSON['current_round']; $current_round = $resultJSON['current_round'];
$cache_current_round = Yii::$app->redis->get('chain33_game_bet_status_'.$key); $cache_current_round = Yii::$app->redis->get('chain33_game_bet_status_' . $key);
if (empty($cache_current_round)) { if (empty($cache_current_round)) {
$cache_current_round = CoinGameBet::find()->where(['platform' => $key])->max('round'); $cache_current_round = CoinGameBet::find()->where(['platform' => $key])->max('round');
Yii::$app->redis->set('chain33_game_bet_status_'.$key, $cache_current_round, 'EX', 300); Yii::$app->redis->set('chain33_game_bet_status_' . $key, $cache_current_round, 'EX', 300);
} }
$cache_current_round = (false == $cache_current_round ? 0 : $cache_current_round); $cache_current_round = (false == $cache_current_round ? 0 : $cache_current_round);
if ($cache_current_round >= $current_round) { if ($cache_current_round >= $current_round) {
echo $key.':'.date('Y-m-d H:i:s') . '数据已为最新' . PHP_EOL; echo $key . ':' . date('Y-m-d H:i:s') . '数据已为最新' . PHP_EOL;
continue; continue;
} }
Yii::$app->redis->set('chain33_game_bet_status_'.$key, $current_round, 'EX', 300); Yii::$app->redis->set('chain33_game_bet_status_' . $key, $current_round, 'EX', 300);
$result = $service->getBetStatus($cache_current_round, $current_round, '', $node); $result = $service->getBetStatus($cache_current_round, $current_round, '', $node);
if (0 !== $result['code']) { if (0 !== $result['code']) {
echo $key.':'.date('Y-m-d H:i:s') . '数据错误' . PHP_EOL; echo $key . ':' . date('Y-m-d H:i:s') . '数据错误' . PHP_EOL;
continue; continue;
} }
$queryResultItems = $result['result'] ?? []; $queryResultItems = $result['result'] ?? [];
if (empty($queryResultItems)) { if (empty($queryResultItems)) {
echo $key.':'.date('Y-m-d H:i:s') . '数据错误' . PHP_EOL; echo $key . ':' . date('Y-m-d H:i:s') . '数据错误' . PHP_EOL;
continue; continue;
} }
$platform = $key; $platform = $key;
...@@ -69,7 +69,7 @@ class GameBetController extends Controller ...@@ -69,7 +69,7 @@ class GameBetController extends Controller
]; ];
} }
CoinGameBet::loadArray($datas); CoinGameBet::loadArray($datas);
echo $platform.':'.date('Y-m-d H:i:s') . '数据更新成功'.PHP_EOL; echo $platform . ':' . date('Y-m-d H:i:s') . '数据更新成功' . PHP_EOL;
continue; continue;
} }
return 0; return 0;
...@@ -77,44 +77,66 @@ class GameBetController extends Controller ...@@ -77,44 +77,66 @@ class GameBetController extends Controller
public function actionBetUpdate() public function actionBetUpdate()
{ {
$service = new Chain33Business();
$node_params = [
'scheme' => 'https',
'host' => 'jiedian1.bityuan.com',
'port' => 8801
];
$result = $service->getLastHeader($node_params);
$main_height = isset($result['result']['height']) ? $result['result']['height'] : 0;
$safe_main_height = $main_height - 14;
$nodes = \Yii::$app->params['chain_parallel']['wasm']; $nodes = \Yii::$app->params['chain_parallel']['wasm'];
if(empty($nodes)){ if (empty($nodes)) {
echo date('Y-m-d H:i:s') . '无节点'.PHP_EOL; echo date('Y-m-d H:i:s') . '无节点' . PHP_EOL;
return 0; return 0;
} }
foreach ($nodes as $key => $node) { foreach ($nodes as $key => $node) {
$service = new Chain33Business(); $service = new Chain33Service($node);
$result = $service->getLastHeader($node); $result = $service->getLastHeader();
$height = $result['result']['height']; $height = $result['result']['height'];
$main_info = $service->getBlock2MainInfo($height - 14, $height);
if (!isset($main_info['result']['items'])) continue;
$items = $main_info['result']['items'];
$items = $this->arraySort($items, 'mainHeight');
$safe_height = 0;
foreach ($items as $item) {
if ($safe_main_height > $item['mainHeight']) {
$safe_height = $item['height'];
break;
}
}
echo $key . ':' . date('Y-m-d H:i:s') . '当前主链高度为:' . $main_height . ';当前平行链高度为:' . $height . ';当前安全高度为:' . $safe_height . PHP_EOL;
$models = CoinGameBet::find()->select('round')->where([ $models = CoinGameBet::find()->select('round')->where([
'and', 'and',
['valid' => CoinGameBet::VAILD_FALSE], ['valid' => CoinGameBet::VAILD_FALSE],
['<', 'height', $height - 12], ['<', 'height', $safe_height],
['platform' => $key] ['platform' => $key]
])->all(); ])->all();
if(empty($models)){ if (empty($models)) {
echo $key.':'.date('Y-m-d H:i:s') . '无需更新的数据'.PHP_EOL; echo $key . ':' . date('Y-m-d H:i:s') . '无需更新的数据' . PHP_EOL;
continue; continue;
} }
$valid_arr = []; $valid_arr = [];
foreach ($models as $model) { foreach ($models as $model) {
$valid_arr[] = $model->round; $valid_arr[] = $model->round;
} }
$result = $service->getBetStatus('', '', $valid_arr, $node); $business = new Chain33Business();
if( 0 !== $result['code']){ $result = $business->getBetStatus('', '', $valid_arr, $node);
echo $key.':'.date('Y-m-d H:i:s') . '数据错误'.PHP_EOL; if (0 !== $result['code']) {
echo $key . ':' . date('Y-m-d H:i:s') . '数据错误' . PHP_EOL;
continue; continue;
} }
$queryResultItems = $result['result'] ?? []; $queryResultItems = $result['result'] ?? [];
if(empty($queryResultItems)){ if (empty($queryResultItems)) {
echo $key.':'.date('Y-m-d H:i:s') . '数据错误'.PHP_EOL; echo $key . ':' . date('Y-m-d H:i:s') . '数据错误' . PHP_EOL;
continue; continue;
} }
$platform = $key; $platform = $key;
foreach ($queryResultItems['queryResultItems'] as $key => $val){ foreach ($queryResultItems['queryResultItems'] as $key => $val) {
if (false == $val['found']) continue; if (false == $val['found']) continue;
$resultArr = json_decode($val['resultJSON'],true); $resultArr = json_decode($val['resultJSON'], true);
CoinGameBet::updateAll([ CoinGameBet::updateAll([
'amount' => $resultArr['amount'], 'amount' => $resultArr['amount'],
'height' => $resultArr['height'], 'height' => $resultArr['height'],
...@@ -122,14 +144,25 @@ class GameBetController extends Controller ...@@ -122,14 +144,25 @@ class GameBetController extends Controller
'rand_num' => $resultArr['rand_num'], 'rand_num' => $resultArr['rand_num'],
'player_win' => $resultArr['player_win'], 'player_win' => $resultArr['player_win'],
'valid' => CoinGameBet::VAILD_TRUE 'valid' => CoinGameBet::VAILD_TRUE
],[ ], [
'round' => $resultArr['round'], 'round' => $resultArr['round'],
'platform' => $platform 'platform' => $platform
]); ]);
} }
echo $platform.':'.date('Y-m-d H:i:s') . '数据更新成功'.PHP_EOL; echo $platform . ':' . date('Y-m-d H:i:s') . '数据更新成功' . PHP_EOL;
continue; continue;
} }
return 0; return 0;
} }
protected function arraySort($array, $keys, $sort = SORT_DESC)
{
$keysValue = [];
foreach ($array as $k => $v) {
$keysValue[$k] = $v[$keys];
}
array_multisort($keysValue, $sort, $array);
return $array;
}
} }
\ No newline at end of file
#!/bin/bash
while true; do php /var/www/html/token_pwallet/yii cross-chain/auto-transfer >> /var/www/html/auto-transfer.log 2>&1; sleep 15; done &
\ No newline at end of file
#!/bin/bash
while true; do php /var/www/html/token_pwallet/yii game-bet/game-status >> /var/log/game-bet.log 2>&1; sleep 5; done &
\ No newline at end of file
#!/bin/bash
while true; do php /var/www/html/token_pwallet/yii cross-chain/query-transaction >> /var/www/html/query-transaction.log 2>&1; sleep 20; done &
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment