SecurityCodeController.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\api\controller\v1\user;
  12. use app\Request;
  13. use app\services\user\member\SecurityCodeRecordServices;
  14. use app\services\user\member\SecurityCategoryServices;
  15. use crmeb\exceptions\AuthException;
  16. /**
  17. * 用户收藏
  18. * Class UserCollectController
  19. * @package app\api\controller\v1\user
  20. */
  21. class SecurityCodeController
  22. {
  23. protected $services = NUll;
  24. /**
  25. * UserCollectController constructor.
  26. * @param StoreProductRelationServices $services
  27. */
  28. public function __construct(SecurityCodeRecordServices $services)
  29. {
  30. $this->services = $services;
  31. }
  32. /**
  33. * 通过微信地址查询
  34. * @param Request $request
  35. * @return mixed
  36. */
  37. public function checkSecurityCode(Request $request)
  38. {
  39. $data = $request->getMore([
  40. ['wx_url', ''],
  41. ]);
  42. if(!$data['wx_url']){
  43. return app('json')->fail(600000);
  44. }
  45. if (mb_strlen($data['wx_url']) < 12) {
  46. $data['security_code'] = $data['wx_url'];
  47. $data['wx_url'] = '';
  48. }
  49. $res = $this->services->getOneByUrl($data);
  50. if (!$res) {
  51. return app('json')->fail(600001);
  52. } else {
  53. $categoryServices = app()->make(\app\services\user\member\SecurityCategoryServices::class);
  54. $cateInfo = $categoryServices->getOne(['id' => $res['category_id']]);
  55. $res['point'] = $cateInfo['point'];
  56. $res['cateName'] = $cateInfo['name'];
  57. return app('json')->success([$res]);
  58. }
  59. }
  60. /**
  61. * 领取扫码积分
  62. * @param Request $request
  63. * @return mixed
  64. */
  65. public function receiveSecurityCodePoint(Request $request)
  66. {
  67. $data = $request->getMore([
  68. ['id', ''],
  69. ]);
  70. if(!$data['id']){
  71. return app('json')->fail(600000);
  72. }
  73. $uid = (int)$request->uid();
  74. if($uid<=0){
  75. throw new AuthException(110002);
  76. }
  77. $integral = $this->services->receiveSecurityCodePoint($uid, $data);
  78. return app('json')->success(410127, ['integral' => $integral], ['integral' => $integral]);
  79. }
  80. /**
  81. * 领取扫码积分
  82. * @param Request $request
  83. * @return mixed
  84. */
  85. public function receiveSecurityCodeIndex()
  86. {
  87. return app('json')->success([
  88. 'image' => sys_config('code_image_url'),
  89. 'desc' => sys_config('code_rule_desc')
  90. ]);
  91. }
  92. }