123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170 |
- <?php
- namespace app\common\model;
- use think\facade\Db;
- class Inviter extends BaseModel
- {
- public $page_info;
-
- public function addInviter($inviter_array)
- {
- $inviter_id = Db::name('inviter')->insertGetId($inviter_array);
- return $inviter_id;
- }
-
- public function editInviter($condition, $data)
- {
- if (empty($condition)) {
- return false;
- }
- if (is_array($data)) {
- $result = Db::name('inviter')->where($condition)->update($data);
- return $result;
- } else {
- return false;
- }
- }
- public function getInviterInfo($condition, $fields = 'm.member_name,i.*')
- {
- if (empty($condition)) {
- return false;
- }
- $result = Db::name('inviter')->alias('i')->join('member m', 'i.inviter_id=m.member_id')->field($fields)->where($condition)->find();
- return $result;
- }
-
- public function getInviterList($condition = array(), $pagesize = '', $limit = 0, $fields = '*')
- {
- if ($pagesize) {
- $res = Db::name('inviter')->alias('i')->join('member m', 'i.inviter_id=m.member_id')->field($fields)->where($condition)->order('inviter_applytime desc')->paginate(['list_rows' => $pagesize, 'query' => request()->param()], false);
- $this->page_info = $res;
- $result = $res->items();
- } else {
- $result = Db::name('inviter')->alias('i')->join('member m', 'i.inviter_id=m.member_id')->field($fields)->where($condition)->limit($limit)->order('inviter_applytime desc')->select()->toArray();
- }
- return $result;
- }
-
- public function qrcode_weixin($member_info)
- {
- $wx_error_msg = '';
- if (!file_exists(BASE_UPLOAD_PATH . '/' . ATTACH_INVITER . '/' . $member_info['member_id'] . '_weixin.png')) {
- $config = model('wechat')->getOneWxconfig();
- $wechat = new \app\api\controller\WechatApi($config);
- $expire_time = $config['expires_in'];
- if ($expire_time > TIMESTAMP) {
-
- $wechat->access_token_ = $config['access_token'];
- } else {
- $access_token = $wechat->checkAuth();
- $web_expires = TIMESTAMP + 7000;
- Db::name('wxconfig')->where(array('id' => $config['id']))->update(array('access_token' => $access_token, 'expires_in' => $web_expires));
- }
- $return = $wechat->getQRCode($member_info['member_id'], 1);
- if ($return) {
- $refer_qrcode_weixin = $wechat->getQRUrl($return['ticket']);
- if (!is_dir(BASE_UPLOAD_PATH . '/' . ATTACH_INVITER)) {
- mkdir(BASE_UPLOAD_PATH . '/' . ATTACH_INVITER, 0755, true);
- }
- copy($refer_qrcode_weixin, BASE_UPLOAD_PATH . '/' . ATTACH_INVITER . '/' . $member_info['member_id'] . '_weixin.png');
- } else {
- $refer_qrcode_weixin = '';
- $wx_error_msg = $wechat->errMsg;
- }
- } else {
- $refer_qrcode_weixin = UPLOAD_SITE_URL . '/' . ATTACH_INVITER . '/' . $member_info['member_id'] . '_weixin.png';
- }
- return array(
- 'refer_qrcode_weixin' => $refer_qrcode_weixin,
- 'wx_error_msg' => $wx_error_msg,
- );
- }
-
- public function qrcode_logo($member_info)
- {
- !is_dir(BASE_UPLOAD_PATH . '/' . ATTACH_INVITER) && mkdir(BASE_UPLOAD_PATH . '/' . ATTACH_INVITER, 0755, true);
- $qrcode_path = BASE_UPLOAD_PATH . '/' . ATTACH_INVITER . '/' . $member_info['member_id'] . '.png';
- $refer_qrcode_logo = BASE_UPLOAD_PATH . '/' . ATTACH_INVITER . '/' . $member_info['member_id'] . '_poster.png';
- if (!file_exists($qrcode_path)) {
- include_once root_path() . 'extend/qrcode/phpqrcode.php';
- \QRcode::png(config('ds_config.h5_site_url') . '/pages/home/memberregister/Register?inviter_id=' . $member_info['member_id'], $qrcode_path);
- }
- $qrcode = imagecreatefromstring(file_get_contents($qrcode_path));
-
- $inviter_back = imagecreatefromstring(file_get_contents(ds_get_pic(ATTACH_COMMON, config('ds_config.inviter_back'))));
- $QR_width = imagesx($qrcode);
- $QR_height = imagesy($qrcode);
- imagecopyresampled($inviter_back, $qrcode, 100, 170, 0, 0, 160, 160, $QR_width, $QR_height);
- $portrait = imagecreatefromstring(file_get_contents(get_member_avatar_for_id($member_info['member_id'])));
- $QR_width2 = imagesx($portrait);
- $QR_height2 = imagesy($portrait);
- imagecopyresampled($inviter_back, $portrait, 170, 240, 0, 0, 20, 20, $QR_width2, $QR_height2);
-
-
- imagepng($inviter_back, $refer_qrcode_logo);
- }
- }
|