UsersController.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <?php
  2. namespace backend\modules\ib\controllers;
  3. use common\helpers\ExcelHelper;
  4. use Yii;
  5. use backend\models\MemberApi;
  6. use backend\models\Mt4UserApi;
  7. use yii\helpers\Url;
  8. use common\helpers\UserAgentHelper;
  9. class UsersController extends BaseController
  10. {
  11. /**
  12. * 名下账户
  13. */
  14. public function actionIndex()
  15. {
  16. $request = Yii::$app->request;
  17. $ibId = (int) $request->get('ibId');
  18. $api = new MemberApi();
  19. $ibs = $api->getIbs()['data'];
  20. return $this->render('index', [
  21. 'ibId' => $ibId,
  22. 'ibs' => $ibs,
  23. 'isHaveAdmin' => Yii::$app->user->identity->isHaveAdmin(),
  24. ]);
  25. }
  26. /**
  27. * 列表数据
  28. */
  29. public function actionList()
  30. {
  31. $get = Yii::$app->request->get();
  32. $orderInt = isset($get['order'][0]['column']) ? (int) $get['order'][0]['column'] : 1;
  33. $order = isset($get['columns'][$orderInt]['data']) ? $get['columns'][$orderInt]['data'] : '';
  34. $orderBy = isset($get['order'][0]['dir']) ? $get['order'][0]['dir'] : 'desc';
  35. $search = isset($get['search']['value']) ? $get['search']['value'] : '';
  36. $start = isset($get['start']) ? (int) $get['start'] : 0;
  37. $length = isset($get['length']) ? (int) $get['length'] : 20;
  38. $ibId = isset($get['ibId']) ? $get['ibId'] : 0;
  39. $draw = isset($get['draw']) ? $get['draw'] : 1;
  40. $params = [
  41. 'order' => $order,
  42. 'orderBy' => $orderBy,
  43. 'search' => $search,
  44. 'start' => $start,
  45. 'length' => $length,
  46. 'ibId' => $ibId,
  47. 'draw' => $draw,
  48. ];
  49. if ($params['length'] > 5000) {
  50. if (Yii::$app->getRequest()->getIsAjax()) {
  51. Yii::$app->getResponse()->redirect(Url::current(), UserAgentHelper::isIE() ? 200 : 302);
  52. } else {
  53. $this->exportXls($params);
  54. }
  55. Yii::$app->end();
  56. }
  57. $api = new Mt4UserApi();
  58. $result = $api->getList($params);
  59. echo json_encode($result['data']);
  60. }
  61. /**
  62. * @param array $params
  63. */
  64. protected function exportXls($params)
  65. {
  66. ExcelHelper::init();
  67. $attachmentName = Yii::$app->user->identity->name . "_名下账户_" . date('Y-m-d') . '.xlsx';
  68. $header = ['代理商', '账户', '姓名', '杠杆', '余额', '保证金', '可用保证金', '保证金比例', '净值', '最后更新时间'];
  69. $source = [];
  70. $summaryRow = [];
  71. $api = new Mt4UserApi();
  72. $params['length'] = 5000;
  73. while (true) {
  74. $result = $api->getList($params);
  75. if ($result['code'] == 1 && !empty($result['data']['data'])) {
  76. foreach ((array)$result['data']['data'] as $key => $row) {
  77. $arr = [];
  78. $arr[] = $row['name'];
  79. $arr[] = $row['LOGIN'];
  80. $arr[] = $row['NAME'];
  81. $arr[] = $row['LEVERAGE'];
  82. $arr[] = $row['BALANCE'];
  83. $arr[] = $row['MARGIN'];
  84. $arr[] = $row['MARGIN_FREE'];
  85. $arr[] = $row['MARGIN_LEVEL'];
  86. $arr[] = $row['EQUITY'];
  87. $arr[] = $row['MODIFY_TIME'];
  88. $source[] = $arr;
  89. }
  90. $summaryRow = array_pop($source);
  91. } else {
  92. break;
  93. }
  94. $params['start'] += $params['length'];
  95. if ($params['start'] >= $result['data']['recordsTotal']) {
  96. break;
  97. }
  98. }
  99. $source[] = $summaryRow;
  100. ExcelHelper::output($source, $header, $attachmentName);
  101. }
  102. }