AdminController.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. <?php
  2. namespace App\Controllers;
  3. use App\Models\InviteCode;
  4. use App\Models\Node;
  5. use App\Models\TrafficLog;
  6. use App\Models\Payback;
  7. use App\Models\Coupon;
  8. use App\Models\User;
  9. use App\Utils\Tools;
  10. use App\Services\Analytics;
  11. use Ozdemir\Datatables\Datatables;
  12. use App\Utils\DatatablesHelper;
  13. /**
  14. * Admin Controller
  15. */
  16. class AdminController extends UserController
  17. {
  18. public function index($request, $response, $args)
  19. {
  20. $sts = new Analytics();
  21. return $this->view()->assign('sts', $sts)->display('admin/index.tpl');
  22. }
  23. public function node($request, $response, $args)
  24. {
  25. $nodes = Node::all();
  26. return $this->view()->assign('nodes', $nodes)->display('admin/node.tpl');
  27. }
  28. public function sys()
  29. {
  30. return $this->view()->display('admin/index.tpl');
  31. }
  32. public function invite($request, $response, $args)
  33. {
  34. $table_config['total_column'] = array("id" => "ID",
  35. "total" => "原始金额", "event_user_id" => "发起用户ID",
  36. "event_user_name" => "发起用户名", "ref_user_id" => "获利用户ID",
  37. "ref_user_name" => "获利用户名", "ref_get" => "获利金额",
  38. "datetime" => "时间");
  39. $table_config['default_show_column'] = array();
  40. foreach ($table_config['total_column'] as $column => $value) {
  41. array_push($table_config['default_show_column'], $column);
  42. }
  43. $table_config['ajax_url'] = 'payback/ajax';
  44. return $this->view()->assign('table_config', $table_config)->display('admin/invite.tpl');
  45. }
  46. public function addInvite($request, $response, $args)
  47. {
  48. $n = $request->getParam('num');
  49. $prefix = $request->getParam('prefix');
  50. if ($request->getParam('uid')!="0") {
  51. if (strpos($request->getParam('uid'), "@")!=false) {
  52. $user=User::where("email", "=", $request->getParam('uid'))->first();
  53. } else {
  54. $user=User::Where("id", "=", $request->getParam('uid'))->first();
  55. }
  56. if ($user==null) {
  57. $res['ret'] = 0;
  58. $res['msg'] = "邀请码添加失败,检查用户id或者用户邮箱是否输入正确";
  59. return $response->getBody()->write(json_encode($res));
  60. }
  61. $uid = $user->id;
  62. } else {
  63. $uid=0;
  64. }
  65. $user->invite_num += $n;
  66. $user->save();
  67. $res['ret'] = 1;
  68. $res['msg'] = "邀请次数添加成功";
  69. return $response->getBody()->write(json_encode($res));
  70. }
  71. public function coupon($request, $response, $args)
  72. {
  73. $table_config['total_column'] = array("id" => "ID", "code" => "优惠码",
  74. "expire" => "过期时间", "shop" => "限定商品ID",
  75. "credit" => "额度");
  76. $table_config['default_show_column'] = array();
  77. foreach ($table_config['total_column'] as $column => $value) {
  78. array_push($table_config['default_show_column'], $column);
  79. }
  80. $table_config['ajax_url'] = 'coupon/ajax';
  81. return $this->view()->assign('table_config', $table_config)->display('admin/coupon.tpl');
  82. }
  83. public function addCoupon($request, $response, $args)
  84. {
  85. $code = new Coupon();
  86. $code->onetime=$request->getParam('onetime');
  87. $code->code=$request->getParam('prefix').Tools::genRandomChar(8);
  88. $code->expire=time()+$request->getParam('expire')*3600;
  89. $code->shop=$request->getParam('shop');
  90. $code->credit=$request->getParam('credit');
  91. $code->save();
  92. $res['ret'] = 1;
  93. $res['msg'] = "优惠码添加成功";
  94. return $response->getBody()->write(json_encode($res));
  95. }
  96. public function trafficLog($request, $response, $args)
  97. {
  98. $table_config['total_column'] = array("id" => "ID", "user_id" => "用户ID",
  99. "user_name" => "用户名", "node_name" => "使用节点",
  100. "rate" => "倍率", "origin_traffic" => "实际使用流量",
  101. "traffic" => "结算流量",
  102. "log_time" => "记录时间");
  103. $table_config['default_show_column'] = array("id", "user_id",
  104. "user_name", "node_name",
  105. "rate", "origin_traffic",
  106. "traffic", "log_time");
  107. $table_config['ajax_url'] = 'trafficlog/ajax';
  108. return $this->view()->assign('table_config', $table_config)->display('admin/trafficlog.tpl');
  109. }
  110. public function ajax_trafficLog($request, $response, $args)
  111. {
  112. $datatables = new Datatables(new DatatablesHelper());
  113. $datatables->query('Select log.id,log.user_id,user.user_name,node.name as node_name,log.rate,(log.u + log.d) as origin_traffic,log.traffic,log.log_time from user_traffic_log as log,user,ss_node as node WHERE log.user_id = user.id AND log.node_id = node.id');
  114. $datatables->edit('log_time', function ($data) {
  115. return date('Y-m-d H:i:s', $data['log_time']);
  116. });
  117. $datatables->edit('origin_traffic', function ($data) {
  118. return Tools::flowAutoShow($data['origin_traffic']);
  119. });
  120. $body = $response->getBody();
  121. $body->write($datatables->generate());
  122. }
  123. public function ajax_payback($request, $response, $args)
  124. {
  125. $datatables = new Datatables(new DatatablesHelper());
  126. $datatables->query('Select payback.id,payback.total,payback.userid as event_user_id,event_user.user_name as event_user_name,payback.ref_by as ref_user_id,ref_user.user_name as ref_user_name,payback.ref_get,payback.datetime from payback,user as event_user,user as ref_user where event_user.id = payback.userid and ref_user.id = payback.ref_by');
  127. $datatables->edit('datetime', function ($data) {
  128. return date('Y-m-d H:i:s', $data['datetime']);
  129. });
  130. $body = $response->getBody();
  131. $body->write($datatables->generate());
  132. }
  133. public function ajax_coupon($request, $response, $args)
  134. {
  135. $datatables = new Datatables(new DatatablesHelper());
  136. $datatables->query('Select id,code,expire,shop,credit from coupon');
  137. $datatables->edit('expire', function ($data) {
  138. return date('Y-m-d H:i:s', $data['expire']);
  139. });
  140. $body = $response->getBody();
  141. $body->write($datatables->generate());
  142. }
  143. }