DepositController.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291
  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 common\lib\Mt4ManagerApi;
  16. use Yii;
  17. class DepositController extends BaseController
  18. {
  19. /**
  20. * 入金记录
  21. * @return \yii\web\Response
  22. */
  23. public function actionIndex()
  24. {
  25. $data = Yii::$app->getRequest()->get();
  26. $data['type'] = isset($data['type']) ? trim($data['type']) : '';
  27. $data['from'] = isset($data['from']) ? trim($data['from']) : '';
  28. $data['name'] = isset($data['name']) ? trim($data['name']) : '';
  29. $data['memberId'] = isset($data['memberId']) ? trim($data['memberId']) : '';
  30. $data['inTimeStart'] = isset($data['inTimeStart']) ? trim($data['inTimeStart']) : '';
  31. $data['inTimeEnd'] = isset($data['inTimeEnd']) ? trim($data['inTimeEnd']) : '';
  32. $data['search'] = isset($data['search']) ? trim($data['search']) : '';
  33. $data['page'] = isset($data['page']) ? max(intval($data['page']), 1) : 1;
  34. $data['pageSize'] = isset($data['pageSize']) ? intval($data['pageSize']) : 20;
  35. $data['orderBy'] = isset($data['orderBy']) ? trim($data['orderBy']) : 'id desc';
  36. $data = ValidatorHelper::validateData($data, [
  37. ['type', 'integer'],
  38. ['from', 'string'],
  39. ['name', 'string'],
  40. ['memberId', 'integer'],
  41. ['inTimeStart', 'integer'],
  42. ['inTimeEnd', 'integer'],
  43. ['search', 'string'],
  44. ['page', 'integer', 'min' => 1],
  45. ['pageSize', 'integer', 'min' => 1],
  46. ['orderBy', 'string'],
  47. ], $errors);
  48. if ($data == false) {
  49. return $this->outJson(0, '', $errors);
  50. }
  51. $query = Deposit::find()->orderBy($data['orderBy']);
  52. $query->andFilterWhere(['crm_deposit.mt4_status' => $data['type']]);
  53. if ($data['from'] == 'admin') {
  54. $query->andFilterWhere(['member_id' => $data['memberId']]);
  55. } else {
  56. $query->andWhere(['member_id' => $data['memberId']]);
  57. }
  58. if (trim($data['name']) != '') {
  59. $query->leftJoin(Member::tableName() . ' m', 'crm_deposit.member_id=m.id')->andWhere(['like', 'm.name', $data['name']]);
  60. }
  61. $query->andFilterWhere(['>=', 'in_time', $data['inTimeStart']]);
  62. $query->andFilterWhere(['<', 'in_time', $data['inTimeEnd']]);
  63. $query->andFilterWhere(['or', ['like', 'login', $data['search']], ['like', 'id', $data['search']]]);
  64. $query->leftJoin('crm_mt4_deposit_log l','crm_deposit.id = l.log_id');
  65. // $query->where("l.mt4_order_id != ''");
  66. $query->select('crm_deposit.*,l.mt4_order_id');
  67. $result = PaginationHelper::queryPage($query, $data['page'], $data['pageSize']);
  68. if ($data['from'] == 'admin') {
  69. foreach ($result['dataList'] as $key => &$row) {
  70. $member = Member::findById($row['member_id']);
  71. if ($member == null) {
  72. $row['name'] = '';
  73. $row['mobile'] = '';
  74. } else {
  75. $row['name'] = $member['name'];
  76. $row['mobile'] = $member['mobile'];
  77. }
  78. $userMember = UserMember::findByLogin($row['login']);
  79. if ($userMember == null) {
  80. $row['IBNAME'] = '';
  81. } else {
  82. $member = Member::findById($userMember['member_id']);
  83. if ($member == null) {
  84. $row['IBNAME'] = '';
  85. } else {
  86. $row['IBNAME'] = $member['name'];
  87. }
  88. }
  89. }
  90. }
  91. return $this->outJson(1, $result);
  92. }
  93. /**
  94. * 入金统计
  95. * @return \yii\web\Response
  96. */
  97. public function actionSumDeposit()
  98. {
  99. $type = trim(Yii::$app->getRequest()->get('type'));
  100. $sum = Deposit::sumDepositByType($type);
  101. return $this->outJson(1, Utils::formatFloatOrInt($sum));
  102. }
  103. /**
  104. * 入金补单
  105. */
  106. public function actionPatchIntoGold()
  107. {
  108. $id = intval(Yii::$app->getRequest()->post('id'));
  109. $admin_name = trim(Yii::$app->getRequest()->post('admin_name'));
  110. if ($id <= 0) {
  111. return $this->outJson(0, [], '未指定数据对象');
  112. }
  113. $deposit = Deposit::findById($id);
  114. if ($deposit == null) {
  115. return $this->outJson(0, [], '数据对象不存在');
  116. }
  117. if ($deposit->mt4_status == 0) {
  118. $res = MtKit::deposit($deposit['login'], $deposit['amount'], 'Deposit',$id); //增加了一个字段;
  119. if(!$res){
  120. return $this->outJson(0, [], '补单失败');
  121. }
  122. $deposit->mt4_status = 1;
  123. $deposit->type = 1;
  124. $admin_name != '' && $deposit->admin_name = $admin_name;
  125. if ($deposit->save(false)) {
  126. SyncDesposit::updateAll(['is_sync' => 1], ['memo' => $deposit['order_sn'], 'is_sync' => 0]);
  127. $member = Member::findById($deposit->member_id);
  128. if ($member != null) {
  129. $config = Config::findOne(1);
  130. $paramArray = [
  131. 'name' => $member['name'],
  132. 'login' => $deposit['login'],
  133. 'usd' => $deposit['amount'],
  134. 'rmb' => $deposit['rmb'],
  135. 'rate' => $deposit['rate'],
  136. ];
  137. // 发送邮件
  138. MailHelper::sendMail("恭喜您,您的入金已成功受理", $member['username'], $paramArray, '', $config->mail_deposit);
  139. }
  140. }
  141. }
  142. return $this->outJson(1, [], '操作成功');
  143. }
  144. /**
  145. * 撤销入金
  146. */
  147. public function actionRevokegold(){
  148. $id = (int) Yii::$app->request->post('id'); //获取入金id
  149. $mt4_id = (int) Yii::$app->request->post('mt4_id'); //获取mt4的订单号
  150. file_put_contents('goldentry_id.txt',$id);
  151. file_put_contents('goldentry_mt4_id.txt',$mt4_id);
  152. if ($id <= 0) {
  153. return $this->outJson(0, [], '未指定数据对象');
  154. }
  155. $login = Deposit::findOne($id)['login']; //获取login参数
  156. $res = Deposit::updateAll(['type' => 0], "id = $id"); //更新入金表的状态(等待) 后续还需要更改什么
  157. if($res){
  158. //调用mt4的撤销入金接口
  159. $api = new Mt4ManagerApi();
  160. $result = $api->revokeOrder($mt4_id);
  161. if(empty($result)){
  162. return $this->outJson(0, [], '更新失败');
  163. }
  164. $result = json_decode($result,true);
  165. $tt = print_r($result,true);
  166. file_put_contents('goldentry1.txt',$tt);
  167. if(!$result['ret']){
  168. $result2 = $api->fixbalance($login);
  169. if(empty($result2)){
  170. return $this->outJson(0, [], '更新失败');
  171. }
  172. $res2 = json_decode($result2,true);
  173. $tt = print_r($res2,true);
  174. file_put_contents('goldentry2.txt',$tt);
  175. if(!$res2['ret']){
  176. $res3 = Deposit::updateAll(['mt4_status' => 0], "id = $id"); //更新出金表的状态(mt4未扣减)
  177. if($res3){
  178. return $this->outJson(1, [], '操作成功');
  179. }else{
  180. return $this->outJson(0, [], '更新失败');
  181. }
  182. }
  183. }else{
  184. return $this->outJson(0, [], '更新失败');
  185. }
  186. }else{
  187. return $this->outJson(0, [], '更新失败');
  188. }
  189. }
  190. /**
  191. * 获取入金配置
  192. * @return \yii\web\Response
  193. */
  194. public function actionGetDepositConfig()
  195. {
  196. $depositConfig = [];
  197. foreach (PayForm::$payNames as $payId => $payName) {
  198. $depositConfig[$payId] = [
  199. 'id' => $payId,
  200. 'label' => $payName,
  201. 'enable' => 0,
  202. ];
  203. }
  204. /** @var DepositConfig $model */
  205. $model = DepositConfig::find()->one();
  206. if ($model) {
  207. $configData = @json_decode($model->config_data, true);
  208. foreach ((array)$configData as $key => $row) {
  209. if (isset($depositConfig[$row['id']])) {
  210. $depositConfig[$row['id']]['enable'] = isset($row['enable']) && $row['enable'] == 1 ? 1 : 0;
  211. }
  212. }
  213. }
  214. return $this->outJson(1, $depositConfig, '操作成功');
  215. }
  216. /**
  217. * 设置入金配置
  218. * @return \yii\web\Response
  219. */
  220. public function actionSetDepositConfig()
  221. {
  222. $depositConfig = [];
  223. foreach (PayForm::$payNames as $payId => $payName) {
  224. $depositConfig[$payId] = [
  225. 'id' => $payId,
  226. 'label' => $payName,
  227. 'enable' => 0,
  228. ];
  229. }
  230. /** @var DepositConfig $model */
  231. $model = DepositConfig::find()->one();
  232. if ($model == null) {
  233. $model = new DepositConfig();
  234. }
  235. $configData = @json_decode($model->config_data, true);
  236. foreach ((array)$configData as $key => $row) {
  237. if (isset($depositConfig[$row['id']])) {
  238. $depositConfig[$row['id']]['enable'] = isset($row['enable']) && $row['enable'] == 1 ? 1 : 0;
  239. }
  240. }
  241. $config = trim(Yii::$app->getRequest()->post('config'));
  242. if ($config == '') {
  243. return $this->outJson(0, [], '参数非法' . __LINE__);
  244. }
  245. $configArr = @json_decode($config, true);
  246. if ($configArr == null) {
  247. return $this->outJson(0, [], '参数非法' . __LINE__);
  248. }
  249. foreach ($configArr as $key => $row) {
  250. if (!isset($row['id']) || !isset($depositConfig[$row['id']])) {
  251. continue;
  252. }
  253. $depositConfig[$row['id']]['enable'] = isset($row['enable']) && $row['enable'] == 1 ? 1 : 0;
  254. }
  255. $model->config_data = json_encode($depositConfig, 320);
  256. if ($model->save()) {
  257. return $this->outJson(1, [], '操作成功');
  258. } else {
  259. return $this->outJson(0, [], '操作失败');
  260. }
  261. }
  262. }