KeyController.php 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * Author: 芸众商城 www.yunzshop.com
  5. * Date: 2017/3/9
  6. * Time: 下午5:26
  7. */
  8. namespace app\backend\modules\setting\controllers;
  9. use app\common\components\BaseController;
  10. use app\common\facades\Setting;
  11. use app\common\models\Address;
  12. use app\common\models\Setting as SettingModel;
  13. use app\common\services\AutoUpdate;
  14. use Ixudra\Curl\Facades\Curl;
  15. class KeyController extends BaseController
  16. {
  17. public function preAction()
  18. {
  19. if (\YunShop::app()->role != 'founder') {
  20. return $this->message('非法访问', yzWebUrl('survey.survey.index') , 'warning');
  21. }
  22. $this->uniacid = \YunShop::app()->uniacid;
  23. $this->_log = app('log');
  24. }
  25. /**
  26. * 密钥填写
  27. * @return mixed
  28. */
  29. public function index()
  30. {
  31. $requestModel = request()->upgrade;
  32. $upgrade = Setting::get('shop.key');
  33. $page = 'auth';
  34. if (empty($upgrade['key']) && empty($upgrade['secret'])) {
  35. $domain = request()->getHttpHost();
  36. $url = config('auto-update.registerUrl') . '/check_domain.json';
  37. $auth_str = Curl::to($url)
  38. ->withData(['domain' => $domain])
  39. ->asJsonResponse(true)
  40. ->get();
  41. if (empty($auth_str['data']['key']) && empty($auth_str['data']['secret'])) {
  42. $page = 'free';
  43. } else {
  44. $upgrade = $auth_str['data'];
  45. $this->processingKey($upgrade, 'create');
  46. $free_plugins = SettingModel::where('group', 'free')->where('key', 'plugin')->first();
  47. if (!is_null($free_plugins)) {
  48. Setting::set('free.plugin', unserialize($free_plugins->value));
  49. }
  50. }
  51. }
  52. $auth_url = ''; //yzWebFullUrl('setting.key.index', ['page' => 'auth']);
  53. $free_url = ''; //yzWebFullUrl('setting.key.index', ['page' => 'free']);
  54. $type = request()->type;
  55. //$page = request()->page ?: 'register';
  56. $btn = empty($upgrade['key']) || empty($upgrade['secret']) ? 1 : 0;
  57. $message = $type == 'create' ? '添加' : '取消';
  58. if ($requestModel) {
  59. //检测数据是否存在
  60. $res = $this->isExist($requestModel);
  61. //var_dump($res);exit();
  62. if (!$res['isExists']) {
  63. if ($res['message'] == 'amount exceeded') {
  64. $this->errorJson('您已经没有剩余站点数量了,如添加新站点,请取消之前的站点或者联系我们的客服人员!');
  65. } else {
  66. $this->errorJson('Key或者密钥出错了!');
  67. }
  68. } else {
  69. if ($this->processingKey($requestModel, $type)) {
  70. return $this->successJson("站点{$message}成功", ['url' => $auth_url]);
  71. } else {
  72. $this->errorJson("站点{$message}失败");
  73. }
  74. }
  75. }
  76. $province = Address::getProvince();
  77. return view('setting.key.index', [
  78. 'province' => json_encode(['data' => $province->toArray()]),
  79. 'page' => json_encode(['type' => $page]),
  80. 'url' => json_encode(['free' => $free_url, 'auth' => $auth_url]),
  81. 'set' => json_encode(['key' => $upgrade['key'], 'secret' => $upgrade['secret'], 'btn' => $btn]),
  82. ])->render();
  83. }
  84. /*
  85. * 处理信息
  86. */
  87. private function processingKey($requestModel, $type)
  88. {
  89. $domain = request()->getHttpHost();
  90. $data = [
  91. 'uniacid' => $this->uniacid,
  92. 'key' => $requestModel['key'],
  93. 'secret' => $requestModel['secret'],
  94. 'domain' => $domain,
  95. ];
  96. if ($type == 'create') {
  97. $content = Curl::to(config('auto-update.checkUrl') . '/app-account/create')
  98. ->withData($data)
  99. ->get();
  100. // dd($content);exit();
  101. $writeRes = Setting::set('shop.key', $requestModel);
  102. \Cache::forget('app_auth' . $this->uniacid);
  103. return $writeRes && $content;
  104. } else if ($type == 'cancel') {
  105. $content = Curl::to(config('auto-update.checkUrl') . '/app-account/cancel')
  106. ->withData($data)
  107. ->get();
  108. //var_dump($content);exit();
  109. $writeRes = Setting::set('shop.key', '');
  110. \Cache::forget('app_auth' . $this->uniacid);
  111. return $writeRes && $content;
  112. }
  113. }
  114. /*
  115. * 检测是否有数据存在
  116. */
  117. public function isExist($data)
  118. {
  119. $type = request()->type;
  120. $domain = request()->getHttpHost();
  121. $filename = config('auto-update.checkUrl') . '/check_isKey.json';
  122. $postData = [
  123. 'type' => $type,
  124. 'domain' => $domain,
  125. ];
  126. $update = new AutoUpdate();
  127. $res = $update->isKeySecretExists($filename, $data, $postData, 'auto_update ' . $this->uniacid . ' ');
  128. return $res;
  129. }
  130. public function getCity()
  131. {
  132. $data = request()->data;
  133. $addressData = Address::getCityByParentId($data['id']);
  134. return $this->successJson('ok', $addressData);
  135. }
  136. public function getArea()
  137. {
  138. $data = request()->data;
  139. $addressData = Address::getAreaByParentId($data['id']);
  140. return $this->successJson('ok', $addressData);
  141. }
  142. public function register()
  143. {
  144. $data = request()->data;
  145. $auth_url = yzWebFullUrl('setting.key.index');
  146. $key = 'free';
  147. $secret = request()->getSchemeAndHttpHost();
  148. $url = config('auto-update.registerUrl') . "/free/{$data['name']}/{$data['trades']}/{$data['province']['areaname']}/{$data['city']['areaname']}/{$data['area']['areaname']}/{$data['address']}/{$data['mobile']}/{$data['captcha']}";
  149. $register = Curl::to($url)
  150. ->withHeader(
  151. "Authorization: Basic " . base64_encode("{$key}:{$secret}")
  152. )
  153. ->asJsonResponse(true)
  154. ->get();
  155. if (!is_null($register) && 1 == $register['result']) {
  156. if ($register['data']) {
  157. //检测数据是否存在
  158. $res = $this->isExist($register['data']['shop']);
  159. //var_dump($res);exit();
  160. if (!$res['isExists']) {
  161. if ($res['message'] == 'amount exceeded') {
  162. $this->errorJson('您已经没有剩余站点数量了,如添加新站点,请取消之前的站点或者联系我们的客服人员!');
  163. } else {
  164. $this->errorJson('Key或者密钥出错了!');
  165. }
  166. } else {
  167. if ($this->processingKey($register['data']['shop'], 'create')) {
  168. if ($register['data']['plugins']) {
  169. Setting::set('free.plugin', $register['data']['plugins']);
  170. }
  171. return $this->successJson("站点添加成功", ['url' => $auth_url]);
  172. }
  173. }
  174. }
  175. }
  176. return $this->errorJson("站点添加失败");
  177. }
  178. public function sendSms()
  179. {
  180. $key = 'free';
  181. $secret = request()->getHttpHost();
  182. $mobile = request()->mobile;
  183. $url = config('auto-update.registerUrl') . "/sendsms/{$mobile}";
  184. $res = Curl::to($url)
  185. ->withHeader(
  186. "Authorization: Basic " . base64_encode("{$key}:{$secret}")
  187. )
  188. ->asJsonResponse(true)
  189. ->get();
  190. return $this->successJson('验证码已发送', $res);
  191. }
  192. public function reset()
  193. {
  194. $data = request()->data;
  195. $setting = Setting::get('shop.key');
  196. if ($data['key'] && $data['secret']) {
  197. try {
  198. Setting::set('shop.key', $data);
  199. } catch (\Exception $e) {
  200. return $this->errorJson($e->getMessage());
  201. }
  202. }
  203. return $this->successJson('成功', $setting);
  204. }
  205. }