WebChannelConfigController.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Game\WebChannelConfig;
  4. use App\Game\WebRegionConfig;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Facades\DB;
  7. use Illuminate\Support\Facades\Validator;
  8. class WebChannelConfigController
  9. {
  10. protected $groupColors = [
  11. 0 => '#007bff', // blue
  12. 1 => '#28a745', // green
  13. 2 => '#ffc107', // yellow/orange
  14. 3 => '#dc3545', // red
  15. 4 => '#6f42c1', // purple
  16. 5 => '#17a2b8', // cyan
  17. 6 => '#6c757d', // gray
  18. 7 => '#e83e8c', // pink
  19. ];
  20. protected $specialModes = [
  21. 1 => 'GUEST (自动游客登录模式)',
  22. 2 => 'ZERO_MONEY (注册不送钱)',
  23. 4 => 'DISABLE_PROMOTE_INSTALL (提示安装)',
  24. 8 => 'PWA_BONUS (安装app送钱)',
  25. 16 => 'REG_TO_REALMONEY (注册返回就是真金)',
  26. 32 => 'MAIL_BONUS (MAIL验证送钱)',
  27. 64 => 'FIRSTPAY_OFF30 (首冲打开30%bonus)',
  28. 128 => 'DEBUG_EVENT (是否开启事件日志上报)',
  29. 256 => 'REGION_UNIQUE (是否开启区域独立模式)',
  30. 512 => 'FB_JUMP_LATER (fb内浏览器弹出时机在绑定手机后)',
  31. 1024 => 'FB_JUMP_LATER2 (fb内浏览器弹出在点击提现后)',
  32. 2048 => 'JUMP_APK1 (安卓包开启无脑跳转引导)',
  33. 4096 => 'JUMP_APK2 (安卓包开启付费后引导跳转)',
  34. ];
  35. public function index(Request $request)
  36. {
  37. $channel = $request->input('Channel');
  38. $packageName = $request->input('PackageName');
  39. $query = WebChannelConfig::query();
  40. if ($channel) {
  41. $query->where('Channel', $channel);
  42. }
  43. if ($packageName) {
  44. $query->where('PackageName', 'like', '%' . $packageName . '%');
  45. }
  46. $list = $query->orderBy('Channel', 'asc')->paginate(40);
  47. $regions = WebRegionConfig::all();
  48. $regionMap = [];
  49. $regionUrlMap = [];
  50. foreach ($regions as $region) {
  51. $logoUrl = $region->DomainUrl . $region->LogoUrl;
  52. $isSvg = !empty($region->LogoUrl) && strtolower(pathinfo($region->LogoUrl, PATHINFO_EXTENSION)) === 'svg';
  53. $regionMap[$region->RegionID] = [
  54. 'color' => $this->groupColors[$region->GroupID] ?? '#000000',
  55. 'logo' => $logoUrl,
  56. 'has_logo' => !empty($region->LogoUrl),
  57. 'is_svg' => $isSvg
  58. ];
  59. // 构建区域的 URL 映射
  60. $regionUrlMap[$region->RegionID] = $region->DomainUrl;
  61. }
  62. // 为每条记录计算网站地址
  63. $channelUrls = [];
  64. foreach ($list as $item) {
  65. $url = '';
  66. // 优先:如果 WebChannelConfig 绑定了 RegionID,直接使用该 Region 的 URL
  67. if (!empty($item->RegionID) && isset($regionUrlMap[$item->RegionID])) {
  68. $url = rtrim($regionUrlMap[$item->RegionID], '/') . '/?c=' . $item->Channel;
  69. }
  70. $channelUrls[$item->ID] = $url;
  71. }
  72. return view('admin.web_channel_config.index', [
  73. 'list' => $list,
  74. 'channel' => $channel,
  75. 'packageName' => $packageName,
  76. 'regionMap' => $regionMap,
  77. 'channelUrls' => $channelUrls,
  78. ]);
  79. }
  80. public function create()
  81. {
  82. $regionList = WebRegionConfig::orderBy('GroupID', 'asc')->get();
  83. return view('admin.web_channel_config.add', [
  84. 'regionList' => $regionList,
  85. 'groupColors' => $this->groupColors,
  86. 'specialModes' => $this->specialModes
  87. ]);
  88. }
  89. public function store(Request $request)
  90. {
  91. $data = $request->all();
  92. $validator = Validator::make($data, [
  93. 'Channel' => 'required|integer',
  94. 'PackageName' => 'required|string|max:200',
  95. ]);
  96. if ($validator->fails()) {
  97. return apiReturnFail($validator->errors()->first());
  98. }
  99. // 处理 BonusArr
  100. $bonusArr = [
  101. $request->input('BonusArr_REG', 0),
  102. $request->input('BonusArr_MOBILE', 0),
  103. $request->input('BonusArr_EMAIL', 0),
  104. $request->input('BonusArr_PWA', 0),
  105. ];
  106. $data['BonusArr'] = implode('|', $bonusArr);
  107. // 处理 LoginOpen 和 RegOpen (多选框)
  108. $data['LoginOpen'] = $request->has('LoginOpen') ? implode(',', $request->input('LoginOpen')) : '';
  109. $data['RegOpen'] = $request->has('RegOpen') ? implode(',', $request->input('RegOpen')) : '';
  110. // 处理 SpecialMode (多选框位运算)
  111. $specialMode = 0;
  112. if ($request->has('SpecialMode') && is_array($request->input('SpecialMode'))) {
  113. foreach ($request->input('SpecialMode') as $val) {
  114. $specialMode += (int)$val;
  115. }
  116. }
  117. $data['SpecialMode'] = $specialMode;
  118. // 防止 null 报错
  119. $data['ShadowChannel'] = $data['ShadowChannel'] ?? '';
  120. $data['LightApk'] = $data['LightApk'] ?? '';
  121. $data['FullApk'] = $data['FullApk'] ?? '';
  122. $data['PlatformID'] = $data['PlatformID'] ?? '';
  123. $data['PlatformToken'] = $data['PlatformToken'] ?? '';
  124. $data['RegionID'] = $data['RegionID'] ?? '';
  125. $config = WebChannelConfig::create($data);
  126. // 同步更新 WebRegionConfig 的 BindChannels
  127. if (!empty($config->RegionID)) {
  128. $region = WebRegionConfig::where('RegionID', $config->RegionID)->first();
  129. if ($region) {
  130. $bindChannels = is_array($region->BindChannels) ? $region->BindChannels : [];
  131. if (!in_array($config->Channel, $bindChannels)) {
  132. $bindChannels[] = (int)$config->Channel;
  133. sort($bindChannels);
  134. $region->BindChannels = $bindChannels;
  135. $region->save();
  136. }
  137. }
  138. }
  139. return apiReturnSuc();
  140. }
  141. public function edit($id)
  142. {
  143. $info = WebChannelConfig::findOrFail($id);
  144. $regionList = WebRegionConfig::orderBy('GroupID', 'asc')->get();
  145. return view('admin.web_channel_config.edit', [
  146. 'info' => $info,
  147. 'regionList' => $regionList,
  148. 'groupColors' => $this->groupColors,
  149. 'specialModes' => $this->specialModes
  150. ]);
  151. }
  152. public function update(Request $request, $id)
  153. {
  154. $data = $request->all();
  155. $info = WebChannelConfig::findOrFail($id);
  156. $validator = Validator::make($data, [
  157. 'PackageName' => 'required|string|max:200',
  158. ]);
  159. if ($validator->fails()) {
  160. return apiReturnFail($validator->errors()->first());
  161. }
  162. // 确保 Channel 不被修改
  163. unset($data['Channel']);
  164. // 处理 BonusArr
  165. $bonusArr = [
  166. $request->input('BonusArr_REG', 0),
  167. $request->input('BonusArr_MOBILE', 0),
  168. $request->input('BonusArr_EMAIL', 0),
  169. $request->input('BonusArr_PWA', 0),
  170. ];
  171. $data['BonusArr'] = implode('|', $bonusArr);
  172. // 处理 LoginOpen 和 RegOpen (多选框)
  173. $data['LoginOpen'] = $request->has('LoginOpen') ? implode(',', $request->input('LoginOpen')) : '';
  174. $data['RegOpen'] = $request->has('RegOpen') ? implode(',', $request->input('RegOpen')) : '';
  175. // 处理 SpecialMode (多选框位运算)
  176. $specialMode = 0;
  177. if ($request->has('SpecialMode') && is_array($request->input('SpecialMode'))) {
  178. foreach ($request->input('SpecialMode') as $val) {
  179. $specialMode += (int)$val;
  180. }
  181. }
  182. $data['SpecialMode'] = $specialMode;
  183. // 防止 null 报错
  184. $data['ShadowChannel'] = $data['ShadowChannel'] ?? '';
  185. $data['LightApk'] = $data['LightApk'] ?? '';
  186. $data['FullApk'] = $data['FullApk'] ?? '';
  187. $data['PlatformID'] = $data['PlatformID'] ?? '';
  188. $data['PlatformToken'] = $data['PlatformToken'] ?? '';
  189. $data['RegionID'] = $data['RegionID'] ?? '';
  190. $data['PlatformName'] = $data['PlatformName'] ?? '';
  191. $oldRegionID = $info->RegionID;
  192. $oldChannel = $info->Channel;
  193. $oldSpecialMode = $info->SpecialMode;
  194. // 一旦启用 REGION_UNIQUE,RegionID 不可更换同时 REGION_UNIQUE 选项不可更改
  195. if (($oldSpecialMode & 256) == 256) {
  196. $data['RegionID'] = $oldRegionID;
  197. if (!in_array(256, $request->input('SpecialMode', []))) {
  198. $specialMode += 256;
  199. $data['SpecialMode'] = $specialMode;
  200. }
  201. }
  202. $info->update($data);
  203. // 同步更新 WebRegionConfig 的 BindChannels
  204. // 1. 从旧的 RegionID 中移除旧的 Channel
  205. if (!empty($oldRegionID)) {
  206. $oldRegion = WebRegionConfig::where('RegionID', $oldRegionID)->first();
  207. if ($oldRegion) {
  208. $bindChannels = is_array($oldRegion->BindChannels) ? $oldRegion->BindChannels : [];
  209. $key = array_search($oldChannel, $bindChannels);
  210. if ($key !== false) {
  211. unset($bindChannels[$key]);
  212. $oldRegion->BindChannels = array_values($bindChannels);
  213. $oldRegion->save();
  214. }
  215. }
  216. }
  217. // 2. 向新的 RegionID 中添加新的 Channel(如果新 RegionID 不为空)
  218. if (!empty($info->RegionID)) {
  219. $newRegion = WebRegionConfig::where('RegionID', $info->RegionID)->first();
  220. if ($newRegion) {
  221. $bindChannels = is_array($newRegion->BindChannels) ? $newRegion->BindChannels : [];
  222. if (!in_array($info->Channel, $bindChannels)) {
  223. $bindChannels[] = (int)$info->Channel;
  224. sort($bindChannels);
  225. $newRegion->BindChannels = $bindChannels;
  226. $newRegion->save();
  227. }
  228. }
  229. }
  230. return apiReturnSuc();
  231. }
  232. public function destroy($id)
  233. {
  234. $info = WebChannelConfig::findOrFail($id);
  235. $channel = $info->Channel;
  236. $regionID = $info->RegionID;
  237. $info->delete();
  238. // 删除时,从 WebRegionConfig 的 BindChannels 中移除该 Channel
  239. if (!empty($regionID)) {
  240. $region = WebRegionConfig::where('RegionID', $regionID)->first();
  241. if ($region) {
  242. $bindChannels = is_array($region->BindChannels) ? $region->BindChannels : [];
  243. $key = array_search($channel, $bindChannels);
  244. if ($key !== false) {
  245. unset($bindChannels[$key]);
  246. $region->BindChannels = array_values($bindChannels);
  247. $region->save();
  248. }
  249. }
  250. }
  251. return apiReturnSuc();
  252. }
  253. public function remarks(Request $request, $id)
  254. {
  255. $remark = $request->input('remark', '');
  256. // 查找 WebChannelConfig 记录
  257. $config = WebChannelConfig::find($id);
  258. if (!$config) {
  259. return apiReturnFail('记录不存在');
  260. }
  261. $channel = $config->Channel;
  262. $packageName = $config->PackageName;
  263. // 更新 WebChannelConfig 的备注
  264. if (WebChannelConfig::where('Channel', $channel)->exists()) {
  265. WebChannelConfig::where('Channel', $channel)->update(['Remarks' => $remark]);
  266. } else {
  267. // 如果不存在,使用渠道100的配置作为模板创建新记录
  268. $templateConfig = WebChannelConfig::where('Channel', 100)->first();
  269. if ($templateConfig) {
  270. $configArray = $templateConfig->toArray();
  271. $configArray['Remarks'] = $remark;
  272. $configArray['Channel'] = $channel;
  273. $configArray['PackageName'] = $packageName;
  274. unset($configArray['ID']);
  275. WebChannelConfig::insert($configArray);
  276. }
  277. }
  278. //同步更新 ChannelPackage
  279. $channelNumber = DB::connection('write')->table('QPPlatformDB.dbo.ChannelPackageName')
  280. ->where('Channel', $channel);
  281. if ($channelNumber->exists()) {
  282. $channelNumber->update(['Remarks' => $remark]);
  283. }
  284. // 同步更新 dcat-admin.channel 表
  285. $dcatChannel = DB::connection('mysql')->table('dcat-admin.channel')->where('channel', $channel);
  286. if ($dcatChannel->exists()) {
  287. $dcatChannel->update(['channel_name' => $remark]);
  288. } else {
  289. DB::connection('mysql')->table('dcat-admin.channel')->insert([
  290. 'channel' => $channel,
  291. 'channel_name' => $remark,
  292. 'package_name' => '',
  293. 'remark' => ''
  294. ]);
  295. }
  296. // 同步更新 dcat-admin.channel_ownership 表
  297. $dcatChannelOwnership = DB::connection('mysql')->table('dcat-admin.channel_ownership')->where('channel', $channel);
  298. if ($dcatChannelOwnership->exists()) {
  299. $dcatChannelOwnership->update(['name' => $remark]);
  300. } else {
  301. DB::connection('mysql')->table('dcat-admin.channel_ownership')->insert([
  302. 'channel' => $channel,
  303. 'name' => $remark
  304. ]);
  305. }
  306. return apiReturnSuc('备注更新成功');
  307. }
  308. }