DepositController.php 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. <?php
  2. namespace backend\controllers;
  3. use backend\helpers\MailHelper;
  4. use backend\helpers\PaginationHelper;
  5. use backend\helpers\ValidatorHelper;
  6. use backend\models\Config;
  7. use backend\models\Deposit;
  8. use backend\models\DepositConfig;
  9. use backend\models\SyncDesposit;
  10. use backend\models\Member;
  11. use backend\models\UserMember;
  12. use common\helpers\MtKit;
  13. use common\helpers\Utils;
  14. use common\pay\PayForm;
  15. use Yii;
  16. class DepositController extends BaseController
  17. {
  18. /**
  19. * 入金记录
  20. * @return \yii\web\Response
  21. */
  22. public function actionIndex()
  23. {
  24. $data = Yii::$app->getRequest()->get();
  25. $data['type'] = isset($data['type']) ? trim($data['type']) : '';
  26. $data['from'] = isset($data['from']) ? trim($data['from']) : '';
  27. $data['name'] = isset($data['name']) ? trim($data['name']) : '';
  28. $data['memberId'] = isset($data['memberId']) ? trim($data['memberId']) : '';
  29. $data['inTimeStart'] = isset($data['inTimeStart']) ? trim($data['inTimeStart']) : '';
  30. $data['inTimeEnd'] = isset($data['inTimeEnd']) ? trim($data['inTimeEnd']) : '';
  31. $data['search'] = isset($data['search']) ? trim($data['search']) : '';
  32. $data['page'] = isset($data['page']) ? max(intval($data['page']), 1) : 1;
  33. $data['pageSize'] = isset($data['pageSize']) ? intval($data['pageSize']) : 20;
  34. $data['orderBy'] = isset($data['orderBy']) ? trim($data['orderBy']) : 'id desc';
  35. $data = ValidatorHelper::validateData($data, [
  36. ['type', 'integer'],
  37. ['from', 'string'],
  38. ['name', 'string'],
  39. ['memberId', 'integer'],
  40. ['inTimeStart', 'integer'],
  41. ['inTimeEnd', 'integer'],
  42. ['search', 'string'],
  43. ['page', 'integer', 'min' => 1],
  44. ['pageSize', 'integer', 'min' => 1],
  45. ['orderBy', 'string'],
  46. ], $errors);
  47. if ($data == false) {
  48. return $this->outJson(0, '', $errors);
  49. }
  50. $query = Deposit::find()->orderBy($data['orderBy']);
  51. $query->andFilterWhere(['crm_deposit.mt4_status' => $data['type']]);
  52. if ($data['from'] == 'admin') {
  53. $query->andFilterWhere(['member_id' => $data['memberId']]);
  54. } else {
  55. $query->andWhere(['member_id' => $data['memberId']]);
  56. }
  57. if (trim($data['name']) != '') {
  58. $query->leftJoin(Member::tableName() . ' m', 'crm_deposit.member_id=m.id')->andWhere(['like', 'm.name', $data['name']]);
  59. }
  60. $query->andFilterWhere(['>=', 'in_time', $data['inTimeStart']]);
  61. $query->andFilterWhere(['<', 'in_time', $data['inTimeEnd']]);
  62. $query->andFilterWhere(['or', ['like', 'login', $data['search']], ['like', 'id', $data['search']]]);
  63. $result = PaginationHelper::queryPage($query, $data['page'], $data['pageSize']);
  64. if ($data['from'] == 'admin') {
  65. foreach ($result['dataList'] as $key => &$row) {
  66. $member = Member::findById($row['member_id']);
  67. if ($member == null) {
  68. $row['name'] = '';
  69. $row['mobile'] = '';
  70. } else {
  71. $row['name'] = $member['name'];
  72. $row['mobile'] = $member['mobile'];
  73. }
  74. $userMember = UserMember::findByLogin($row['login']);
  75. if ($userMember == null) {
  76. $row['IBNAME'] = '';
  77. } else {
  78. $member = Member::findById($userMember['member_id']);
  79. if ($member == null) {
  80. $row['IBNAME'] = '';
  81. } else {
  82. $row['IBNAME'] = $member['name'];
  83. }
  84. }
  85. }
  86. }
  87. return $this->outJson(1, $result);
  88. }
  89. /**
  90. * 入金统计
  91. * @return \yii\web\Response
  92. */
  93. public function actionSumDeposit()
  94. {
  95. $type = trim(Yii::$app->getRequest()->get('type'));
  96. $sum = Deposit::sumDepositByType($type);
  97. return $this->outJson(1, Utils::formatFloatOrInt($sum));
  98. }
  99. /**
  100. * 入金补单
  101. */
  102. public function actionPatchIntoGold()
  103. {
  104. $id = intval(Yii::$app->getRequest()->post('id'));
  105. $admin_name = trim(Yii::$app->getRequest()->post('admin_name'));
  106. if ($id <= 0) {
  107. return $this->outJson(0, [], '未指定数据对象');
  108. }
  109. $deposit = Deposit::findById($id);
  110. if ($deposit == null) {
  111. return $this->outJson(0, [], '数据对象不存在');
  112. }
  113. if ($deposit->mt4_status == 0) {
  114. $deposit->mt4_status = 1;
  115. $deposit->type = 1;
  116. $admin_name != '' && $deposit->admin_name = $admin_name;
  117. if ($deposit->save(false)) {
  118. SyncDesposit::updateAll(['is_sync' => 1], ['memo' => $deposit['order_sn'], 'is_sync' => 0]);
  119. MtKit::deposit($deposit['login'], $deposit['amount'], 'Deposit');
  120. $member = Member::findById($deposit->member_id);
  121. if ($member != null) {
  122. $config = Config::findOne(1);
  123. $paramArray = [
  124. 'name' => $member['name'],
  125. 'login' => $deposit['login'],
  126. 'usd' => $deposit['amount'],
  127. 'rmb' => $deposit['rmb'],
  128. 'rate' => $deposit['rate'],
  129. ];
  130. // 发送邮件
  131. MailHelper::sendMail("恭喜您,您的入金已成功受理", $member['username'], $paramArray, '', $config->mail_deposit);
  132. }
  133. }
  134. }
  135. return $this->outJson(1, [], '操作成功');
  136. }
  137. /**
  138. * 获取入金配置
  139. * @return \yii\web\Response
  140. */
  141. public function actionGetDepositConfig()
  142. {
  143. $depositConfig = [];
  144. foreach (PayForm::$payNames as $payId => $payName) {
  145. $depositConfig[$payId] = [
  146. 'id' => $payId,
  147. 'label' => $payName,
  148. 'enable' => 0,
  149. ];
  150. }
  151. /** @var DepositConfig $model */
  152. $model = DepositConfig::find()->one();
  153. if ($model) {
  154. $configData = @json_decode($model->config_data, true);
  155. foreach ((array)$configData as $key => $row) {
  156. if (isset($depositConfig[$row['id']])) {
  157. $depositConfig[$row['id']]['enable'] = isset($row['enable']) && $row['enable'] == 1 ? 1 : 0;
  158. }
  159. }
  160. }
  161. return $this->outJson(1, $depositConfig, '操作成功');
  162. }
  163. /**
  164. * 设置入金配置
  165. * @return \yii\web\Response
  166. */
  167. public function actionSetDepositConfig()
  168. {
  169. $depositConfig = [];
  170. foreach (PayForm::$payNames as $payId => $payName) {
  171. $depositConfig[$payId] = [
  172. 'id' => $payId,
  173. 'label' => $payName,
  174. 'enable' => 0,
  175. ];
  176. }
  177. /** @var DepositConfig $model */
  178. $model = DepositConfig::find()->one();
  179. if ($model == null) {
  180. $model = new DepositConfig();
  181. }
  182. $configData = @json_decode($model->config_data, true);
  183. foreach ((array)$configData as $key => $row) {
  184. if (isset($depositConfig[$row['id']])) {
  185. $depositConfig[$row['id']]['enable'] = isset($row['enable']) && $row['enable'] == 1 ? 1 : 0;
  186. }
  187. }
  188. $config = trim(Yii::$app->getRequest()->post('config'));
  189. if ($config == '') {
  190. return $this->outJson(0, [], '参数非法' . __LINE__);
  191. }
  192. $configArr = @json_decode($config, true);
  193. if ($configArr == null) {
  194. return $this->outJson(0, [], '参数非法' . __LINE__);
  195. }
  196. foreach ($configArr as $key => $row) {
  197. if (!isset($row['id']) || !isset($depositConfig[$row['id']])) {
  198. continue;
  199. }
  200. $depositConfig[$row['id']]['enable'] = isset($row['enable']) && $row['enable'] == 1 ? 1 : 0;
  201. }
  202. $model->config_data = json_encode($depositConfig, 320);
  203. if ($model->save()) {
  204. return $this->outJson(1, [], '操作成功');
  205. } else {
  206. return $this->outJson(0, [], '操作失败');
  207. }
  208. }
  209. }