Ledger.php 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. <?php
  2. namespace app\api\controller;
  3. use app\api\logic\WelfareLoginc;
  4. use app\common\controller\Api;
  5. use app\common\model\LedgerFrozenChangeModel;
  6. use app\common\model\ProductLists;
  7. use app\common\model\ProductOrder;
  8. use app\common\model\RwaExchangeRecordModel;
  9. use app\common\model\UserModel;
  10. use app\common\model\LedgerTokenChangeModel;
  11. use app\common\model\LedgerWalletModel;
  12. use app\common\model\OfflineWithdrawRecordModel;
  13. use think\Log;
  14. use think\Env;
  15. use think\Db;
  16. use fast\Asset;
  17. use think\Loader ;
  18. use think\Exception;
  19. /**
  20. * 首页接口
  21. */
  22. class Ledger extends Api
  23. {
  24. protected array $noNeedLogin = ['withdrawCallback'];
  25. /**
  26. * 资产首页
  27. */
  28. public function assets()
  29. {
  30. $config = getAllConfig();
  31. $wallet = LedgerWalletModel::getWallet($this->auth->id);
  32. $res['assets'] = $wallet->token;
  33. $res['transfes_fee'] = $config['transfer_fee']; //转让手续费比例
  34. $res['transfes_txt'] = $config['transfes_txt']; //转让文字表述
  35. $res['chabao_rate'] = $config['chabao_rate']; //茶宝汇率
  36. $res['giveaway_txt'] = $config['giveaway_txt']; //赠送说明
  37. $res['withdrawal_next_fee'] = $config['withdrawal_next_fee']; //600以下提现收费
  38. $res['withdrawal_up_fee'] = $config['withdrawal_up_fee']; //600以上提现收费
  39. $res['coin_list'] = [
  40. [
  41. 'coin_name' => '茶宝',
  42. 'coin_key' => 'token',
  43. 'amount' => $wallet->token,
  44. 'frozen_amount'=> $wallet->buying //冻结金额
  45. ],[
  46. 'coin_name' => 'TeaC',
  47. 'coin_key' => 'teac',
  48. 'amount' => $wallet->teac,
  49. 'frozen_amount'=> 0 //冻结金额
  50. ],[
  51. 'coin_name' => '茶宝(手续费账户)',
  52. 'coin_key' => 'frozen',
  53. 'amount' => $wallet->frozen,
  54. 'frozen_amount'=> 0 //冻结金额
  55. ],[
  56. 'coin_name' => 'TeaC·天使',
  57. 'coin_key' => 'teac_angel',
  58. 'amount' => $wallet->teac_angel,
  59. 'frozen_amount'=> 0 //冻结金额
  60. ]
  61. ];
  62. $this->success('', $res);
  63. }
  64. /**
  65. * 资产变动明细
  66. * @return void
  67. */
  68. public function coinList()
  69. {
  70. $type_id = $this->request->post('query.action'); // 账变类型
  71. $coin_type = $this->request->post('query.coin_type'); // 資金类型
  72. $where = ['user_id' => $this->auth->id];
  73. if ($type_id > 0) $where['action'] = $type_id;
  74. switch ($coin_type){
  75. case 'token':
  76. $paginator = Loader::model('LedgerTokenChangeModel');
  77. $res['data']= $paginator->alias('a')
  78. ->join('user u', 'a.from_id = u.id and a.action > 9 and a.action < 12', 'LEFT')
  79. ->field('a.*, u.address')
  80. ->where($where)
  81. ->order('a.id DESC')->paginate($this->pageSize);
  82. break;
  83. case 'frozen':
  84. $paginator = (new LedgerFrozenChangeModel());
  85. $res['data'] = $paginator->alias('a')
  86. ->join('user u', 'a.from_id = u.id and a.action > 2', 'LEFT')
  87. ->field('a.*, u.address')
  88. ->where($where)
  89. ->order('id DESC')->paginate($this->pageSize);
  90. break;
  91. case 'teac':
  92. $paginator = Loader::model('LedgerTeacChangeModel');
  93. $res['data'] = $paginator->where($where)->order('id DESC')->paginate($this->pageSize);
  94. break;
  95. case 'teac_angel':
  96. $paginator = (new LedgerUsdtChangeModel());
  97. break;
  98. case 'smh':
  99. $paginator = (new LedgerSmhChangeModel());
  100. break;
  101. default:
  102. $this->error(__('Invalid parameters'));
  103. break;
  104. }
  105. $res['statusList'] = $paginator::getStatusList();
  106. $this->success('',$res);
  107. }
  108. /**
  109. * 标记茶宝资产转账
  110. * @return void
  111. */
  112. public function frozenTransfer(UserModel $userModel, LedgerWalletModel $ledgerWalletModel)
  113. {
  114. $amount = $this->request->post('amount'); // 茶宝
  115. $account= $this->request->post('account', ''); // 账号
  116. $type = (substr($account, 0, 2) == '0x')? 0: 1; // type: 0地址 1uid
  117. if(empty($amount) || empty($account)){
  118. $this->error(__('Parameter error'));
  119. }
  120. // 验证地址是否以0x开头
  121. if($type == 0 && substr($account, 0, 2) !== '0x'){
  122. $this->error(__('Invalid address format, must start with 0x'));
  123. }
  124. $real = bcsub($amount, bcmul(getConfig('frozen_transfer'), $amount, 2), 2) ; // 手续费
  125. // 启动事务
  126. Db::startTrans();
  127. try {
  128. $user = (empty($type))? $userModel->getByAddress($account): $userModel->getById($account);
  129. if(empty($user)) throw new Exception(__("赠送用户不存在"));
  130. if($user['id'] == $this->auth->id) throw new Exception(__("赠送用户不能是自己"));
  131. $freeze = $ledgerWalletModel::getWalletFrozen($this->auth->id);
  132. //剩余冻结金额
  133. $available = bcsub($freeze, config('min_frozen'), 2);
  134. if(bccomp($amount, $available, 2) > 0) throw new Exception(__("转账后余额不能低于9.9"), 15001);
  135. // 更新USDT和账变
  136. $ledgerWalletModel->changeWalletAccount($this->auth->id, Asset::FROZEN, -$amount, LedgerFrozenChangeModel::Payment, $user['id']);
  137. $ledgerWalletModel->changeWalletAccount($user['id'], Asset::FROZEN, $real, LedgerFrozenChangeModel::Receive, $this->auth->id);
  138. // 提交事务
  139. Db::commit();
  140. } catch (Exception $e) {
  141. // 回滚事务
  142. Db::rollback();
  143. $this->error($e->getMessage(), null, $e->getCode());
  144. }
  145. $this->success('ok');
  146. }
  147. /**
  148. * 赠送/转账明细
  149. * @return void
  150. */
  151. public function getGiftDesc()
  152. {
  153. $this->success('', ['chabao'=>['value' => getConfig('chabao_giveaway'), 'text' => getConfig('chabao_giveaway_txt')],
  154. 'frozen'=>['value' => getConfig('frozen_transfer'), 'text' => getConfig('frozen_transfer_txt')]]);
  155. }
  156. /**
  157. * 茶宝赠送 0x
  158. * @return void
  159. */
  160. public function chabaoGift(UserModel $userModel, LedgerWalletModel $ledgerWalletModel)
  161. {
  162. $amount = $this->request->post('amount'); // 茶宝
  163. $account= $this->request->post('account', ''); // 账号
  164. $type = (substr($account, 0, 2) == '0x')? 0: 1; // type: 0地址 1uid
  165. if(empty($amount) || empty($account)){
  166. $this->error(__('Parameter error'));
  167. }
  168. // 验证地址是否以0x开头
  169. if($type == 0 && substr($account, 0, 2) !== '0x'){
  170. $this->error(__('Invalid address format, must start with 0x'));
  171. }
  172. $real = bcsub($amount, bcmul(getConfig('chabao_giveaway'), $amount, 2), 2) ; // 手续费
  173. // 启动事务
  174. Db::startTrans();
  175. try {
  176. $user = (empty($type))? $userModel->getByAddress($account): $userModel->getById($account);
  177. if(empty($user)) throw new Exception(__("赠送用户不存在"));
  178. if($user['id'] == $this->auth->id) throw new Exception(__("赠送用户不能是自己"));
  179. $chabao = $ledgerWalletModel::getWalletChaBao($this->auth->id);
  180. if(bccomp($amount, $chabao, 2) > 0) throw new Exception(__("余额不足请前往充值"), 15001);
  181. // 更新USDT和账变
  182. $ledgerWalletModel->changeWalletAccount($this->auth->id, Asset::TOKEN, -$amount, LedgerTokenChangeModel::GiftPay, $user['id']);
  183. $ledgerWalletModel->changeWalletAccount($user['id'], Asset::TOKEN, $real, LedgerTokenChangeModel::GiftReceipt, $this->auth->id);
  184. // 提交事务
  185. Db::commit();
  186. } catch (Exception $e) {
  187. // 回滚事务
  188. Db::rollback();
  189. $this->error($e->getMessage(), null, $e->getCode());
  190. }
  191. $this->success('ok');
  192. }
  193. /**
  194. * 提现自动打款回调
  195. * 接口回调信息格式:
  196. * @return void
  197. */
  198. public function withdrawCallback_my()
  199. {
  200. //post 获取过来的数据格式为:{"code":"1","data":{"orderNo":"1768","tx_hash":"xx4545"}}
  201. $parems = $this->request->post();
  202. Log::write('提现自动打款回调参数:','info');
  203. Log::info(json_encode($parems));
  204. if(empty($parems)){
  205. $this->error("回调参数为空");
  206. }
  207. if($parems['code'] != 1){
  208. $this->error("本次提现失败");
  209. }
  210. $rs_data = $parems['data'];
  211. $info = (new OfflineWithdrawRecordModel())
  212. ->where('id', $rs_data['orderNo'])
  213. ->find();
  214. if(empty($info)){
  215. $this->error("当前提现信息不存在");
  216. }
  217. if($info['status'] == 2){
  218. $this->success("更新成功");
  219. }
  220. if($info['status'] == 5){
  221. $is_update = (new OfflineWithdrawRecordModel())
  222. ->where('id', $info['id'])
  223. ->update([
  224. 'tx_hash' => $rs_data['tx_hash'],
  225. 'status' => 2,
  226. 'update_time' => time(),
  227. ]);
  228. if($is_update){
  229. $this->success("更新成功");
  230. }else{
  231. $this->error("更新失败");
  232. }
  233. }
  234. }
  235. // 获取充值地址
  236. public function getAddress()
  237. {
  238. return $this->success('', ['value'=> Env::get('rental.pay_address'), 'name'=>getConfig('recharge_txt')]);
  239. }
  240. }