AdService.php 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423
  1. <?php
  2. namespace App\JsonRpc;
  3. use App\Model\Ad;
  4. use App\Model\AdPlace;
  5. use App\Model\AdSize;
  6. use Hyperf\RpcServer\Annotation\RpcService;
  7. use App\Tools\Result;
  8. use Hyperf\DbConnection\Db;
  9. use App\Model\WebsiteTemplate;
  10. #[RpcService(name: "AdService", protocol: "jsonrpc-http", server: "jsonrpc-http")]
  11. class AdService implements AdServiceInterface
  12. {
  13. /**
  14. * @param array $data
  15. * @return string
  16. */
  17. public function createAd(array $data): array
  18. {
  19. $insertData = [
  20. 'name'=>$data['name']??'',
  21. 'pid'=>$data['pid']??0,
  22. 'areaid'=>$data['areaid']??0,
  23. 'amount'=>$data['amount']??0,//浏览数量
  24. 'introduce'=>$data['introduce']??'',
  25. 'hits'=>$data['hits']??0, //点击数量
  26. 'fromtime'=>$data['f_t_date'][0]??0,
  27. 'totime'=>$data['f_t_date'][1]??0,
  28. 'text_name'=>$data['text_name']??'',
  29. 'text_url'=>$data['text_url']??'',
  30. 'text_title'=>$data['text_title']??'',
  31. 'image_src'=>$data['image_src']??'',
  32. 'image_url'=>$data['image_url']??'',
  33. 'image_alt'=>$data['image_alt']??'',
  34. 'video_src'=>$data['video_src']??'',//视频
  35. 'video_url'=>$data['video_url']??'',
  36. 'video_auto'=>$data['video_auto'] ??0,
  37. 'video_loop'=>$data['video_loop'] ??0,
  38. 'status'=>$data['status']??2,
  39. 'remark'=>$data['remark']??'',
  40. ];
  41. $result = Ad::query()->insertGetId($insertData);
  42. if($result){
  43. return Result::success();
  44. }else{
  45. return Result::error("创建广告失败",500);
  46. }
  47. }
  48. /**
  49. * @param int $id
  50. * @return array
  51. */
  52. public function getAdInfo(int $id): array
  53. {
  54. $adInfo = Ad::query()->find($id);
  55. if (empty($adInfo)) {
  56. return Result::error("没有数据",0);
  57. }
  58. return Result::success($adInfo->toArray());
  59. }
  60. /**
  61. * @param array $data
  62. * @return array
  63. */
  64. public function getAdList(array $data): array
  65. {
  66. if(isset($data['pid'])){
  67. $where[] = ['ad.pid','=',$data['pid']];
  68. }
  69. $rep = Ad::where($where)
  70. ->leftJoin("ad_place","ad.pid","ad_place.id")
  71. ->leftJoin("website","website.id","ad_place.website_id")
  72. ->select("ad.*","ad_place.name as place_name","ad_place.typeid","website.website_name")
  73. ->limit($data['pageSize'])->orderBy("ad.id","desc")->offset(($data['page']-1)*$data['pageSize'])->get();
  74. $count = Ad::where($where)
  75. ->leftJoin("ad_place","ad.pid","ad_place.id")
  76. ->leftJoin("website","website.id","ad_place.website_id")
  77. ->count();
  78. $data = [
  79. 'rows'=>$rep->toArray(),
  80. 'count'=>$count
  81. ];
  82. if(empty($rep->toArray())){
  83. return Result::error("没有数据");
  84. }
  85. return Result::success($data);
  86. }
  87. public function updateAd(array $data): array
  88. {
  89. $where = [
  90. 'id'=>$data['id']
  91. ];
  92. $insertData = [
  93. 'name'=>$data['name']??'',
  94. 'pid'=>$data['pid']??0,
  95. 'areaid'=>$data['areaid']??0,
  96. 'amount'=>$data['amount']??0,//浏览数量
  97. 'introduce'=>$data['introduce']??'',
  98. 'hits'=>$data['hits']??0, //点击数量
  99. 'fromtime'=>$data['f_t_date'][0]??0,
  100. 'totime'=>$data['f_t_date'][1]??0,
  101. 'text_name'=>$data['text_name']??'',
  102. 'text_url'=>$data['text_url']??'',
  103. 'text_title'=>$data['text_title']??'',
  104. 'image_src'=>$data['image_src']??'',
  105. 'image_url'=>$data['image_url']??'',
  106. 'image_alt'=>$data['image_alt']??'',
  107. 'video_src'=>$data['video_src']??'',//视频
  108. 'video_url'=>$data['video_url']??'',
  109. 'video_auto'=>isset($data['video_auto']) && empty($data['video_auto'])?0:$data['video_auto'],
  110. 'video_loop'=>isset($data['video_loop']) && empty($data['video_loop'])?0:$data['video_loop'],
  111. 'status'=>$data['status']??2,
  112. 'remark'=>$data['remark']??'',
  113. ];
  114. $result = Ad::where($where)->update($insertData);
  115. if($result){
  116. return Result::success($result);
  117. }else{
  118. return Result::error("更新失败");
  119. }
  120. }
  121. public function delAd(array $data): array
  122. {
  123. $result = Ad::where($data)->delete();
  124. if(!$result){
  125. return Result::error("删除失败");
  126. }
  127. return Result::success($result);
  128. }
  129. /**
  130. * 广告位列表
  131. * @param array $data
  132. * @return array
  133. */
  134. public function getAdPlaceList(array $data): array
  135. {
  136. $where = [];
  137. if(isset($data['name']) && $data['name']){
  138. array_push($where,['ad_place.name','like','%'.$data['name'].'%']);
  139. }
  140. if(isset($data['website_id']) && $data['website_id']){
  141. array_push($where,['ad_place.website_id','=',$data['website_id']]);
  142. }
  143. $rep = AdPlace::where($where)
  144. ->leftJoin("ad_size","ad_place.ad_size_id","ad_size.id")
  145. ->leftJoin("website","website.id","ad_place.website_id")
  146. ->limit($data['pageSize'])
  147. ->orderBy("ad_place.updated_at","desc")
  148. ->offset(($data['page']-1)*$data['pageSize'])
  149. ->select("ad_place.*","ad_size.width","ad_size.height","website.website_name","website.website_column_id","website.website_column_arr_id")
  150. ->get();
  151. if($rep){
  152. foreach ($rep as $key=>$val){
  153. $rep[$key]['website_column_arr_id'] = json_decode($val['website_column_arr_id'],true);
  154. }
  155. }
  156. $count = AdPlace::where($where)->count();
  157. $reponse = [
  158. 'rows'=>$rep->toArray(),
  159. 'count'=>$count
  160. ];
  161. if(empty($rep->toArray())){
  162. return Result::error("没有数据");
  163. }
  164. return Result::success($reponse);
  165. }
  166. public function createAdPlace(array $data): array
  167. {
  168. unset($data['size']);
  169. $result = AdPlace::query()->insertGetId($data);
  170. if($result){
  171. return Result::success();
  172. }else{
  173. return Result::error("创建广告位失败",500);
  174. }
  175. }
  176. /**
  177. * @param array $data
  178. * @return array
  179. */
  180. public function updateAdPlace(array $data): array
  181. {
  182. // 11
  183. $where = [
  184. 'ad_place.id'=>$data['id']
  185. ];
  186. // $website_id = intval($data['website_id']);
  187. // 原代码 leftJoin 条件使用错误,第三个参数应该是关联字段,这里修正为 "website.id" 关联 "ad_place.website_id"
  188. $web = AdPlace::where($where)
  189. ->leftJoin("website","website.id","ad_place.website_id")
  190. ->select("website.*","ad_place.name",'ad_place.ad_tag')
  191. ->first();
  192. if(empty($web)){
  193. return Result::error("广告位不存在");
  194. }
  195. // 自助建站广告位-广告位编辑同步模板数据-------fr----start
  196. // return Result::success($web);
  197. $website_column_arr_id = json_decode($web['website_column_arr_id'],true);
  198. Db::beginTransaction();
  199. try{
  200. // 判断网站的广告位是否通过自助建站创建的广告位(通过网系包含2来判断)
  201. if(!in_array(3,$website_column_arr_id)){
  202. $template_data = ['ad_tag'=>$web['ad_tag']];
  203. $template_data = array_merge($data,$template_data);
  204. $template_module = WebsiteTemplate::where('website_id',$template_data['website_id'])->first();
  205. $page_type = explode('_', $template_data['ad_tag']);
  206. // 页面类型
  207. $page = $page_type[1];
  208. $ad_places = [];
  209. // 模板数据及画布数据
  210. $oldtemplate_data = json_decode($template_module['template_data'],true);
  211. $oldcanvas_data = json_decode($template_module['canvas_data'],true);
  212. if(array_key_exists( $page,$oldtemplate_data['ad'])){
  213. $ad_places = $oldtemplate_data['ad'][$page];
  214. }
  215. // return Result::success($ad_places);
  216. if($page == 'top'){
  217. $ad_place = [
  218. 'width' => $oldtemplate_data['ad'][$page]['width'],
  219. 'height' => $oldtemplate_data['ad'][$page]['height'],
  220. 'name'=>$template_data['name'], //广告位名称可更改
  221. 'price'=>$template_data['price'], //广告位价格可更改
  222. 'introduce'=>$template_data['introduce'], //广告位介绍可更改
  223. 'website_id'=>$oldtemplate_data['ad'][$page]['website_id'],
  224. 'thumb'=>$template_data['thumb'], //广告位默认图可更改
  225. 'typeid'=>$oldtemplate_data['ad'][$page]['typeid'],
  226. 'ad_tag'=>$oldtemplate_data['ad'][$page]['ad_tag'],
  227. 'ad_url'=>$template_data['ad_url'], //广告位默认链接可更改
  228. ];
  229. }else{
  230. foreach($ad_places as $key=>$val){
  231. if($template_data['ad_tag'] == $val['ad_tag']){
  232. $ad_place[$key] = [
  233. 'width' => $val['width'],
  234. 'height' => $val['height'],
  235. 'name'=>$template_data['name'], //广告位名称可更改
  236. 'price'=>$template_data['price'], //广告位价格可更改
  237. 'introduce'=>$template_data['introduce'], //广告位介绍可更改
  238. 'website_id'=>$val['website_id'],
  239. 'thumb'=>$template_data['thumb'], //广告位默认图可更改
  240. 'typeid'=>$val['typeid'],
  241. 'ad_tag'=>$val['ad_tag'],
  242. 'ad_url'=>$template_data['ad_url'], //广告位默认链接可更改
  243. ];
  244. $template_ad = $ad_place[$key];
  245. }else{
  246. $ad_place[$key] = $val;
  247. }
  248. }
  249. if(array_key_exists( $page,$oldtemplate_data['template'])){
  250. $ad_places_info = $oldtemplate_data['template'][$page];
  251. }
  252. foreach($ad_places_info as $key=>$val){
  253. $ad_info[$key] = $val;
  254. if(array_key_exists('ad',$val) && $val['ad']['ad_tag'] == $template_data['ad_tag']){
  255. $ad_info[$key]['ad'] = $template_ad;
  256. $num = $key;
  257. }
  258. }
  259. $canvas_data = $oldcanvas_data;
  260. foreach($oldcanvas_data['template'][$page] as $key=>$val){
  261. // $canvas_info_ad[$key] = $val;
  262. if(array_key_exists('ad',$val['content']) && $val['content']['ad']['ad_tag'] == $template_data['ad_tag']){
  263. // $canvas_info_ad[$key]['ad'] = $template_ad;
  264. $canvas_ad['content']['ad'] = [
  265. 'width' => $val['content']['ad']['width'],
  266. 'height' => $val['content']['ad']['height'],
  267. 'name'=>$template_data['name'], //广告位名称可更改
  268. 'price'=>$template_data['price'], //广告位价格可更改
  269. 'introduce'=>$template_data['introduce'], //广告位介绍可更改
  270. 'website_id'=>$val['content']['ad']['website_id'],
  271. 'thumb'=>$val['content']['ad']['thumb'], //广告位默认图可更改
  272. 'typeid'=>$val['content']['ad']['typeid'],
  273. 'ad_tag'=>$val['content']['ad']['ad_tag'],
  274. ];
  275. $canvas_data['template'][$page][$key]['content']['ad'] = $canvas_ad['content']['ad'];
  276. }
  277. }
  278. $oldtemplate_data['template'][$page] = $ad_info; //模板广告位相关信息已修改
  279. }
  280. // return Result::success($ad_place);
  281. // 保存的模板中的广告位相关信息
  282. $oldtemplate_data['ad'][$page] = $ad_place;
  283. // Db::rollBack();
  284. // }
  285. if($page == 'top'){
  286. $canvas_data['topAd'] = $ad_place;
  287. }
  288. // return Result::success($canvas_data);
  289. $template_module['canvas_data'] = json_encode($canvas_data,JSON_UNESCAPED_UNICODE);
  290. $template_module['template_data'] = json_encode($oldtemplate_data,JSON_UNESCAPED_UNICODE);
  291. $template_result = WebsiteTemplate::where('website_id',$template_data['website_id'])->update([
  292. 'canvas_data'=>$template_module['canvas_data'],
  293. 'template_data'=>$template_module['template_data'],
  294. ]);
  295. if(!$template_result){
  296. Db::rollBack();
  297. return Result::error('同步模板失败!');
  298. }
  299. }
  300. // return Result::success($website_column_arr_id);
  301. $Insdata = [
  302. 'website_id'=>$data['website_id']??'',
  303. 'typeid'=>$data['typeid']??1,
  304. 'status'=>$data['status']??2,
  305. 'name'=>$data['name']??'',
  306. 'thumb'=>$data['thumb']??'',
  307. 'introduce'=>$data['introduce']??'',
  308. 'code'=>$data['code']??'',
  309. 'price'=>$data['price']??0,
  310. 'ad_size_id'=>$data['ad_size_id']??0,
  311. 'ad_url'=>$data['ad_url']??'',
  312. 'ad_tag'=>$data['ad_tag']??'',
  313. ];
  314. $result = AdPlace::where($where)->update($Insdata);
  315. if(!$result){
  316. Db::rollBack();
  317. return Result::error("更新失败");
  318. }
  319. Db::commit();
  320. return Result::success($result);
  321. }catch (\Exception $e) {
  322. Db::rollBack();
  323. return Result::error($e->getMessage());
  324. }
  325. // 自助建站广告位-广告位编辑同步模板数据-------fr----end
  326. // 11--end
  327. }
  328. /**
  329. * 删除广告位
  330. * @param array $data
  331. * @return array
  332. */
  333. public function delAdPlace(array $data): array
  334. {
  335. $adList = Ad::where(['pid'=>$data['id']])->get();
  336. if($adList->toArray()){
  337. return Result::error("广告位里面还有广告,不能删除广告位");
  338. }
  339. $result = AdPlace::where($data)->delete();
  340. if(!$result){
  341. return Result::error("删除失败");
  342. }
  343. return Result::success($result);
  344. }
  345. /**
  346. * @param int $id
  347. * @return array
  348. */
  349. public function getAdPlaceInfo(int $id): array
  350. {
  351. $adInfo = AdPlace::query()->find($id);
  352. if (empty($adInfo)) {
  353. return Result::error("没有数据",0);
  354. }
  355. return Result::success($adInfo->toArray());
  356. }
  357. /**
  358. * @param array $data
  359. * @return array
  360. */
  361. public function addTwinAdPlace(array $data): array
  362. {
  363. Db::beginTransaction();
  364. try {
  365. //根据传过来的website_id查询网站下的广告位 ad_tag字段组合成一个数组
  366. $adTagList = AdPlace::where(['website_id'=>$data['adPlaceList'][0]['website_id']])->pluck('ad_tag')->toArray();
  367. //循环传过来的adPlaceList数组取参数的ad_tag字段
  368. $adTagNewList = array_column($data['adPlaceList'],'ad_tag');
  369. //假设$adTagNewList=[1,2,3],$adTagList=[1,2,4,5] 我要取到$adTagList 里面的4,5
  370. $adTagDiffList = array_diff($adTagList,$adTagNewList);
  371. //删除AdPlace模型里面的$adTagDiffList 里面的广告位
  372. if($adTagDiffList){
  373. AdPlace::whereIn('ad_tag',$adTagDiffList)->delete();
  374. }
  375. if(isset($data['adPlaceList']) && $data['adPlaceList']){
  376. foreach ($data['adPlaceList'] as $key=>$val){
  377. $adSizeInfo = AdSize::firstOrCreate(['width'=>$val['width'],'height'=>$val['height']]);
  378. $adPlaceInfo = AdPlace::updateOrCreate(
  379. [ 'ad_tag'=>$val['ad_tag'],'website_id'=>$val['website_id']],
  380. [
  381. 'website_id'=>$val['website_id'],
  382. 'typeid'=>$val['typeid'] ?? 2,
  383. 'status'=>1,
  384. 'name'=>$val['name']??'',
  385. 'thumb'=>$val['thumb']??'',
  386. 'code'=>$val['code']??'',
  387. 'ad_size_id'=>$adSizeInfo->id,
  388. 'ad_tag'=>$val['ad_tag']??'',
  389. 'introduce'=>$val['introduce']??'',
  390. 'price'=>$val['price']??0,
  391. ]
  392. );
  393. }
  394. }
  395. Db::commit();
  396. return Result::success([]);
  397. }catch (\Exception $e){
  398. Db::rollBack();
  399. return Result::error("创建广告位失败".$e->getMessage(),0);
  400. }
  401. }
  402. }