ReadOauth.php 83 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Modules\Book\Services\BookConfigService;
  4. use App\Modules\Channel\Models\YqMoveChannel;
  5. use App\Modules\Channel\Services\ChannelService;
  6. use App\Modules\OfficialAccount\Services\ForceSubscribeService;
  7. use App\Modules\User\Models\YqMove;
  8. use App\Modules\User\Services\ReadRecordService;
  9. use App\Modules\User\Services\UserService;
  10. use App\Modules\YunQi\Services\BookUserService;
  11. use App\Modules\YunQi\Services\YqUserBidRelationService;
  12. use App\Modules\YunQi\Services\YqZsyTestService;
  13. use Closure;
  14. use Cookie;
  15. use App\Libs\ApiClient;
  16. use EasyWeChat\Core\Exception;
  17. use Illuminate\Http\Request;
  18. use Log;
  19. use Redis;
  20. use App\Modules\OfficialAccount\Services\OfficialAccountService;
  21. use Hashids;
  22. use GuzzleHttp\Client;
  23. use App\Jobs\SendTexts;
  24. use DB;
  25. class ReadOauth
  26. {
  27. /**
  28. * 判断是否登陆.
  29. */
  30. public function handle(Request $request, Closure $next)
  31. {
  32. $this->cookieNoCrypt();
  33. $test = 0;
  34. if ($request->has('test') && $request->input('test') == 'bonan') {
  35. $test = 1;
  36. }
  37. $uid_cookie = Cookie::get(env('COOKIE_AUTH_WEB_WECHAT'));
  38. $h5_scheme = env('H5_SCHEME', 'https');
  39. $params = $request->except('_url');
  40. $url = str_replace('http://', $h5_scheme . '://', url()->current() . '?' . http_build_query($params));
  41. //Log::info('-----------------uid' . $uid_cookie);
  42. $send_order_id = $request->input('send_order_id');
  43. if ($send_order_id) {
  44. Cookie::queue('send_order_id', $send_order_id, env('U_COOKIE_EXPIRE'), null, null, false, false);
  45. }
  46. $distribution_channel_id = str_replace('site', '', explode('.', _domain())[0]);
  47. $origin_distribution_channel_id = $distribution_channel_id;
  48. if (!is_numeric($distribution_channel_id)) {
  49. $distribution_channel_id = decodeDistributionChannelId($distribution_channel_id);
  50. }
  51. if (!$distribution_channel_id) {
  52. return response()->error('WAP_SYS_ERROR');
  53. }
  54. //禁止访问的site
  55. $not_allow_access_site = env('NOT_ALLOW_ACCESS_SITE', '');
  56. if ($not_allow_access_site) {
  57. $not_allow_access_site_arr = explode(',', $not_allow_access_site);
  58. if (in_array($distribution_channel_id, $not_allow_access_site_arr)) {
  59. return response($this->notAccessPage())->header('Content-Type', 'text/html');
  60. }
  61. }
  62. if (!$uid_cookie && $test == 0) {
  63. //$url = str_replace('http://','https://',url()->current())."?".http_build_query($params);
  64. $uri = $request->input('_url');
  65. if (strpos($uri, '/yun/') !== false) {
  66. $uri_send_order_id = (int)str_ireplace('/yun/', '', $uri);
  67. Cookie::queue('send_order_id', $uri_send_order_id, env('U_COOKIE_EXPIRE'), null, null, false, false);
  68. }
  69. $this->share($request);
  70. Cookie::queue('auth_redirect', urlencode($url), env('U_COOKIE_EXPIRE'));
  71. //$params['redirect_url'] = urlencode(env('PUBLIC_BASE_API').'oauthCallBack');
  72. //$params['redirect_url'] = urlencode('http://47.96.174.172:8093/oauthCallBack');
  73. $domain = _domain();
  74. $params['redirect_url'] = urlencode($h5_scheme . '://' . $domain . '/oauthCallBack');
  75. $params['timestamp'] = time();
  76. //$office_info = $this->getOfficialAccount(_domain());
  77. //$params['gzh_app_id'] = $office_info['appid'];
  78. $params['gzh_app_id'] = env('WECHAT_AUTH_APPID');
  79. $params['sign'] = $this->getSign($params, env('OAUTH_KEY'));
  80. $redirect = env('AUTH_URL') . '?' . http_build_query($params);
  81. $auth_v2_url = $this->authV2($request, $distribution_channel_id);
  82. if ($auth_v2_url) {
  83. return redirect()->to($auth_v2_url);
  84. }
  85. $redirect_V2 = $this->auth($request, $distribution_channel_id);
  86. if ($redirect_V2) {
  87. return redirect()->to($redirect_V2);
  88. }
  89. return redirect()->to($redirect);
  90. }
  91. //禁止明文访问
  92. if ($this->isForbidPrimaryNumberChannleID($origin_distribution_channel_id, $uid_cookie)) {
  93. return response('<html><head><meta charset=utf-8><meta name=viewport content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no"><title>该网站地址暂停访问</title></head><body style="padding:0;margin:0;font-size:0"><div style="width:300px;height:100px;margin: 20px auto"><p style="font-size:20px;color:red;text-align:center">该网站地址暂停访问,请联系客服微信获取新地址:wuxinchao12</p></body></html>');
  94. }
  95. if ($request->has('appid') && $request->has('openid')) {
  96. Log::info('param is:');
  97. Log::info($params);
  98. $uri = $request->input('_url');
  99. $openid = $request->get('openid');
  100. $appid = $request->get('appid');
  101. /* $user_info = ForceSubscribeService::getUserInfo($appid,$openid);
  102. Log::info('appid user id to userinfo');
  103. Log::info($user_info);*/
  104. $back = $request->get('back', '');
  105. if ($openid && $appid && $distribution_channel_id && $uid_cookie) {
  106. $this->apidAndOpenId($distribution_channel_id, $appid, $openid, $uid_cookie);
  107. $channel = ChannelService::getById($distribution_channel_id);
  108. $is_yq_move = $this->isQyMove($channel, $distribution_channel_id);
  109. if ($is_yq_move) {
  110. $move_user = YqMove::where('zsy_uid', $uid_cookie)->select('zsy_uid')->first();
  111. if (!$move_user) {
  112. if (!$back) {
  113. $yq_home = $this->getYqChannleIdByAppid($appid);
  114. Log::info('$this->getYqChannleIdByAppid($appid) is : ');
  115. Log::info($yq_home);
  116. if ($yq_home) {
  117. $params['zsy_channel_id'] = encodeDistributionChannelId($distribution_channel_id);
  118. $params['pa'] = $uri;
  119. $back_url = $yq_home . 'move?' . http_build_query($params);
  120. Log::info('$yq_home - $back_url is: ' . $back_url);
  121. return redirect()->to($back_url);
  122. }
  123. }
  124. $this->moveUserFromYq($distribution_channel_id, $appid, $openid, $uid_cookie);
  125. }
  126. }
  127. }
  128. }
  129. //云栖测试
  130. $qy_test_url = $this->yqTest($request,$uid_cookie,$distribution_channel_id);
  131. if($qy_test_url){
  132. Log::info('url is: '.$qy_test_url);
  133. //return redirect()->to($qy_test_url);
  134. }
  135. //只能推送的统计
  136. $this->smartPush($request, $uid_cookie);
  137. //数据分析 长篇推短片的统计
  138. $this->dataAnalysis($request, $uid_cookie);
  139. //from where的临时统计
  140. $this->tempFromWhere($request, $uid_cookie);
  141. //统计访问site数字的uid记录下
  142. //$this->recordPrimaryNumberChannleIDUser($origin_distribution_channel_id,$uid_cookie);
  143. $response = $next($request);
  144. $stats = $request->get('stats', 0);
  145. if ($request->has('fromtype') && $request->input('fromtype')) {
  146. try {
  147. $from = $request->input('fromtype', 'main');
  148. Cookie::queue('from', $from, env('U_COOKIE_EXPIRE'), null, null, false, false);
  149. if (!$stats) {
  150. Redis::sadd('push:distribution_channel_id:' . $distribution_channel_id . 'from:' . $from . ':date:' . date('Y-m-d'), $uid_cookie);
  151. Redis::sadd('push:distribution_channel_id:alluv:from:' . $from, $uid_cookie);
  152. Redis::hincrby('push:distribution_channel_id:allpv', $from, 1);
  153. Redis::hincrby('customer:push:click:distribution_channel_id:' . $distribution_channel_id . 'from:' . $from, date('Y-m-d'), 1);
  154. Redis::sadd('wap_from_stats' . date('Y-m-d'), $distribution_channel_id . '-' . $from);
  155. }
  156. } catch (\Exception $e) {
  157. Log::info($e);
  158. }
  159. }
  160. $from = $request->get('fromtype');
  161. $inner_order_id = $request->get('inner_order_id');
  162. if (!$from) {
  163. $from = Cookie::get('from');
  164. $this->innerSendOrderIdFromFromtype($uid_cookie, 1, $from, $inner_order_id);
  165. } else {
  166. $this->innerSendOrderIdFromFromtype($uid_cookie, $stats, $from, $inner_order_id);
  167. }
  168. //内部派单
  169. if ($inner_order_id) {
  170. $this->innerSendOrderIdStats($uid_cookie, $inner_order_id, $stats);
  171. }
  172. //from_title_image
  173. $this->fromTitleImage($request, $uid_cookie);
  174. if ($test) {
  175. Cookie::queue(env('COOKIE_AUTH_WEB_WECHAT'), 9, env('U_COOKIE_EXPIRE'), null, null, false, false);
  176. }
  177. return $response;
  178. }
  179. private function share(Request $request)
  180. {
  181. if ($request->has('fromtype') && 'readershare' == $request->get('fromtype')) {
  182. $bid = $request->get('bid');
  183. try {
  184. if ($bid) {
  185. $bid_arr = Hashids::decode($bid);
  186. isset($bid_arr[0]) && $bid = $bid_arr[0];
  187. }
  188. } catch (\Exception $e) {
  189. }
  190. $fromflag = $request->get('fromflag', 0);
  191. $cid = $request->get('fromcid', 0);
  192. Cookie::queue('reader_share_bid', $bid . '-' . $fromflag, 60);
  193. Cookie::queue('reader_share_cid', $cid, 60);
  194. }
  195. }
  196. private function isQyMove($channel, $distribution_channel_id)
  197. {
  198. $is_yq_move = 0;
  199. // 新站
  200. if (isset($channel->is_yq_move) && $channel->is_yq_move) {
  201. $is_yq_move = 1;
  202. }
  203. // 已经迁移过的站,回复也要有老站
  204. $yqMoveChannel = YqMoveChannel::get_yq_move_channel($distribution_channel_id, 1);
  205. if (!empty($yqMoveChannel)) {
  206. //\Log::info('old_has_move_site:'.$distribution_channel_id);
  207. $is_yq_move = 1;
  208. }
  209. return $is_yq_move;
  210. }
  211. private function innerSendOrderIdFromFromtype($uid, $stats, $from, $inner_order_id)
  212. {
  213. //$inner_send_order_id = ReadRecordService::getInnerSendOrderId($uid);
  214. $inner_send_order_id = false;
  215. if (!$inner_send_order_id) {
  216. if ($from && (starts_with($from, 'custom') || starts_with($from, 'template')) && count(explode('_', $from)) == 2) {
  217. if (!$inner_order_id) {
  218. $this->innerSendOrderIdStats($uid, $from, $stats);
  219. }
  220. }
  221. }
  222. }
  223. private function innerSendOrderIdStats($uid, $inner_order_id, $stats)
  224. {
  225. try {
  226. ReadRecordService::setInnerSendOrderId($uid, $inner_order_id);
  227. if (!$stats) {
  228. Redis::sadd('push:inner_send_order_id:uv:' . $inner_order_id, $uid);
  229. Redis::hincrby('push:inner_send_order_id:pv', $inner_order_id, 1);
  230. }
  231. } catch (\Exception $e) {
  232. }
  233. }
  234. private function cookieNoCrypt()
  235. {
  236. $cookie_key = ['send_order_id', 'from', 'send_order_continue', 'send_order_flag'];
  237. foreach ($cookie_key as $v) {
  238. $temp = Cookie::get($v);
  239. if ($temp && strlen($temp) > 150) {
  240. try {
  241. $temp = decrypt($temp);
  242. } catch (\Exception $e) {
  243. }
  244. if ($v == 'from') {
  245. Cookie::queue('from', $temp, env('U_COOKIE_EXPIRE'), null, null, false, false);
  246. //Cookie::queue($v, $temp);
  247. } else {
  248. Cookie::queue($v, $temp, env('U_COOKIE_EXPIRE'), null, null, false, false);
  249. }
  250. }
  251. }
  252. }
  253. /**
  254. * 公众号签名@华灯初上
  255. * @param $params
  256. * @return string
  257. */
  258. protected function getSign($params, $key)
  259. {
  260. $url = $this->arr_to_url($params, false);
  261. $url = $url . '&key=' . $key;
  262. $sign = md5($url);
  263. return $sign;
  264. }
  265. /**
  266. * 公众号签名@华灯初上
  267. * @param $array
  268. * @param bool $has_sign
  269. * @return string
  270. */
  271. protected function arr_to_url($array, $has_sign = false)
  272. {
  273. ksort($array);
  274. reset($array);
  275. $arg = "";
  276. while (list ($name, $val) = each($array)) {
  277. if ($name == 'sign' && !$has_sign) continue;
  278. if (strpos($name, "_") === 0)
  279. continue;
  280. if (is_array($val))
  281. $val = join(',', $val);
  282. if ($val === "")
  283. continue;
  284. $arg .= $name . "=" . $val . "&";
  285. }
  286. $arg = substr($arg, 0, count($arg) - 2);
  287. return $arg;
  288. }
  289. private function apidAndOpenId($distribution_channel_id, $appid, $openid, $uid)
  290. {
  291. $appid_info = OfficialAccountService::officialAccountByAppid(['appid' => $appid]);
  292. if (!$appid_info)
  293. return false;
  294. if ($appid_info->distribution_channel_id != $distribution_channel_id) {
  295. return false;
  296. }
  297. //ForceSubscribeService::
  298. $res = ForceSubscribeService::forceSubscribeUsersByUid(['uid' => $uid]);
  299. if ($res) return false;
  300. $forcesubuser = ForceSubscribeService::forceSubscribeUsersByOpenid(['openid' => $openid]);
  301. if ($forcesubuser) {
  302. return false;
  303. }
  304. $send_order_id = ReadRecordService::getSendOrderId($uid);
  305. if ($send_order_id) {
  306. try {
  307. Redis::hset('force_subscribe_from_send_order_id', $appid . '_' . $uid, $send_order_id);
  308. } catch (\Exception $e) {
  309. }
  310. }
  311. $user_info = ForceSubscribeService::getUserInfoAll($appid, $openid);
  312. $forcesubuserdata = [
  313. 'appid' => $appid,
  314. 'uid' => $uid,
  315. 'distribution_channel_id' => $distribution_channel_id,
  316. 'last_interactive_time' => date('Y-m-d H:i:s'),
  317. 'openid' => $openid,
  318. 'official_account_id' => 1
  319. ];
  320. if ($user_info) {
  321. isset($user_info['province']) && !empty($user_info['province']) && $forcesubuserdata['province'] = $user_info['province'];
  322. isset($user_info['nickname']) && !empty($user_info['nickname']) && $forcesubuserdata['nickname'] = $user_info['nickname'];
  323. isset($user_info['city']) && !empty($user_info['city']) && $forcesubuserdata['city'] = $user_info['city'];
  324. isset($user_info['country']) && !empty($user_info['country']) && $forcesubuserdata['country'] = $user_info['country'];
  325. isset($user_info['headimgurl']) && !empty($user_info['headimgurl']) && $forcesubuserdata['headimgurl'] = $user_info['headimgurl'];
  326. isset($user_info['sex']) && !empty($user_info['sex']) && $forcesubuserdata['sex'] = $user_info['sex'];
  327. }
  328. ForceSubscribeService::addForceSubscribeUsers($forcesubuserdata);
  329. ForceSubscribeService::tempForceSubscribeUsersLastTimeUpdate([
  330. 'openid' => $openid,
  331. 'last_interactive_time' => date('Y-m-d H:i:s')
  332. ]);
  333. return true;
  334. }
  335. private function getYqChannleIdByAppid($appid)
  336. {
  337. $client = new Client(['timeout' => 3.0]);
  338. $url = 'http://help.imycmh.com/help/getLinkByAppid?appid=' . $appid;
  339. Log::info('getYqChannleIdByAppid url is: ' . $url);
  340. try {
  341. $result = $client->request('get', $url)->getBody()->getContents();
  342. $result = json_decode($result, 1);
  343. Log::info('getYqChannleIdByAppid result is.: ');
  344. Log::info($result);
  345. if (isset($result['data']['link']) && !empty($result['data']['link'])) {
  346. return $result['data']['link'];
  347. }
  348. } catch (\Exception $e) {
  349. }
  350. return '';
  351. }
  352. private function moveUserFromYq($distribution_channel_id, $appid, $openid, $uid)
  353. {
  354. /*//is_yq_move
  355. $channel = ChannelService::getById($distribution_channel_id);
  356. if(!$channel->is_yq_move){
  357. return ;
  358. }
  359. $move_user = YqMove::where('zsy_uid',$uid)->select('zsy_uid')->first();
  360. if($move_user){
  361. return ;
  362. }*/
  363. $client = new Client(['timeout' => 3.0]);
  364. $url = 'http://help.imycmh.com/getUserInfoByOpenid?openid=' . $openid;
  365. try {
  366. $result = $client->request('get', $url)->getBody()->getContents();
  367. if (!$result) {
  368. return;
  369. }
  370. $result = json_decode($result, 1);
  371. $result_data = isset($result['data']) ? $result['data'] : '';
  372. if (!$result_data) {
  373. return;
  374. }
  375. if (isset($result_data['uid']) && !empty($result_data['uid'])) {
  376. //$result_data['read_count'] = 53;
  377. if ($result_data['read_count'] > 50) {
  378. //不补偿
  379. $pay_for_balance = 500;
  380. $data = [
  381. 'yq_uid' => $result_data['uid'],
  382. 'zsy_uid' => $uid,
  383. 'yq_distribution_channel_id' => $result_data['user']['distribution_channel_id'],
  384. 'zsy_distribution_channel_id' => $distribution_channel_id,
  385. 'read_count' => $result_data['read_count'],
  386. 'yq_balance' => $result_data['user']['balance'],
  387. 'is_pay' => 0,
  388. 'pay_for_balance' => $pay_for_balance,
  389. 'openid' => $openid,
  390. 'appid' => $appid
  391. ];
  392. $special = env('YQ_MOVE_SPECIAL');
  393. if ($special && in_array($distribution_channel_id, explode(',', $special))) {
  394. //特殊梳理
  395. $yq_charge_amount = $result_data['order_amoun'];
  396. if ($yq_charge_amount > 30) {
  397. $pay_for_balance = 3000;
  398. } else {
  399. $pay_for_balance = $yq_charge_amount * 100;
  400. }
  401. if ($pay_for_balance < 500) {
  402. $pay_for_balance = 500;
  403. }
  404. if ($pay_for_balance > 3000) {
  405. $pay_for_balance = 3000;
  406. }
  407. $pay_for_balance = (int)$pay_for_balance;
  408. $balance = $pay_for_balance + $result_data['user']['balance'];
  409. $data['pay_for_balance'] = $pay_for_balance;
  410. $data['is_pay'] = 1;
  411. YqMove::create($data);
  412. UserService::addBalance($uid, $balance, 0, $balance);
  413. $flag = false;
  414. if (in_array($distribution_channel_id, [160, 4236, 4237, 4241])) {
  415. //特殊 回复老站
  416. $flag = true;
  417. }
  418. $this->movePush($distribution_channel_id, $pay_for_balance, $appid, $result_data['user']['distribution_channel_id'], $openid, $flag);
  419. } else {
  420. $data['is_pay'] = 1;
  421. YqMove::create($data);
  422. UserService::addBalance($uid, $pay_for_balance, 0, $pay_for_balance);
  423. $this->movePush($distribution_channel_id, $pay_for_balance, $appid, $result_data['user']['distribution_channel_id'], $openid, true);
  424. }
  425. } else {
  426. //补偿
  427. $yq_charge_amount = $result_data['order_amoun'];
  428. if ($yq_charge_amount > 30) {
  429. $pay_for_balance = 3000;
  430. } else {
  431. $pay_for_balance = $yq_charge_amount * 100;
  432. }
  433. if ($pay_for_balance < 500) {
  434. $pay_for_balance = 500;
  435. }
  436. if ($pay_for_balance > 3000) {
  437. $pay_for_balance = 3000;
  438. }
  439. $pay_for_balance = (int)$pay_for_balance;
  440. YqMove::create([
  441. 'yq_uid' => $result_data['uid'],
  442. 'zsy_uid' => $uid,
  443. 'yq_distribution_channel_id' => $result_data['user']['distribution_channel_id'],
  444. 'zsy_distribution_channel_id' => $distribution_channel_id,
  445. 'read_count' => $result_data['read_count'],
  446. 'yq_balance' => $result_data['user']['balance'],
  447. 'is_pay' => 1,
  448. 'pay_for_balance' => $pay_for_balance,
  449. 'openid' => $openid,
  450. 'appid' => $appid
  451. ]);
  452. $balance = $pay_for_balance + $result_data['user']['balance'];
  453. UserService::addBalance($uid, $balance, 0, $balance);
  454. $this->movePush($distribution_channel_id, $pay_for_balance, $appid, $result_data['user']['distribution_channel_id'], $openid);
  455. }
  456. }
  457. } catch (\Exception $e) {
  458. }
  459. }
  460. private function movePush($distribution_channel_id, $pay_for_balance, $appid, $old_channel_id, $openid, $need_old = false)
  461. {
  462. $move_not_need_push_channel_id = env('MOVE_NOT_NEED_PUSH_CHANNEL_ID');
  463. if ($move_not_need_push_channel_id && in_array($distribution_channel_id, explode(',', $move_not_need_push_channel_id))) {
  464. return;
  465. }
  466. $data = [];
  467. if ($pay_for_balance) {
  468. if ($need_old) {
  469. $format = "亲爱的用户:\r\n由于原小说站进行网站维护中,为了让您能够继续阅读更多优质小说,我们将在新站中补偿您%s书币,以表达我们诚挚的歉意\r\n\r\n<a href='%s'>点此进入新站</a>\r\n\r\n<a href='%s'>继续老站阅读</a>";
  470. $url = env('PROTOCOL') . '://site' . encodeDistributionChannelId($distribution_channel_id) . '.' . env('CUSTOM_HOST') . '.com/';
  471. $content = sprintf($format, $pay_for_balance, $url);
  472. } else {
  473. $format = "亲爱的用户:\r\n由于原小说站进行网站维护中,为了让您能够继续阅读更多优质小说,我们将在新站中补偿您%s书币,以表达我们诚挚的歉意\r\n\r\n<a href='%s'>点此进入新站</a>";
  474. $url = env('PROTOCOL') . '://site' . encodeDistributionChannelId($distribution_channel_id) . '.' . env('CUSTOM_HOST') . '.com/';
  475. //$old_url = env('PROTOCOL') . '://site' . encodeDistributionChannelId($old_channel_id) . '.chunnuan555.com/continue';
  476. $old_url = 'http://site' . encodeDistributionChannelId($old_channel_id) . '.imycmh.com/continue';
  477. $content = sprintf($format, $pay_for_balance, $url, $old_url);
  478. }
  479. } else {
  480. $fromat = "亲爱的用户:\r\n%s新增全新站点,新站拥有海量优质小说,同时原先站点可继续看书\r\n<a href='%s'>点此进入新站</a>\r\n\r\n<a href='%s'>继续老站阅读</a>";
  481. $new_url = env('PROTOCOL') . '://site' . encodeDistributionChannelId($distribution_channel_id) . '.' . env('CUSTOM_HOST') . '.com/';
  482. //$old_url = env('PROTOCOL') . '://site' . encodeDistributionChannelId($old_channel_id) . '.chunnuan555.com/continue';
  483. $old_url = 'http://site' . encodeDistributionChannelId($old_channel_id) . '.imycmh.com/continue';
  484. $offical = DB::table('official_accounts')->where('appid', $appid)->select('nickname')->first();
  485. $offical_name = '网站';
  486. if ($offical && $offical->nickname) {
  487. $offical_name = $offical->nickname;
  488. }
  489. $content = sprintf($fromat, $offical_name, $new_url, $old_url);
  490. }
  491. $data['openid'] = $openid;
  492. $data['appid'] = $appid;
  493. $data['content'] = $content;
  494. $data['type'] = 'one_task';
  495. $data['task_id'] = 1;
  496. $data['send_time'] = date("Y-m-d H:i:s");
  497. $send_data = array(
  498. 'send_time' => date("Y-m-d H:i:s"),
  499. 'data' => $data
  500. );
  501. Log::info('movePush info');
  502. Log::info($send_data);
  503. $delay = 0;
  504. $job = (new SendTexts($send_data))->onConnection('rabbitmq')->delay($delay)->onQueue('send_texts_list');
  505. dispatch($job);
  506. }
  507. private function smartPush(Request $request, $uid)
  508. {
  509. $bid = $request->get('bid');
  510. $fromsource = $request->get('fromsource');
  511. if (!$fromsource || !$bid) {
  512. return;
  513. }
  514. if ($fromsource != 'smart_push') {
  515. return;
  516. }
  517. $decode_bid_array = Hashids::decode($bid);
  518. if (!$decode_bid_array)
  519. return;
  520. $decode_bid = 0;
  521. if (isset($decode_bid_array[0]) && !empty($decode_bid_array[0])) {
  522. $decode_bid = $decode_bid_array[0];
  523. }
  524. if (!$decode_bid)
  525. return;
  526. //记录pv uv
  527. try {
  528. $uv_key = sprintf('%s_%s_uv', $decode_bid, 'smart_push');
  529. Redis::sadd($uv_key, $uid);
  530. Redis::HINCRBY('smart_push_test_book', $decode_bid, 1);
  531. ReadRecordService::setSmartPush($uid, $decode_bid);
  532. } catch (\Exception $e) {
  533. Log::info($e);
  534. }
  535. }
  536. protected function notAccessPage()
  537. {
  538. return '<html><head><meta charset=utf-8><meta name=viewport content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no"><title>网站正在维护中</title></head><body style="padding:0;margin:0;font-size:0"><div style="width:300px;height:100px;margin: 20px auto"><p style="font-size:20px;color:red;text-align:center">网站正在维护中,请联系客服</p><img src="" width=300px ></div></body></html>';
  539. }
  540. private function fromTitleImage(Request $request, $uid)
  541. {
  542. $from_title_image = $request->get('from_title_image');
  543. if ($from_title_image) {
  544. $key = 'smart_push_from_title_image:' . $from_title_image;
  545. try {
  546. Redis::hincrby($key, 'click_num', 1);
  547. Redis::sadd('smart_push_from_title_image_click_uv:' . $from_title_image, $uid);
  548. } catch (\Exception $e) {
  549. }
  550. }
  551. }
  552. //短片推唱片
  553. private function dataAnalysis(Request $request, $uid)
  554. {
  555. if (!$request->has('ru')) {
  556. return;
  557. }
  558. $su = $request->get('ru');
  559. if (!$su) return;
  560. $su_array = explode('_', $su);
  561. if (count($su_array) !== 2) {
  562. return;
  563. }
  564. $data = [];
  565. $arr = ['title' => 1, 'over' => 2];
  566. if (isset($arr[$su_array[0]])) {
  567. $data['type'] = $arr[$su_array[0]];
  568. $data['material_id'] = $su_array[1];
  569. $data['uid'] = $uid;
  570. $data['created_at'] = $data['updated_at'] = date('Y-m-d H:i:s');
  571. try {
  572. DB::table('data_analysis_visit_stats')->insert($data);
  573. } catch (\Exception $e) {
  574. }
  575. }
  576. }
  577. /**
  578. * 临时统计
  579. * @param Request $request
  580. * @param $uid
  581. */
  582. private function tempFromWhere(Request $request, $uid)
  583. {
  584. $temp_from_where = env('TEMP_FROM_WHERE');
  585. if (!$temp_from_where) {
  586. return;
  587. }
  588. $from_where = $request->get('fromwhere');
  589. if (!$from_where) {
  590. return;
  591. }
  592. $url = $request->get('_url', '0');
  593. if (stripos($url, 'reader') !== false) {
  594. $temp_from_where_start_end = explode(',', $temp_from_where);
  595. if (count($temp_from_where_start_end) == 2) {
  596. if (time() > $temp_from_where_start_end[0] && time() < $temp_from_where_start_end[1]) {
  597. try {
  598. Redis::sadd('temp_from_where:' . $from_where, $uid);
  599. } catch (\Exception $e) {
  600. }
  601. return;
  602. }
  603. }
  604. }
  605. return;
  606. }
  607. private function recordPrimaryNumberChannleIDUser($distribution_channel_id, $uid)
  608. {
  609. if (!is_numeric($distribution_channel_id)) {
  610. return;
  611. }
  612. try {
  613. Redis::sadd('recordPrimaryNumberChannleIDUser', $uid);
  614. } catch (\Exception $e) {
  615. }
  616. }
  617. /**
  618. * 禁止site+数字站点的访问 保留已经充值过的用户和4267站点所有用户
  619. * true禁止 false 不禁止
  620. * @param $distribution_channel_id
  621. * @return bool
  622. */
  623. private function isForbidPrimaryNumberChannleID($distribution_channel_id, $uid)
  624. {
  625. $forbid_primary_number_channel_id = env('FORBID_PRIMARY_NUMBER_CHANNEL_ID', '14,2,4267');
  626. if (is_numeric($distribution_channel_id) &&
  627. !in_array($distribution_channel_id, explode(',', $forbid_primary_number_channel_id)) &&
  628. !DB::table('orders')->where('uid', $uid)->where('status', 'PAID')->first()
  629. ) {
  630. return true;
  631. }
  632. return false;
  633. }
  634. /**
  635. * 特殊渠道的授权登陆
  636. * @param Request $request
  637. * @return string
  638. */
  639. private function authV2(Request $request, $channel_id)
  640. {
  641. if (!$request->has('auth')) return '';
  642. $auth = $request->get('auth');
  643. if ($auth != 'v2') {
  644. return '';
  645. }
  646. $h5_scheme = env('PROTOCOL', 'https');
  647. $domain = _domain();
  648. $params['redirect_url'] = urlencode($h5_scheme . '://' . $domain . '/oauthCallBackV2');
  649. $params['timestamp'] = time();
  650. $info = specialChannelAuthInfo();
  651. if (!$info || !isset($info[$channel_id])) {
  652. return '';
  653. }
  654. $appid = $info[$channel_id];
  655. if (!$appid) {
  656. return '';
  657. }
  658. $params['gzh_app_id'] = $appid;
  659. $params['sign'] = $this->getSign($params, env('OAUTH_KEY'));
  660. $redirect = env('AUTH_URL') . '?' . http_build_query($params);
  661. return $redirect;
  662. }
  663. /**
  664. * @param Request $request
  665. * @param $channel_id
  666. * @return string
  667. */
  668. private function auth(Request $request, $channel_id)
  669. {
  670. $appid = env('WECHAT_AUTH_APPID');
  671. $h5_scheme = env('PROTOCOL', 'https');
  672. $domain = _domain();
  673. $params['redirect_url'] = urlencode($h5_scheme . '://' . $domain . '/oauthCallBack');
  674. $params['timestamp'] = time();
  675. $info = specialChannelAuthInfoV2();
  676. if ($info && isset($info[$channel_id]) && !empty($info[$channel_id])) {
  677. $appid = $info[$channel_id];
  678. }
  679. $params['gzh_app_id'] = $appid;
  680. $params['sign'] = $this->getSign($params, env('OAUTH_KEY'));
  681. $redirect = env('AUTH_URL') . '?' . http_build_query($params);
  682. return $redirect;
  683. }
  684. private function yqTest(Request $request, $uid,$channel_id)
  685. {
  686. if (!$request->has('fromtype')) return '';
  687. $from_type = $request->get('fromtype');
  688. if(empty($from_type)){
  689. return '';
  690. }
  691. if($from_type == 'main'){
  692. return '';
  693. }
  694. if($request->has('r') ){
  695. return '';
  696. }
  697. //Log::info('1111111111111111111111111111111');
  698. $param = $request->except('_url');
  699. if (isset($param['bid'])) unset($param['bid']);
  700. if(isset($param['cid'])) unset($param['cid']);
  701. //unset($param['from_type']);
  702. $other_str = 'r=1';
  703. if($param){
  704. $other_str = http_build_query($param).'&'.$other_str;
  705. }
  706. //$uri = $request->input('_url');
  707. $bid = $request->get('bid');
  708. if (!$bid) return '';
  709. try {
  710. $bid_arr = Hashids::decode($bid);
  711. isset($bid_arr[0]) && $bid = $bid_arr[0];
  712. } catch (\Exception $e) {
  713. return '';
  714. }
  715. //Log::info('222222222222222222222222222222');
  716. if (!$bid) return '';
  717. //Log::info('333333333333333333333333333333');
  718. //用户是否在样本中
  719. $yq_book_user = BookUserService::selectUser($uid);
  720. if (!$yq_book_user) {
  721. return '';
  722. }
  723. $flag = $yq_book_user->flag;
  724. if(empty($flag)){
  725. return '';
  726. }
  727. //Log::info('44444444444444444444444444444');
  728. //如果是group_1 不错操作
  729. if($flag == 'group_1'){
  730. YqUserBidRelationService::create($uid,$bid,'GROUP_1',0);
  731. if ($yq_book_user->type == 'INIT'){
  732. BookUserService::updateUser($uid, ['type'=>'GROUP_1']);
  733. }
  734. return '';
  735. }
  736. //Log::info('5555555555555555555555555555');
  737. if($flag != 'group_2'){
  738. return '';
  739. }
  740. //Log::info('66666666666666666666666666666');
  741. //用户的类型是初始类型 区域还没获取
  742. if ($yq_book_user->type == 'INIT') {
  743. if(isset($_SERVER['HTTP_X_FORWARDED_FOR']) && $_SERVER['HTTP_X_FORWARDED_FOR']){
  744. $ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
  745. }else{
  746. $ip = get_client_ip();
  747. }
  748. $area = $this->getIpArea($ip);
  749. $area = $area ? $area : 'unknown';
  750. $type = $this->isLimit($area);
  751. $data = ['area' => $area, 'type' => $type];
  752. if ('ENABLE' == $type) {
  753. $yq_zsy_test = YqZsyTestService::getByBid($bid);
  754. if ($yq_zsy_test) {
  755. YqUserBidRelationService::create($uid,$bid,'GROUP_2',$bid);
  756. //书在测试列表中
  757. $data['bid'] = $bid;
  758. BookUserService::updateUser($uid, $data);
  759. return '';
  760. }
  761. //Log::info('7777777777777777777777777');
  762. //书不在在测试列表中
  763. //获取随机获取一本书,获取不到则返回
  764. $redirect_bids = YqZsyTestService::getRandomBooks($uid,1);
  765. $redirect_bid = 0;
  766. if ($redirect_bids && isset($redirect_bids[0])) {
  767. $redirect_bid = $redirect_bids[0];
  768. }
  769. if (!$redirect_bid) {
  770. BookUserService::updateUser($uid, $data);
  771. return '';
  772. };
  773. //Log::info('88888888888888888888888888');
  774. //Log::info($redirect_bids);
  775. $redirect_book_info = BookConfigService::getBookById($redirect_bid);
  776. if ($redirect_book_info) {
  777. $redirect = $this->getBookReaderUrl($redirect_bid,$channel_id);
  778. if($redirect){
  779. $data['bid'] = $redirect_bid;
  780. }
  781. YqUserBidRelationService::create($uid,$bid,'GROUP_2',$redirect_bid);
  782. BookUserService::updateUser($uid, $data);
  783. return $redirect.'&'.$other_str;
  784. }
  785. //Log::info('9999999999999999999999999');
  786. return '';
  787. }
  788. if ('DISABLED' == $type) {
  789. //禁止访问的区域
  790. BookUserService::updateUser($uid, $data);
  791. BookUserService::popUser($uid);
  792. return '';
  793. }
  794. //Log::info('aaaaaaaaaaaaaaaaaaaaaaaaaaaaa');
  795. }
  796. if($yq_book_user->type == 'DISABLED'){
  797. return '';
  798. }
  799. //Log::info('bbbbbbbbbbbbbbbbbbbbbbbbbbbbbb');
  800. $yq_zsy_test = YqZsyTestService::getByBid($bid);
  801. //如果书在测试样本中 不跳转
  802. if ($yq_zsy_test) {
  803. YqUserBidRelationService::create($uid,$bid,'GROUP_2',0);
  804. return '';
  805. }
  806. //Log::info('ccccccccccccccccccccccccccccc');
  807. // 用户符合条件 且看的书不样本中
  808. $relate_info = YqUserBidRelationService::getByUidAndBid($uid,$bid);
  809. if($relate_info && $relate_info->to_bid){
  810. //已经有对应关系
  811. //如果有阅读记录
  812. $record_url = $this->readerRecpord($uid,$relate_info->to_bid,$channel_id);
  813. if($record_url) return $record_url.'&'.$other_str;
  814. //没有阅读记录
  815. $book_url = $this->getBookReaderUrl($relate_info->to_bid,$channel_id);
  816. //Log::info('dddddddddddddddddddddddddd');
  817. //Log::info($book_url.'&'.$other_str);
  818. return $book_url.'&'.$other_str;
  819. }else{
  820. //没有对应关系
  821. //随机获取一本书
  822. $redirect_bids = YqZsyTestService::getRandomBooks($uid,1);
  823. $redirect_bid = 0;
  824. if ($redirect_bids && isset($redirect_bids[0])) {
  825. $redirect_bid = $redirect_bids[0];
  826. }
  827. if (!$redirect_bid) {
  828. return '';
  829. };
  830. //Log::info('eeeeeeeeeeeeeeeeeeeeeeeeeeeee');
  831. $redirect = $this->getBookReaderUrl($redirect_bid,$channel_id);
  832. if($redirect){
  833. $data['bid'] = $redirect_bid;
  834. //更新对应关系
  835. BookUserService::updateUser($uid, $data);
  836. //Log::info('ffffffffffffffffffffffff');
  837. YqUserBidRelationService::create($uid,$bid,'GROUP_2',$redirect_bid);
  838. return $redirect.'&'.$other_str;
  839. }
  840. //Log::info('gggggggggggggggggggggggggggggggg');
  841. return '';
  842. }
  843. }
  844. private function getBookReaderUrl($bid,$channel_id){
  845. $redirect_book_info = BookConfigService::getBookById($bid);
  846. if ($redirect_book_info) {
  847. //Log::info('getBookReaderUrl');
  848. //Log::info($redirect_book_info);
  849. $redirect = sprintf(
  850. 'https://site%s.iycdm.com/reader?bid=%s&cid=%s',
  851. encodeDistributionChannelId($channel_id),
  852. Hashids::encode($bid),
  853. $redirect_book_info->first_cid
  854. );
  855. return $redirect;
  856. }
  857. return '';
  858. }
  859. private function readerRecpord($uid,$bid,$channel_id){
  860. $record_info = null;
  861. try {
  862. $record_info = ReadRecordService::getRecordByUidBid($uid, $bid);
  863. } catch (\Exception $e) {
  864. return '';
  865. }
  866. if (!$record_info) return '';
  867. $record_info_arr = explode('_', $record_info);
  868. if (isset($record_info_arr[0])) {
  869. $cid = $record_info_arr[0];
  870. if(!$cid) return '';
  871. $redirect = sprintf(
  872. 'https://site%s.iycdm.com/reader?bid=%s&cid=%s',
  873. encodeDistributionChannelId($channel_id),
  874. Hashids::encode($bid),
  875. $cid
  876. );
  877. return $redirect;
  878. }
  879. return '';
  880. }
  881. private function isLimit($area)
  882. {
  883. if($area == 'unknown'){
  884. return 'DISABLED';
  885. }
  886. $limit_area = ['上海', '北京','杭州','南京','广州'];
  887. foreach ($limit_area as $a) {
  888. Log::info('$area: '.$area.',$a: '.$a.PHP_EOL);
  889. if (mb_strpos($area, $a) !== false) {
  890. return 'DISABLED';
  891. }
  892. }
  893. return 'ENABLE';
  894. }
  895. private function getIpArea($ip)
  896. {
  897. $client = new Client(['timeout' => 3.0]);
  898. $url = 'http://apis.juhe.cn/ip/ip2addr?key=5cb679e201b214cf70106e4bf09ab576&ip=' . $ip;
  899. $result = null;
  900. try {
  901. $result = $client->request('get', $url)->getBody()->getContents();
  902. } catch (\Exception $e) {
  903. return '';
  904. }
  905. if (!$result) return '';
  906. $result = json_decode($result, 1);
  907. $area = '';
  908. if (isset($result['result']) && !empty($result['result']) && isset($result['result']['area'])) {
  909. $area = $result['result']['area'];
  910. }
  911. return $area;
  912. }
  913. }