'GET', 'recycle' => 'GET', 'add' => 'POST', 'move' => 'POST', 'delete' => 'POST', ]; /** * 商城列表 * @return Json * @throws \think\db\exception\DbException */ public function index(): Json { // 商城列表 $model = new StoreModel; $list = $model->getList(); if (!$list->isEmpty()) { $list = $list->toArray(); foreach ($list['data'] as &$value) { $value['store_version'] = $value['store_version'] == 0 ? "单商户" : "多商户"; } } return $this->renderSuccess(compact('list')); } /** * 获取商城登录token * @param int $storeId * @return Json */ public function superLogin(int $storeId): Json { // 获取指定商城的管理员用户信息 $userInfo = StoreUserService::getUserInfoByStoreId($storeId); if (empty($userInfo)) { return $this->renderError('未找到该商城管理员用户'); } // 登录商户后台 $token = StoreUserService::login($userInfo->toArray()); return $this->renderSuccess([ 'userId' => $userInfo['store_user_id'], 'token' => $token ]); } /** * 回收站列表 * @return Json * @throws \think\db\exception\DbException */ public function recycle(): Json { // 商城列表 $model = new StoreModel; $list = $model->getList(true); return $this->renderSuccess(compact('list')); } /** * 新增商城 * @return Json */ public function add(): Json { // 新增记录 $model = new StoreModel; if ($model->add($this->postForm())) { return $this->renderSuccess('添加成功'); } return $this->renderError($model->getError() ?: '添加失败'); } /** * 更新商城信息 * @return Json */ public function edit(int $storeId): Json { $params = $this->postForm(); // 商城详情 $model = StoreModel::detail($storeId); // 更新记录 if (!$model->edit($params)) { return $this->renderError($model->getError() ?: '更新失败'); } return $this->renderSuccess('更新成功'); } /** * 移入回收站 * @param int $storeId * @return Json */ public function recovery(int $storeId): Json { // 商城详情 $model = StoreModel::detail($storeId); if (!$model->recycle()) { return $this->renderError($model->getError() ?: '操作失败'); } return $this->renderSuccess('操作成功'); } /** * 移出回收站 * @param int $storeId * @return Json */ public function move(int $storeId): Json { // 商城详情 $model = StoreModel::detail($storeId); if (!$model->recycle(false)) { return $this->renderError($model->getError() ?: '操作失败'); } return $this->renderSuccess('操作成功'); } /** * 删除商城 * @param int $storeId * @return Json */ public function delete(int $storeId): Json { // 商城详情 $model = StoreModel::detail($storeId); if (!$model->setDelete()) { return $this->renderError($model->getError() ?: '操作失败'); } return $this->renderSuccess('操作成功'); } /** * 审核商城 * @param int $storeId * @return Json */ public function audit(int $storeId): Json { // 商城详情 $model = StoreModel::detail($storeId); if (!$model->auditStore($this->request->param())) { return $this->renderError($model->getError() ?: '操作失败'); } return $this->renderSuccess('操作成功'); } /** * 审核商城 * @param int $storeId * @return Json */ public function platformList(): Json { $list = $this->getUserPlatform(); $platformList = []; foreach ($list as $key => $value) { $platformList[$value['code']] = $value['name']; } //$platformList = config('app.platformList'); return $this->renderSuccess($platformList); } /** * 审核商城 * @param int $storeId * @return Json */ public function getStorePlatform(int $storeId): Json { $list = SyncTask::where("store_id", $storeId)->order('create_time desc')->select()->toArray(); return $this->renderSuccess($list); } /** * 审核商城 * @param int $storeId * @return Json */ public function auth(int $storeId): Json { $platformList = $this->request->param('platformList'); //多商户新增一个商户用户 $model = StoreModel::detail($storeId); $storeUserModel = new StoreUserModel; if ($model->store_version == 1) { if ($platformList) { foreach ($platformList as $value) { $channel = Channel::where('code', $value)->where('status',1)->find(); if ($channel->isEmpty()) { return $this->renderError('当前渠道不存在'); } $user_name = $channel->alias.$storeId; //当前账号是否创建 $merchant = Merchant::where('channel_id', $channel->id)->where('store_id', $storeId)->where('is_delete', 0)->find(); if ($merchant) { continue; } //创建账号 //查出当前店铺的商户角色的id $whererole = [ 'store_id' => $storeId, 'role_name' => "商户" ]; $role = role::detail($whererole); if (!$role) { return $this->renderError('当前多商户商城商户角色不存在'); } $params = [ "real_name" => $channel->name, "user_name" => $user_name, "roles" => [$role->role_id], "password" => "123456", "password_confirm" => "123456", "sort" => 100, 'storeId' => $storeId, ]; // var_dump($params); // exit(); $storeUserModel->addNew($params); //复制商户 $merchantData = [ "shop_name" => $channel->shop_name, "shop_label" => $channel->shop_label, "channel_id" => $channel->id, "channel" => $channel->code, "store_id" => $storeId, "user_name" => $user_name, "score" => 5, "sale" => 100, "sort" => 100, "license_img_id" => "", "logo_image_id" => 0, "create_time" => time(), ]; // var_dump($merchantData); // exit(); if ($channel->logo_image_id) { //复制图片 $upload_file = Db::name('upload_file')->where('file_id', $channel->logo_image_id)->find(); if ($upload_file) { $upload_file['store_id'] = $storeId; $upload_file['create_time'] = time(); unset($upload_file['file_id']); $logo_image_id = Db::name('upload_file')->insertGetId($upload_file); $merchantData['logo_image_id'] = $logo_image_id; } } if ($channel->license_img_id) { $arr = explode(",", $channel->license_img_id); $license_img_ids = []; foreach ($arr as $key => $val) { //复制图片 $upload_file = Db::name('upload_file')->where('file_id', $val)->find(); if ($upload_file) { $upload_file['store_id'] = $storeId; $upload_file['create_time'] = time(); unset($upload_file['file_id']); $license_img_id = Db::name('upload_file')->insertGetId($upload_file); $license_img_ids[] = $license_img_id; } } $merchantData['license_img_id'] = implode(",", $license_img_ids); } Merchant::create($merchantData); } } } // var_dump($model->store_version); // exit(); $currItems = SyncTask::where('store_id', $storeId)->select()->toArray(); if ($currItems) { $delIds = []; foreach ($currItems as $item) { if (!in_array($item['channel'], $platformList)) { $delIds[] = $item['id']; } } unset($item); //删除 if ($delIds) { SyncTask::whereIn('id', $delIds)->delete(); } } $curr_channels = array_column($currItems, "channel"); $inData = []; foreach ($platformList as $platform) { if (in_array($platform, $curr_channels)) { continue; } $merchantId = 0; if ($model->store_version == 1) { $merchant = Merchant::where('channel', $platform)->where('store_id', $storeId)->find(); $merchantId = $merchant->merchant_id; } $inData[] = [ 'store_id' => $storeId, 'channel' => $platform, 'create_time' => time(), 'merchant_id' => $merchantId, ]; } if ($inData) { $model = new SyncTask; $model->addAll($inData); } return $this->renderSuccess('操作成功'); } /** * 多商户初始化 * [merchant description] * @param int $storeId [description] * @return [type] [description] */ public function merchant(int $storeId): Json { $model = StoreModel::detail($storeId); if ($model->store_version == 1) { $model->addMerchantRoleAndMenu((int)$storeId); } return $this->renderSuccess(); } /** * 删除商城的商品和商品分类 * [merchant description] * @param int $storeId [description] * @return [type] [description] */ public function deleteGoods(int $storeId): Json { ini_set('memory_limit', '1024M'); set_time_limit(0); $model = StoreModel::detail($storeId); if (!$model || $storeId <= 0) { return $this->renderError('商城不存在'); } //删除分类 Category::where('store_id', $storeId)->delete(); // GoodsSku::where('store_id', $storeId)->delete(); // GoodsImage::where('store_id', $storeId)->delete(); // GoodsSpecRel::where('store_id', $storeId)->delete(); // GoodsModel::where('store_id', $storeId)->delete(); $page = 1; while (TRUE) { //echo $page.PHP_EOL; $goods_list = GoodsModel::where('store_id', $storeId) ->where('channel','<>', 'zy') ->field('goods_id') ->order("goods_id desc") ->page($page) ->limit(2000) ->select(); if ($goods_list->isEmpty()) { break; } $goods_ids = array_column($goods_list->toArray(), "goods_id"); // 分批每次导入20条 $limit = 200; // 根据商品总数量计算需要的队列任务数量 $jobCount = \count($goods_ids) / $limit; // 逐次发布队列任务 for ($i = 0; $i < $jobCount; $i++) { $data = array_slice($goods_ids, $i * $limit, $limit); GoodsRealDeleteJob::dispatch([ 'list' => $data, ]); } //删除商品sku GoodsSku::whereIn('goods_id', $goods_ids)->delete(); //删除商品图片 GoodsImage::whereIn('goods_id', $goods_ids)->delete(); //删除商品规格 GoodsSpecRel::whereIn('goods_id', $goods_ids)->delete(); $page++; } //删除商品 GoodsModel::where('store_id', $storeId)->where('channel','<>', 'zy')->delete(); return $this->renderSuccess(); } }