user_helper.php 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: stanley-king
  5. * Date: 16/4/17
  6. * Time: 下午6:46
  7. */
  8. class user_helper
  9. {
  10. const mobile_login = 1;
  11. const wxopen_login = 2;
  12. const mobile_len = 11;
  13. static public function mobile_valid($mobile)
  14. {
  15. if(isset($mobile) || empty($mobile) || strlen($mobile) < self::mobile_len) {
  16. return false;
  17. }
  18. $mobile = substr($mobile,-self::mobile_len);
  19. $validate = new Validate();
  20. $validate->setValidate(Validate::verify_mobile($mobile));
  21. $err = $validate->validate();
  22. if(empty($err)) {
  23. return $mobile;
  24. } else {
  25. return false;
  26. }
  27. }
  28. static public function nickname()
  29. {
  30. if(isset($_SESSION['member_nickname']) && !empty($_SESSION['member_nickname'])) {
  31. return $_SESSION['member_nickname'];
  32. }
  33. if(isset($_SESSION['member_truename']) && !empty($_SESSION['member_truename'])) {
  34. return $_SESSION['member_truename'];
  35. }
  36. if(isset($_SESSION['member_mobile']) && !empty($_SESSION['member_mobile']))
  37. {
  38. $mobile = $_SESSION['member_mobile'];
  39. if(strlen($mobile) == 11) {
  40. $arData = str_split($mobile,4);
  41. return sprintf("mob%s****%s",$arData[0],$arData[2]);
  42. }
  43. }
  44. return '';
  45. }
  46. static public function isLogin()
  47. {
  48. return ($_SESSION['is_login'] == 1);
  49. }
  50. static public function isVerfiyMobile()
  51. {
  52. if(self::isLogin()) {
  53. return true;
  54. }
  55. else
  56. {
  57. if(isset($_SESSION['member_mobile']) && !empty($_SESSION['member_mobile'])) {
  58. return true;
  59. } else {
  60. return false;
  61. }
  62. }
  63. }
  64. static public function cur_mobile()
  65. {
  66. if(self::isVerfiyMobile()) {
  67. return $_SESSION['member_mobile'];
  68. } else {
  69. return '';
  70. }
  71. }
  72. static public function parase_wxinfo($wxinfo)
  73. {
  74. $user = urldecode($wxinfo);
  75. if(empty($user)) return false;
  76. $user = json_decode($user,true);
  77. if($user == false) return false;
  78. $info = array();
  79. $info['member_nickname'] = $user['nickname'];
  80. $info['member_avatar'] = $user['headimgurl'];
  81. $info['member_sex'] = intval($user['sex']);
  82. return $info;
  83. }
  84. static public function filter_info($info)
  85. {
  86. $member_info = array();
  87. if(isset($info['member_nickname']) && !empty($info['member_nickname'])) {
  88. $member_info['member_nickname'] = $info['member_nickname'];
  89. }
  90. if(isset($info['member_truename']) && !empty($info['member_truename'])) {
  91. if(!isset($member_info['member_nickname'])) {
  92. $member_info['member_nickname'] = $info['member_truename'];
  93. }
  94. $member_info['member_truename'] = $info['member_truename'];
  95. }
  96. if(isset($info['member_mobile']) && !empty($info['member_mobile']))
  97. {
  98. $mobile = $info['member_mobile'];
  99. if(!isset($member_info['member_nickname'])) {
  100. $member_info['member_nickname'] = substr_replace($mobile, '****', 3, 4);
  101. }
  102. $member_info['member_mobile'] = $info['member_mobile'];
  103. }
  104. return $member_info;
  105. }
  106. static public function notify_soon_expired_bonus($warn_remain_days, $warn_interval_days)
  107. {
  108. $user_bonus_model = Model("user_bonus");
  109. $expired_list = $user_bonus_model->getNeedWarn($warn_remain_days, $warn_interval_days);
  110. $bonus_ids = array();
  111. foreach ($expired_list as $key => $val) {
  112. $user_id = $val["user_id"];
  113. $remain_days = intval($val["seconds"]) < 86400 ? 1 : (intval($val["seconds"]) / 86400) + 1;
  114. $param = array();
  115. $param['member_id'] = $user_id;
  116. $param['text'] = "红包过期通知:您领取的红包将在{$remain_days}天内过期.";
  117. $param['go_type'] = 'bonus';
  118. QueueClient::push('upushSendMsg', $param);
  119. $bonus_ids[] = $val["bonus_id"];
  120. }
  121. if (!empty($bonus_ids))
  122. {
  123. $user_bonus_model->where(array('bonus_id' => array('in', $bonus_ids)))->update(array("notify_time" => 'unix_timestamp(now())'));
  124. }
  125. }
  126. static public function notify_already_expired_bonus()
  127. {
  128. $user_bonus_model = Model("user_bonus");
  129. $expired_list = $user_bonus_model->get_already_expired_bonus();
  130. $bonus_ids = array();
  131. foreach ($expired_list as $key => $val) {
  132. $user_id = $val["user_id"];
  133. $param = array();
  134. $param['member_id'] = $user_id;
  135. $param['text'] = "红包过期通知:您领取的红包已经过期.";
  136. $param['go_type'] = 'bonus';
  137. QueueClient::push('upushSendMsg', $param);
  138. $bonus_ids[] = $val["bonus_id"];
  139. }
  140. if (!empty($bonus_ids))
  141. {
  142. $user_bonus_model->where(array('bonus_id' => array('in', $bonus_ids)))->delete();
  143. }
  144. }
  145. static public function filter_member_info($member_info,$openid)
  146. {
  147. field_helper::validate_null_string($member_info, 'member_mobile,member_wxopenid,member_name,' .
  148. 'member_truename,member_signname,member_avatar,member_email,member_birthday');
  149. field_helper::validate_null_string($member_info, 'member_sex', '0');
  150. field_helper::validate_null_string($member_info, 'member_nickname', substr_replace($openid, '****', 3, 4));
  151. return $member_info;
  152. }
  153. static public function register_login($mobile,$password)
  154. {
  155. if($_SESSION['is_login'] == 1) {
  156. return false;
  157. }
  158. $mod_member = Model('member');
  159. $info = $mod_member->getMemberInfo(array('member_mobile' => $mobile));
  160. if(empty($info))
  161. {
  162. $member_info = array('member_mobile' => $mobile,
  163. 'member_type' => self::mobile_login,
  164. 'member_passwd' => $password,
  165. 'member_sex' => 0,
  166. 'member_name' => $mobile,
  167. 'member_nickname' => substr_replace($mobile, '****', 3, 4),
  168. 'member_mobile_bind' => 1);
  169. $member_id = $mod_member->addMember($member_info);
  170. if ($member_id != false) {
  171. sms_helper::send_nostore_message($mobile, Sms::bindbonus_register_code, $password);
  172. $info = $mod_member->getMemberInfo(array('member_mobile' => $mobile));
  173. relation_helper::onRegister($member_id);
  174. } else {
  175. return false;
  176. }
  177. }
  178. $member_info = self::filter_member_info($info,$info['momber_mobile']);
  179. $mod_member->createSession($member_info);
  180. Model('cart')->mergecart($member_info, $_SESSION['store_id']);
  181. Model('goods_browse')->mergebrowse($_SESSION['member_id'], $_SESSION['store_id']);
  182. return self::outsuccess(array('HPHPSESSID' => $_SESSION['MPHPSESSID']));
  183. }
  184. }