Exchange.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. <?php
  2. namespace app\api\controller;
  3. use app\api\logic\WelfareLoginc;
  4. use app\common\controller\Api;
  5. use app\common\logic\BscApi;
  6. use app\common\model\ProductLists;
  7. use app\common\model\LedgerFrozenChangeModel;
  8. use app\common\model\ProductOrder;
  9. use app\common\model\ProductWelfareRede;
  10. use app\common\model\RwaExchangeRecordModel;
  11. use app\common\model\LedgerWalletModel;
  12. use app\common\model\LedgerTeacChangeModel;
  13. use fast\Action;
  14. use fast\Asset;
  15. use think\Db;
  16. use think\Exception;
  17. use think\Log;
  18. //Teac兑换
  19. class Exchange extends Api
  20. {
  21. protected string $lan = '';
  22. public function _initialize()
  23. {
  24. parent::_initialize();
  25. $this->lan = $this->request->getLan();
  26. }
  27. //Rwa福利兑换配置
  28. public function getWelfareRedeList(ProductWelfareRede $productWelfareRede){
  29. $list = $productWelfareRede
  30. ->where('status', $productWelfareRede::Normal)
  31. ->order('weigh desc')
  32. ->paginate($this->pageSize);
  33. $this->success('ok', $list);
  34. }
  35. //Rwa福利兑换详情
  36. public function getWelfareRedeDetail(ProductWelfareRede $productWelfareRede){
  37. $ids = $this->request->post('ids');
  38. if (empty($ids)) $this->error(__('Parameter error'));
  39. $welfare = $productWelfareRede::get($ids);
  40. $data_info = [
  41. 'title' => $welfare['title'],
  42. 'product_image' => $welfare['product_image'],
  43. 'transfer_address' => $welfare['transfer_address'],
  44. 'usdt_num' => round($welfare['usdt_num'],2),
  45. 'is_token' => $welfare['is_token'],
  46. 'token_name' => $welfare['token_name'],
  47. 'token_num' => round($welfare['token_num'], 2),
  48. ];
  49. $this->success('ok', ['data'=>$data_info, 'desc'=> $welfare['describe']]);
  50. }
  51. //Rwa兑换
  52. public function submitWelfare(LedgerWalletModel $ledgerWalletModel, ProductWelfareRede $productWelfareRede)
  53. {
  54. $ids = $this->request->post('ids'); // 代币ids
  55. $coin_from_address = $this->request->post('coin_from_address'); // 代码转入地址
  56. $usdt_from_address = $this->request->post('usdt_from_address'); // U转入地址
  57. if (empty($ids) || empty($usdt_from_address)) {
  58. $this->error(__('Parameter error'));
  59. }
  60. //检查区块链地址是否合法
  61. if(!(isErc20AddressValid($usdt_from_address))){
  62. $this->error(__('Invalid parameters'));
  63. }
  64. //福利兑换记录
  65. $welfare_config = $productWelfareRede::where('id',$ids)->where('status', $productWelfareRede::Normal)->find();
  66. if (!$welfare_config) $this->error(__('Invalid parameters'));
  67. //检查是否在开启时间之内
  68. if(time() < $welfare_config['start_time'] || time() > $welfare_config['end_time']) $this->error(__('不在兑换时间范围内'));
  69. /*
  70. //检查是否已兑换过
  71. if($welfare_config['limit_num'] > 0){
  72. $check_user = (new RwaExchangeRecordModel())
  73. ->where('user_id', $this->auth->id)
  74. ->where('welfare_id', $ids)
  75. ->count();
  76. if($check_user >= $welfare_config['limit_num']) $this->error('每人限制兑换' .$welfare_config['limit_num'].'套,您已达上限');
  77. }
  78. $order_no = date('YmdHis') . rand(1000, 9999);
  79. $inster_data = [
  80. 'order_no' => $order_no,
  81. 'user_id' => $this->auth->id,
  82. 'welfare_id' => $welfare_config['id'],
  83. 'product_id' => $welfare_config['product_id'],
  84. 'from_address_usdt' => $usdt_from_address,
  85. 'amount_usdt' => $welfare_config['usdt_num'],
  86. 'to_address' => $welfare_config['transfer_address'],
  87. 'create_time' => time()
  88. ];
  89. //有代币参与时
  90. if($welfare_config->is_token >0){
  91. if (empty($coin_from_address)) {
  92. $this->error(__('Parameter error'));
  93. }
  94. //检查区块链地址是否合法
  95. if(!(isErc20AddressValid($coin_from_address))){
  96. $this->error(__('Invalid parameters'));
  97. }
  98. $BscApi = new BscApi($welfare_config->token_address);
  99. $result_coin = $BscApi->getTransactionRecordsByAddress($coin_from_address, $welfare_config->transfer_address, 49990000);
  100. if ($result_coin['code'] == 0) {
  101. $this->error($result_coin['msg']);
  102. }
  103. Log::info($result_coin, '代币所有转入记录');
  104. $coin_list = [];
  105. foreach ($result_coin['data'] as $value) {
  106. if ($value['amount'] == $welfare_config->token_num) {
  107. $coin_list[] = $value;
  108. }
  109. }
  110. if (empty($coin_list)) {
  111. $this->error('未识别到代币转入记录');
  112. }
  113. Log::info($coin_list, '代币精准转入记录');
  114. $coin_data = [];
  115. foreach ($coin_list as $item) {
  116. $check_info = (new RwaExchangeRecordModel())->where('tx_hash_token', $item['hash'])->find();
  117. if (empty($check_info)) {
  118. $coin_data = $item;//获取未兑换过的代币转入记录
  119. break;
  120. }
  121. }
  122. if (empty($coin_data)) {
  123. $this->error('未识别到新代币转入记录');
  124. }
  125. Log::info($coin_list, '代币可用转入记录');
  126. //拼装代币转入记录
  127. $inster_data['token_name'] = $welfare_config->token_name;
  128. $inster_data['from_address_token'] = $coin_data['from'];
  129. $inster_data['amount_token'] = $coin_data['amount'];
  130. $inster_data['tx_hash_token'] = $coin_data['hash'];
  131. }
  132. //USDT转入记录
  133. $BscApi = new BscApi('0x55d398326f99059ff775485246999027b3197955');
  134. $result_usdt = $BscApi->getTransactionRecordsByAddress($usdt_from_address, $welfare_config->transfer_address, 49990000);
  135. if ($result_usdt['code'] == 0) {
  136. $this->error($result_usdt['msg']);
  137. }
  138. Log::info($result_usdt, 'USDT所有转入记录');
  139. $usdt_list = [];
  140. foreach ($result_usdt['data'] as $value) {
  141. if ($value['amount'] == $welfare_config->usdt_num) {
  142. $usdt_list[] = $value;
  143. }
  144. }
  145. if (empty($usdt_list)) {
  146. $this->error('未识别到USDT转入记录');
  147. }
  148. Log::info($usdt_list, 'USDT精准转入记录');
  149. $usdt_data = [];
  150. foreach ($usdt_list as $item) {
  151. $check_info = (new RwaExchangeRecordModel())->where('tx_hash_usdt', $item['hash'])->find();
  152. if (empty($check_info)) {
  153. $usdt_data = $item;
  154. break;
  155. }
  156. }
  157. if (empty($usdt_data)) {
  158. $this->error('未识别到新USDT转入记录');
  159. }
  160. Log::info($usdt_list, 'USDT可用入记录');
  161. //记录
  162. $inster_data['tx_hash_usdt'] = $usdt_data['hash'];
  163. Log::info($inster_data, '插入数据');*/
  164. try {
  165. Db::startTrans();
  166. //$rs = Db::name('rwa_exchange_record')->fetchSql(false)->insert($inster_data);
  167. //Log::info($rs, '插入状态');
  168. $usdt_data['amount'] = 100;
  169. $order_no = date('YmdHis') . rand(1000, 9999);
  170. //添加标记茶宝记录
  171. $ledgerWalletModel->changeWalletAccount($this->auth->id, Asset::FROZEN, $usdt_data['amount'], LedgerFrozenChangeModel::RwaExchangeRecord, 0);
  172. //发放产品奖励
  173. $rs =WelfareLoginc::setUserWelfareProduct($this->auth->id, $welfare_config['product_id'], $order_no, ProductOrder::RwaExchange);
  174. Log::info($rs, '发放产品奖励状态');
  175. Db::commit();
  176. $this->success('ok', $order_no);
  177. } catch (Exception $e) {
  178. Db::rollback();
  179. $this->error($e->getMessage(), null, $e->getCode());
  180. }
  181. }
  182. //Teac兑换列表
  183. public function getTeacList(ProductLists $productLists){
  184. $list = $productLists::where('is_teac', 1)
  185. ->where('status', 1)
  186. ->field('id,teac_price,thum,'.$this->lan.'_name as name')
  187. ->order('weigh desc')
  188. ->paginate($this->pageSize);
  189. $this->success('ok', $list);
  190. }
  191. //Teac兑换详情
  192. public function getTeacDetail(ProductLists $productLists){
  193. $ids = $this->request->post('product_id/d', 0);
  194. $list = $productLists::where('is_teac', 1)
  195. ->where('id', $ids)->where('status', 1)
  196. ->field('id,teac_price,images,'.$this->lan.'_name as name,details')
  197. ->find();
  198. $this->success('ok', $list);
  199. }
  200. //Teac兑换购买
  201. public function getTeacOrder(ProductLists $productLists, LedgerWalletModel $ledgerWalletModel, ProductOrder $productOrder){
  202. $params = $this->request->post();
  203. $validate = \think\Loader::validate('Exchange');
  204. if(!$validate->scene('order')->check($params)) $this->error($validate->getError());
  205. $rows = $productLists::where('id', $params['product_id'])->where('is_teac', 1)->where('status', 1)->find();
  206. if(empty($rows)) throw new Exception(__("产品暂未开放"));
  207. // 启动事务
  208. Db::startTrans();
  209. try {
  210. $teac = $ledgerWalletModel::getWalletTeac($this->auth->id);
  211. $amount = bcmul($params['stock'], $rows->teac_price, 2);
  212. if(bccomp($amount, $teac, 2) > 0) throw new Exception(__("Teac购买金额足"), 15001);
  213. //添加产品
  214. $productOrder::setPopularNoAreaOrder($params['stock'], 0, 0, $params['product_id'], $this->auth->id, $productOrder::TeacExchange);
  215. // 更新Teac和账变
  216. $ledgerWalletModel->changeWalletAccount($this->auth->id, Asset::TEAC, -$amount, LedgerTeacChangeModel::Exchange, 0);
  217. // 提交事务
  218. Db::commit();
  219. } catch (Exception $e) {
  220. // 回滚事务
  221. Db::rollback();
  222. $this->error($e->getMessage(), null, $e->getCode());
  223. }
  224. $this->success('ok');
  225. }
  226. }