PromoteReportController.php 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Models\PrFeedback;
  5. use App\Http\Models\PrKeywordExtend;
  6. use App\Http\Models\PrLandPage;
  7. use App\Http\Models\PrLandPageScope;
  8. use App\Http\Models\PrModifyGather;
  9. use App\Http\Models\PrOptimizeData;
  10. use App\Http\Models\PrOptimizeDataScope;
  11. use App\Http\Models\PrOptimizeDataSummary;
  12. use App\Http\Models\PrPlan;
  13. use App\Http\Models\PrPlanScope;
  14. use App\Http\Models\PrSeoItem;
  15. use App\Http\Models\PrSeoItemScope;
  16. use App\Http\Models\PrSocial;
  17. use App\Http\Models\Role;
  18. use App\Http\Models\Site;
  19. use App\Imports\KeywordExtend;
  20. use Illuminate\Http\Request;
  21. use Illuminate\Support\Facades\DB;
  22. use Illuminate\Support\Facades\Log;
  23. use Maatwebsite\Excel\Facades\Excel;
  24. use Illuminate\Http\JsonResponse;
  25. /**
  26. * 项目管理下 项目概况下的 推广月报
  27. * Class PromoteReportController
  28. * @package App\Http\Controllers\Admin
  29. */
  30. class PromoteReportController extends Controller
  31. {
  32. //主页
  33. public function index($siteId)
  34. {
  35. $ym = date('Ym', strtotime('first day of -1 month'));
  36. $where = ['site_id' => $siteId, 'ym' => $ym];
  37. $optimizeDataList = PrOptimizeData::query()->where($where)->get();
  38. $landPageList = PrLandPage::query()->where(['site_id' => $siteId])->get();
  39. $socialList = PrSocial::query()->where($where)->get()->keyBy('type')->toArray();
  40. $threeMonth = [];
  41. for ($i = 1; $i <= 3; $i++) {
  42. $threeMonth[] = date('Ym', strtotime("first day of -$i month"));
  43. }
  44. $modifyGatherList = PrModifyGather::query()->where(['site_id' => $siteId])->get();
  45. $seoItemSingle = PrSeoItem::query()->where($where)->first();
  46. $plan = PrPlan::query()->where($where)->first();
  47. $feedbackList = PrFeedback::query()->where($where)->orderByDesc('ym')->get();
  48. $authUser = auth()->user();
  49. if ($authUser->is_super || in_array($authUser->role_id, [Role::TYPE_MANAGE_LEADER])) {
  50. $scope = true;
  51. }
  52. $oldId = Site::query()->where('id', $siteId)->value('old_id') ?? 0;
  53. $summary = PrOptimizeDataSummary::query()->where($where)->value('content') ?? '';
  54. $info = PrOptimizeDataScope::query()->first() ?? [];
  55. $mobile = DB::table('site_mobile')->where('site_id', $siteId)->value('mobile') ?? '';
  56. $webmasterAccount = 'Hina';
  57. $webmasterType = DB::connection('rank')->table('project')->where('id', $oldId)->value('webmaster_type');
  58. if (!empty($webmasterType)) {
  59. if ($webmasterType == 2) {
  60. $webmasterAccount = 'Tommy Ru';
  61. } else {
  62. $webmasterAccount = '';
  63. }
  64. }
  65. return view('admin.promote_report.index', [
  66. 'webmasterAccount' => $webmasterAccount,
  67. 'mobile' => $mobile,
  68. 'oldId' => $oldId,
  69. 'siteId' => $siteId,
  70. 'optimizeDataList' => $optimizeDataList,
  71. 'optimizeDataScopeList1' => json_decode($info->content_one, true) ?? [],
  72. 'optimizeDataScopeList2' => json_decode($info->content_two, true) ?? [],
  73. 'optimizeDataScopeList3' => json_decode($info->content_three, true) ?? [],
  74. 'optimizeDataScopeList4' => json_decode($info->content_four, true) ?? [],
  75. 'landPageList' => $landPageList,
  76. 'landPageScopeList' => PrLandPageScope::query()->get(),
  77. 'threeMonth' => $threeMonth,
  78. 'socialList' => $socialList,
  79. 'modifyGatherList' => $modifyGatherList,
  80. 'seoItemSingle' => $seoItemSingle,
  81. 'seoItemScopeList' => PrSeoItemScope::query()->get(),
  82. 'plan' => $plan,
  83. 'planScopeList' => PrPlanScope::query()->get(),
  84. 'feedbackList' => $feedbackList,
  85. 'scope' => $scope ?? false,
  86. 'summary' => $summary
  87. ]);
  88. }
  89. //保存优化师数据分析
  90. public function saveOptimizeData(Request $request, $siteId)
  91. {
  92. $ym = date('Ym', strtotime('first day of -1 month'));
  93. $site = Site::query()->select(['old_id'])->find($siteId);
  94. if (!$site) {
  95. return response()->json(['message' => '站点不存在'], 400);
  96. }
  97. $dataList = $request->input('dataList') ?? [];
  98. PrOptimizeData::query()->where(['site_id' => $siteId, 'ym' => $ym])->delete();
  99. $insertData = [];
  100. $datetime = date('Y-m-d H:i:s');
  101. foreach ($dataList as $value) {
  102. $insertData[] = [
  103. 'ym' => $ym,
  104. 'site_id' => $siteId,
  105. 'old_id' => $site->old_id,
  106. 'content' => $value,
  107. 'created_at' => $datetime,
  108. 'updated_at' => $datetime
  109. ];
  110. }
  111. if ($dataList) {
  112. PrOptimizeData::query()->insert($insertData);
  113. }
  114. return response()->json(['message' => '操作成功']);
  115. }
  116. //保存优化师数据总结
  117. public function saveOptimizeDataSummary(Request $request, $siteId)
  118. {
  119. $ym = date('Ym', strtotime('first day of -1 month'));
  120. $site = Site::query()->select(['old_id'])->find($siteId);
  121. if (!$site) {
  122. return response()->json(['message' => '站点不存在'], 400);
  123. }
  124. $summary = $request->input('summary') ?? '';
  125. PrOptimizeDataSummary::query()->where(['site_id' => $siteId, 'ym' => $ym])->delete();
  126. $datetime = date('Y-m-d H:i:s');
  127. $insertData = [
  128. 'ym' => $ym,
  129. 'site_id' => $siteId,
  130. 'old_id' => $site->old_id,
  131. 'content' => $summary,
  132. 'created_at' => $datetime,
  133. 'updated_at' => $datetime
  134. ];
  135. PrOptimizeDataSummary::query()->insert($insertData);
  136. return response()->json(['message' => '操作成功']);
  137. }
  138. //保存优化师数据分析固定话语
  139. public function saveOptimizeDataScope(Request $request)
  140. {
  141. $dataList1 = $request->input('dataList1') ?? [];
  142. $dataList2 = $request->input('dataList2') ?? [];
  143. $dataList3 = $request->input('dataList3') ?? [];
  144. $dataList4 = $request->input('dataList4') ?? [];
  145. $datetime = date('Y-m-d H:i:s');
  146. $insertData = [
  147. 'created_at' => $datetime,
  148. 'updated_at' => $datetime
  149. ];
  150. if (!empty($dataList1)) {
  151. $insertData['content_one'] = \GuzzleHttp\json_encode($dataList1);
  152. }
  153. if (!empty($dataList2)) {
  154. $insertData['content_two'] = \GuzzleHttp\json_encode($dataList2);
  155. }
  156. if (!empty($dataList3)) {
  157. $insertData['content_three'] = \GuzzleHttp\json_encode($dataList3);
  158. }
  159. if (!empty($dataList4)) {
  160. $insertData['content_four'] = \GuzzleHttp\json_encode($dataList4);
  161. }
  162. PrOptimizeDataScope::query()->delete();
  163. PrOptimizeDataScope::query()->insert($insertData);
  164. return response()->json(['message' => '操作成功']);
  165. }
  166. //着陆页清空
  167. public function clearLandPage($siteId)
  168. {
  169. PrLandPage::query()->where(['site_id' => $siteId])->delete();
  170. return response()->json(['message' => '操作成功']);
  171. }
  172. //着陆页保存
  173. public function saveLandPage(Request $request, $siteId)
  174. {
  175. $site = Site::query()->select(['old_id'])->find($siteId);
  176. if (!$site) {
  177. return response()->json(['message' => '站点不存在'], 400);
  178. }
  179. $dataList = $request->input('dataList') ?? [];
  180. $scopeIds = PrLandPage::query()->where(['site_id' => $siteId])->pluck('id')->toArray();
  181. $requestIds = array_column($dataList, 'id');
  182. $delIds = array_diff($scopeIds, $requestIds);
  183. if ($delIds) {
  184. PrLandPage::destroy($delIds);
  185. }
  186. $datetime = date('Y-m-d H:i:s');
  187. foreach ($dataList as $item) {
  188. if (empty($item['id'])) {
  189. PrLandPage::query()->create([
  190. 'site_id' => $siteId,
  191. 'old_id' => $site->old_id,
  192. 'content' => $item['content'],
  193. 'sub_list' => ($item['subList'] ?? []),
  194. 'created_at' => $datetime,
  195. 'updated_at' => $datetime
  196. ]);
  197. } else {
  198. PrLandPage::query()->where(['id' => $item['id']])
  199. ->update([
  200. 'content' => $item['content'],
  201. 'sub_list' => json_encode(($item['subList'] ?? []))
  202. ]);
  203. }
  204. }
  205. return response()->json(['message' => '操作成功', 'data' => PrLandPage::query()->where(['site_id' => $siteId])->get()]);
  206. }
  207. //社交推广保存
  208. public function saveSocial(Request $request, $siteId)
  209. {
  210. $site = Site::query()->select(['old_id', 'id'])->find($siteId);
  211. if (!$site) {
  212. return response()->json(['message' => '站点不存在'], 400);
  213. }
  214. $facebook = $request->input('facebook');
  215. $linkedIn = $request->input('linkedIn');
  216. $twitter = $request->input('twitter');
  217. $pin = $request->input('pin');
  218. $ins = $request->input('ins');
  219. $youtube = $request->input('youtube');
  220. $facebookHide = $request->input('facebookHide');
  221. $linkedInHide = $request->input('linkedInHide');
  222. $twitterHide = $request->input('twitterHide');
  223. $pinHide = $request->input('pinHide');
  224. $insHide = $request->input('insHide');
  225. $youtubeHide = $request->input('youtubeHide');
  226. $ym = date('Ym', strtotime('first day of -1 month'));
  227. $dataList = [
  228. [
  229. 'type' => 'facebook',
  230. 'data' => [
  231. 'data_list' => $facebook,
  232. 'hide' => $facebookHide
  233. ]
  234. ],
  235. [
  236. 'type' => 'linkedIn',
  237. 'data' => [
  238. 'data_list' => $linkedIn,
  239. 'hide' => $linkedInHide
  240. ]
  241. ],
  242. [
  243. 'type' => 'twitter',
  244. 'data' => [
  245. 'data_list' => $twitter,
  246. 'hide' => $twitterHide
  247. ]
  248. ],
  249. [
  250. 'type' => 'pin',
  251. 'data' => [
  252. 'data_list' => $pin,
  253. 'hide' => $pinHide
  254. ]
  255. ],
  256. [
  257. 'type' => 'ins',
  258. 'data' => [
  259. 'data_list' => $ins,
  260. 'hide' => $insHide
  261. ]
  262. ],
  263. [
  264. 'type' => 'youtube',
  265. 'data' => [
  266. 'data_list' => $youtube,
  267. 'hide' => $youtubeHide,
  268. ]
  269. ],
  270. ];
  271. foreach ($dataList as $item) {
  272. if (PrSocial::query()->where(['site_id' => $siteId, 'ym' => $ym])->where(['type' => $item['type']])->exists()) {
  273. PrSocial::query()->where(['site_id' => $siteId, 'ym' => $ym])->where(['type' => $item['type']])->update([
  274. 'data_list' => json_encode($item['data']['data_list']),
  275. 'hide' => $item['data']['hide'],
  276. ]);
  277. } else {
  278. PrSocial::query()->create([
  279. 'ym' => $ym,
  280. 'type' => $item['type'],
  281. 'site_id' => $siteId,
  282. 'old_id' => $site->old_id,
  283. 'data_list' => $item['data']['data_list'],
  284. 'hide' => $item['data']['hide']
  285. ]);
  286. }
  287. }
  288. $this->saveNextSocial($site, $dataList);
  289. return response()->json(['message' => '操作成功']);
  290. }
  291. //提前保存下个月的
  292. private function saveNextSocial($site, $dataList)
  293. {
  294. $ym = date('Ym');
  295. foreach ($dataList as $item) {
  296. $data = PrSocial::query()->where(['site_id' => $site->id, 'ym' => $ym, 'type' => $item['type']])->first();
  297. $item['data']['data_list'][0] = null;
  298. if ($data) {
  299. $data->data_list = $item['data']['data_list'];
  300. $data->hide = $item['data']['hide'];
  301. $data->save();
  302. } else {
  303. PrSocial::query()->create([
  304. 'ym' => $ym,
  305. 'type' => $item['type'],
  306. 'site_id' => $site->id,
  307. 'old_id' => $site->old_id,
  308. 'data_list' => $item['data']['data_list'],
  309. 'hide' => $item['data']['hide']
  310. ]);
  311. }
  312. }
  313. }
  314. //清空修改汇总
  315. public function clearModifyGather($siteId)
  316. {
  317. PrModifyGather::query()->where(['site_id' => $siteId])->delete();
  318. return response()->json(['message' => '操作成功']);
  319. }
  320. //修改汇总保存
  321. public function saveModifyGather(Request $request, $siteId)
  322. {
  323. $site = Site::query()->select(['old_id'])->find($siteId);
  324. if (!$site) {
  325. return response()->json(['message' => '站点不存在'], 400);
  326. }
  327. $dataList = $request->input('dataList') ?? [];
  328. $scopeIds = PrModifyGather::query()->where(['site_id' => $siteId])->pluck('id')->toArray();
  329. $requestIds = array_column($dataList, 'id');
  330. $delIds = array_diff($scopeIds, $requestIds);
  331. if ($delIds) {
  332. PrModifyGather::destroy($delIds);
  333. }
  334. $datetime = date('Y-m-d H:i:s');
  335. foreach ($dataList as $item) {
  336. if (empty($item['id'])) {
  337. PrModifyGather::query()->create([
  338. 'site_id' => $siteId,
  339. 'old_id' => $site->old_id,
  340. 'content' => $item['content'],
  341. 'modify_date' => $item['modify_date'] ?? null,
  342. 'created_at' => $datetime,
  343. 'updated_at' => $datetime
  344. ]);
  345. } else {
  346. PrModifyGather::query()->where(['id' => $item['id']])
  347. ->update([
  348. 'content' => $item['content'],
  349. 'modify_date' => $item['modify_date'] ?? null
  350. ]);
  351. }
  352. }
  353. return response()->json(['message' => '操作成功', 'data' => PrModifyGather::query()->where(['site_id' => $siteId])->get()]);
  354. }
  355. //获取seo
  356. public function getSeoItemScope()
  357. {
  358. $result = PrSeoItemScope::query()->get();
  359. return response()->json(['data' => $result]);
  360. }
  361. //保存Seo
  362. public function saveSeoItem(Request $request, $siteId)
  363. {
  364. $site = Site::query()->select(['old_id', 'id'])->find($siteId);
  365. if (!$site) {
  366. return response()->json(['message' => '站点不存在'], 400);
  367. }
  368. $ym = date('Ym', strtotime('first day of -1 month'));
  369. $checked_list = $request->input('checked_list') ?? [];
  370. $data = PrSeoItem::query()->where(['site_id' => $siteId, 'ym' => $ym])->first();
  371. if ($data) {
  372. $data->checked_list = $checked_list;
  373. $data->save();
  374. } else {
  375. PrSeoItem::query()->create([
  376. 'ym' => $ym,
  377. 'site_id' => $siteId,
  378. 'old_id' => $site->old_id,
  379. 'checked_list' => $checked_list
  380. ]);
  381. }
  382. $this->saveNextSeoItem($site, $checked_list);
  383. return response()->json(['message' => '操作成功']);
  384. }
  385. //提前保存下个月的
  386. private function saveNextSeoItem($site, $checked_list)
  387. {
  388. $ym = date('Ym');
  389. $data = PrSeoItem::query()->where(['site_id' => $site->id, 'ym' => $ym])->first();
  390. if ($data) {
  391. $data->checked_list = $checked_list;
  392. $data->save();
  393. } else {
  394. PrSeoItem::query()->create([
  395. 'ym' => $ym,
  396. 'site_id' => $site->id,
  397. 'old_id' => $site->old_id,
  398. 'checked_list' => $checked_list
  399. ]);
  400. }
  401. }
  402. //seo固定选项保存
  403. public function saveSeoItemScope(Request $request)
  404. {
  405. $dataList = $request->input('dataList') ?? [];
  406. $insertData = [];
  407. $datetime = date('Y-m-d H:i:s');
  408. $idMapList = PrSeoItemScope::query()->get();
  409. $seoItemIds = array_filter(array_column($dataList, 'seoItemId'));
  410. foreach ($idMapList as $item) {
  411. if (!in_array($item->id, $seoItemIds)) {
  412. $item->delete();
  413. }
  414. foreach ($dataList as $v) {
  415. if ($v['seoItemId'] == $item->id && $v['content'] != $item->content) {
  416. $item->update(['content' => $v['content']]);
  417. }
  418. }
  419. }
  420. foreach ($dataList as $value) {
  421. if (empty($value['seoItemId'])) {
  422. $insertData[] = [
  423. 'content' => $value['content'],
  424. 'created_at' => $datetime,
  425. 'updated_at' => $datetime
  426. ];
  427. }
  428. }
  429. if ($dataList) {
  430. PrSeoItemScope::query()->insert($insertData);
  431. }
  432. return response()->json(['message' => '操作成功']);
  433. }
  434. // public function savePlanBak(Request $request, $siteId)
  435. // {
  436. // $site = Site::query()->select(['old_id'])->find($siteId);
  437. // if (!$site) {
  438. // return response()->json(['message' => '站点不存在'], 400);
  439. // }
  440. // $dataList = $request->input('dataList') ?? [];
  441. //
  442. // $ym = date('Ym', strtotime('first day of -1 month'));
  443. //
  444. //
  445. // PrPlan::query()->where(['site_id' => $siteId, 'ym' => $ym])->delete();
  446. //
  447. //
  448. // $insertData = [];
  449. // $datetime = date('Y-m-d H:i:s');
  450. // foreach ($dataList as $value) {
  451. // $insertData[] = [
  452. // 'ym' => $ym,
  453. // 'site_id' => $siteId,
  454. // 'old_id' => $site->old_id,
  455. // 'content' => $value['content'],
  456. // 'created_at' => $datetime,
  457. // 'updated_at' => $datetime
  458. // ];
  459. // }
  460. // if ($dataList) {
  461. // PrPlan::query()->insert($insertData);
  462. // }
  463. // return response()->json(['message' => '操作成功']);
  464. // }
  465. //工作规划保存
  466. public function savePlan(Request $request, $siteId)
  467. {
  468. $site = Site::query()->select(['old_id'])->find($siteId);
  469. if (!$site) {
  470. return response()->json(['message' => '站点不存在'], 400);
  471. }
  472. $dataList = $request->input('dataList') ?? [];
  473. $ym = date('Ym', strtotime('first day of -1 month'));
  474. $plan = PrPlan::query()->where(['site_id' => $siteId, 'ym' => $ym])->first();
  475. if (!$plan) {
  476. PrPlan::query()->create([
  477. 'ym' => $ym,
  478. 'site_id' => $siteId,
  479. 'old_id' => $site->old_id,
  480. 'content_list' => $dataList,
  481. 'file_name' => $request->input('file_name') ?? '',
  482. 'file_path' => $request->input('file_path') ?? '',
  483. ]);
  484. } else {
  485. $plan->update([
  486. 'content_list' => $dataList,
  487. 'file_name' => $request->input('file_name') ?? '',
  488. 'file_path' => $request->input('file_path') ?? '',
  489. ]);
  490. }
  491. return response()->json(['message' => '操作成功']);
  492. }
  493. //工作规划固定话语保存
  494. public function savePlanScope(Request $request)
  495. {
  496. $dataList = $request->input('dataList') ?? [];
  497. PrPlanScope::query()->delete();
  498. $insertData = [];
  499. $datetime = date('Y-m-d H:i:s');
  500. foreach ($dataList as $value) {
  501. $insertData[] = [
  502. 'content' => $value,
  503. 'created_at' => $datetime,
  504. 'updated_at' => $datetime
  505. ];
  506. }
  507. if ($dataList) {
  508. PrPlanScope::query()->insert($insertData);
  509. }
  510. return response()->json(['message' => '操作成功']);
  511. }
  512. //关键词拓展
  513. public function keywordExtend(Request $request, $siteId)
  514. {
  515. if (!$request->ajax()) {
  516. return view('admin.promote_report.keyword_extend', [
  517. 'siteId' => $siteId,
  518. ]);
  519. }
  520. $result = PrKeywordExtend::query()->where(['site_id' => $siteId])->orderByDesc('id')->paginate($request->input('pageSize') ?? TABLE_PAGE_SIZE);
  521. $items = $result->items();
  522. return response()->json([
  523. 'rows' => $items,
  524. 'total' => $result->total()
  525. ]);
  526. }
  527. //导入关键词
  528. public function importKeyword(Request $request)
  529. {
  530. set_time_limit(0);
  531. $siteId = $request->input('siteId');
  532. if (!$request->input('excel_path') || !$siteId) {
  533. return response()->json(['message' => '请先上传excel文件'], 422);
  534. }
  535. $site = Site::query()->where(['id' => $siteId])->first();
  536. if (empty($site->old_id)) {
  537. return response()->json(['message' => '老站点信息不存在'], 400);
  538. }
  539. try {
  540. Excel::import(new KeywordExtend($siteId, $site->old_id), $request->input('excel_path'), 'public');
  541. } catch (\Throwable $throwable) {
  542. Log::error(var_export($throwable->getMessage(), 1));
  543. return response()->json(['message' => '导入失败'], 400);
  544. }
  545. return response()->json(['message' => '操作成功']);
  546. }
  547. //清空关键词
  548. public function clearKeyword($siteId)
  549. {
  550. $ym = date('Ym');
  551. PrKeywordExtend::query()->where(['site_id' => $siteId, 'ym' => $ym])->delete();
  552. return response()->json(['message' => '操作成功']);
  553. }
  554. /**
  555. * 删除关键词
  556. * @param Request $request
  557. * @param $siteId
  558. * @return JsonResponse
  559. */
  560. public function deleteKeyword(Request $request, $siteId)
  561. {
  562. $ids = $request->input('ids');
  563. $keywordList = PrKeywordExtend::query()
  564. ->where('site_id', $siteId)
  565. ->whereIn('id', $ids)
  566. ->pluck('keyword');
  567. $projectId = Site::query()->where('id', $siteId)->value('old_id');
  568. try {
  569. //事务
  570. DB::transaction(function () use ($siteId, $ids, $keywordList, $projectId) {
  571. PrKeywordExtend::query()
  572. ->where('site_id', $siteId)
  573. ->whereIn('id', $ids)
  574. ->delete();
  575. DB::connection('rank')
  576. ->table('project_keyword')
  577. ->where('project_id', $projectId)
  578. ->whereIn('keyword', $keywordList)
  579. ->delete();
  580. });
  581. } catch (\Throwable $exception) {
  582. return response()->json(['message' => $exception->getMessage()], 400);
  583. }
  584. return response()->json(['message' => '操作成功']);
  585. }
  586. }