2020-08-13 08:12:57 +00:00
|
|
|
import store from '../store';
|
|
|
|
import { checkLogin } from './login';
|
|
|
|
import { login } from '../api/public';
|
|
|
|
import Cache from '../utils/cache';
|
|
|
|
import { STATE_R_KEY, USER_INFO, EXPIRES_TIME, LOGIN_STATUS} from './../config/cache';
|
|
|
|
class Routine
|
|
|
|
{
|
|
|
|
|
|
|
|
constructor()
|
|
|
|
{
|
|
|
|
this.scopeUserInfo = 'scope.userInfo';
|
|
|
|
}
|
|
|
|
|
|
|
|
async getUserCode(){
|
|
|
|
let isAuth = await this.isAuth(), code = '' ;
|
|
|
|
if(isAuth)
|
|
|
|
code = await this.getCode();
|
|
|
|
return code;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 获取用户信息
|
|
|
|
*/
|
|
|
|
getUserInfo(){
|
|
|
|
let that = this , code = this.getUserCode();
|
|
|
|
return new Promise( (resolve,reject) => {
|
|
|
|
uni.getUserInfo({
|
|
|
|
lang: 'zh_CN',
|
|
|
|
success(user) {
|
|
|
|
if(code) user.code = code;
|
|
|
|
resolve({userInfo:user,islogin:false});
|
|
|
|
},
|
|
|
|
fail(res){
|
|
|
|
reject(res);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 获取用户信息
|
|
|
|
*/
|
|
|
|
authorize()
|
|
|
|
{
|
|
|
|
let that = this;
|
|
|
|
return new Promise((resolve,reject)=>{
|
|
|
|
if(checkLogin())
|
|
|
|
return resolve({
|
|
|
|
userInfo:Cache.get(USER_INFO,true),
|
|
|
|
islogin:true,
|
|
|
|
});
|
|
|
|
uni.authorize({
|
|
|
|
scope: that.scopeUserInfo,
|
|
|
|
success() {
|
|
|
|
resolve({islogin:false});
|
|
|
|
},
|
|
|
|
fail(res){
|
|
|
|
reject(res);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
async getCode(){
|
|
|
|
let provider = await this.getProvider();
|
|
|
|
return new Promise((resolve,reject)=>{
|
|
|
|
uni.login({
|
|
|
|
provider:provider,
|
|
|
|
success(res) {
|
|
|
|
if (res.code) Cache.set(STATE_R_KEY, res.code ,10800);
|
|
|
|
return resolve(res.code);
|
|
|
|
},
|
|
|
|
fail(){
|
|
|
|
return reject(null);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 获取服务供应商
|
|
|
|
*/
|
|
|
|
getProvider()
|
|
|
|
{
|
|
|
|
return new Promise((resolve,reject)=>{
|
|
|
|
uni.getProvider({
|
|
|
|
service:'oauth',
|
|
|
|
success(res) {
|
|
|
|
resolve(res.provider);
|
|
|
|
},
|
|
|
|
fail() {
|
|
|
|
resolve(false);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 是否授权
|
|
|
|
*/
|
|
|
|
isAuth(){
|
|
|
|
let that = this;
|
|
|
|
return new Promise((resolve,reject)=>{
|
|
|
|
uni.getSetting({
|
|
|
|
success(res) {
|
|
|
|
if (!res.authSetting[that.scopeUserInfo]) {
|
|
|
|
resolve(true)
|
|
|
|
} else {
|
|
|
|
resolve(true);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
fail(){
|
|
|
|
resolve(false);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
authUserInfo(code,data)
|
|
|
|
{
|
2021-03-19 10:26:43 +00:00
|
|
|
console.log('code:',code);
|
|
|
|
console.log('data:',data);
|
2020-08-13 08:12:57 +00:00
|
|
|
return new Promise((resolve, reject)=>{
|
|
|
|
login(code,data).then(res=>{
|
2021-03-19 10:26:43 +00:00
|
|
|
if(res.data.type==='login'){
|
|
|
|
// let time = res.data.expiresTime - Cache.time();
|
|
|
|
store.commit('UPDATE_USERINFO', res.data.user);
|
|
|
|
store.commit('LOGIN', {token:res.data.token});
|
|
|
|
store.commit('SETUID', res.data.user.uid);
|
|
|
|
// Cache.set(EXPIRES_TIME,res.data.expiresTime,time);
|
|
|
|
Cache.set(USER_INFO,res.data.user);
|
|
|
|
}
|
2020-08-13 08:12:57 +00:00
|
|
|
return resolve(res);
|
|
|
|
}).catch(res=>{
|
|
|
|
return reject(res);
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default new Routine();
|