PremiumPlatformController.php 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. <?php
  2. namespace App\Http\Controllers\Admin\Premium;
  3. use Illuminate\Http\Request;
  4. use App\Services\AipHttpClient;
  5. use App\Http\Controllers\Controller;
  6. use Illuminate\Support\Facades\DB;
  7. use App\Models\Telegram\TelegramBot;
  8. use App\Models\Premium\PremiumPlatform;
  9. use App\Models\Energy\EnergyPlatformBot;
  10. use App\Models\Transit\TransitWallet;
  11. use App\Http\Services\RsaServices;
  12. class PremiumPlatformController extends Controller
  13. {
  14. public $PlatformName = ['1' => '自己搭建'];
  15. public $Status = ['开启','关闭'];
  16. public function index(Request $request)
  17. {
  18. $PlatformName = $this->PlatformName;
  19. $Status = $this->Status;
  20. $botData = TelegramBot::pluck('bot_username','rid');
  21. return view('admin.premium.platform.index',compact("PlatformName","Status","botData"));
  22. }
  23. //列表
  24. public function getData(Request $request)
  25. {
  26. $model = PremiumPlatform::from('premium_platform as a')
  27. ->leftJoin('telegram_bot as b','a.bot_rid','b.rid')
  28. ->where(function($query) use ($request){
  29. if ($request->platform_hash != '') {
  30. $query->where('a.platform_hash', 'like' ,"%" . $request->platform_hash ."%");
  31. }
  32. });
  33. $count = $model->count();
  34. $limit = $request->limit ?? 15;
  35. $offset = $request->page ? ($request->page - 1) * $limit : 0;
  36. $data = $model->limit($limit)->offset($offset)->select('a.*','b.bot_token','b.bot_firstname','b.bot_username')->orderBy('a.rid','desc')->get();
  37. $PlatformName = $this->PlatformName;
  38. $rsa_services = new RsaServices();
  39. $data = $data->map(function($query) use ($rsa_services,$PlatformName){
  40. $platform_cookie = $rsa_services->privateDecrypt($query->platform_cookie); //解密
  41. $query->platform_cookie = mb_substr($platform_cookie, 0,4).'****'.mb_substr($platform_cookie, -4,4);
  42. $platform_phrase = $rsa_services->privateDecrypt($query->platform_phrase); //解密
  43. $query->platform_phrase = mb_substr($platform_phrase, 0,4).'****'.mb_substr($platform_phrase, -4,4);
  44. $query->platform_name_val = $PlatformName[$query->platform_name];
  45. return $query;
  46. });
  47. return ['code' => '0', 'data' => $data, 'count' => $count];
  48. }
  49. //添加
  50. public function add(Request $request)
  51. {
  52. $data = PremiumPlatform::where('bot_rid', $request->bot_rid)->where('platform_hash', $request->platform_hash)->first();
  53. if(!empty($data)){
  54. return $this->responseData(400, '机器人对应会员平台已存在');
  55. }
  56. $energydata = EnergyPlatformBot::where('receive_wallet', $request->receive_wallet)->first();
  57. if(!empty($energydata)){
  58. return $this->responseData(400, '不能和能量钱包地址一致');
  59. }
  60. $botdata = TelegramBot::where('recharge_wallet_addr', $request->receive_wallet)->first();
  61. if(!empty($botdata)){
  62. return $this->responseData(400, '收款钱包不能和机器人充值地址一致');
  63. }
  64. $transitdata = TransitWallet::where('receive_wallet', $request->receive_wallet)->first();
  65. if(!empty($transitdata)){
  66. return $this->responseData(400, '不能和闪兑钱包地址一致');
  67. }
  68. $rsa_services = new RsaServices();
  69. $platform_cookie = $rsa_services->publicEncrypt($request->platform_cookie);
  70. $res = PremiumPlatform::create([
  71. 'bot_rid' => $request->bot_rid,
  72. 'platform_name' => $request->platform_name,
  73. 'tg_admin_uid' => $request->tg_admin_uid ?? '',
  74. 'platform_hash' => $request->platform_hash,
  75. 'platform_cookie' => $platform_cookie ?? '',
  76. 'tg_notice_obj_receive' => $request->tg_notice_obj_receive ?? '',
  77. 'tg_notice_obj_send' => $request->tg_notice_obj_send ?? '',
  78. 'receive_wallet' => $request->receive_wallet ?? '',
  79. 'get_tx_time' => $request->get_tx_time ?? null,
  80. 'comments' => $request->comments ?? '',
  81. 'create_time' => nowDate()
  82. ]);
  83. return $res ? $this->responseData(200, '添加成功') : $this->responseData(400, '添加失败');
  84. }
  85. //删除
  86. public function delete(Request $request)
  87. {
  88. $res = PremiumPlatform::where('rid', $request->rid)->delete();
  89. return $res ? $this->responseData(200, '删除成功') : $this->responseData(400, '删除失败');
  90. }
  91. //编辑
  92. public function update(Request $request)
  93. {
  94. $data = PremiumPlatform::where('bot_rid', $request->bot_rid)->where('platform_name', $request->platform_name)->where('rid','<>',$request->rid)->first();
  95. if(!empty($data)){
  96. return $this->responseData(400, '机器人对应会员平台已存在');
  97. }
  98. $energydata = EnergyPlatformBot::where('receive_wallet', $request->receive_wallet)->first();
  99. if(!empty($energydata)){
  100. return $this->responseData(400, '不能和能量钱包地址一致');
  101. }
  102. $botdata = TelegramBot::where('recharge_wallet_addr', $request->receive_wallet)->first();
  103. if(!empty($botdata)){
  104. return $this->responseData(400, '收款钱包不能和机器人充值地址一致');
  105. }
  106. $transitdata = TransitWallet::where('receive_wallet', $request->receive_wallet)->first();
  107. if(!empty($transitdata)){
  108. return $this->responseData(400, '不能和闪兑钱包地址一致');
  109. }
  110. DB::beginTransaction();
  111. try {
  112. $data = PremiumPlatform::where('rid', $request->rid)->first();
  113. $data->bot_rid = $request->bot_rid;
  114. $data->platform_name = $request->platform_name;
  115. $data->tg_admin_uid = $request->tg_admin_uid ?? '';
  116. $data->platform_hash = $request->platform_hash;
  117. $data->tg_notice_obj_receive = $request->tg_notice_obj_receive ?? '';
  118. $data->tg_notice_obj_send = $request->tg_notice_obj_send ?? '';
  119. $data->receive_wallet = $request->receive_wallet ?? '';
  120. $data->get_tx_time = $request->get_tx_time ?? null;
  121. $data->comments = $request->comments ?? '';
  122. $data->update_time = nowDate();
  123. $data->save();
  124. DB::commit();
  125. return $this->responseData(200, '更新成功');
  126. } catch (\Exception $e) {
  127. DB::rollBack();
  128. return $this->responseData(400, '更新失败'.$e->getMessage());
  129. }
  130. }
  131. //编辑apikey
  132. public function updateapikey(Request $request)
  133. {
  134. $rsa_services = new RsaServices();
  135. $platform_cookie = $rsa_services->publicEncrypt($request->platform_cookie);
  136. DB::beginTransaction();
  137. try {
  138. $data = PremiumPlatform::where('rid', $request->rid)->first();
  139. $data->platform_cookie = $platform_cookie;
  140. $data->save();
  141. DB::commit();
  142. return $this->responseData(200, '更新成功');
  143. } catch (\Exception $e) {
  144. DB::rollBack();
  145. return $this->responseData(400, '更新失败'.$e->getMessage());
  146. }
  147. }
  148. //编辑助记词
  149. public function updatephrase(Request $request)
  150. {
  151. $rsa_services = new RsaServices();
  152. $platform_phrase = $rsa_services->publicEncrypt($request->platform_phrase);
  153. $model = PremiumPlatform::where('rid', $request->rid)->thirdData($request->platform_phrase);
  154. DB::beginTransaction();
  155. try {
  156. $data = PremiumPlatform::where('rid', $request->rid)->first();
  157. $data->platform_phrase = $platform_phrase;
  158. $data->save();
  159. DB::commit();
  160. return $this->responseData(200, '更新成功');
  161. } catch (\Exception $e) {
  162. DB::rollBack();
  163. return $this->responseData(400, '更新失败'.$e->getMessage());
  164. }
  165. }
  166. //编辑状态
  167. public function change_status(Request $request)
  168. {
  169. DB::beginTransaction();
  170. try {
  171. $data = PremiumPlatform::where('rid', $request->rid)->first();
  172. $data->status = $request->status == 1 ? 0 : 1;
  173. $data->save();
  174. DB::commit();
  175. return $this->responseData(200, '更新成功');
  176. } catch (\Exception $e) {
  177. DB::rollBack();
  178. return $this->responseData(400, '更新失败'.$e->getMessage());
  179. }
  180. }
  181. }