mirror of
https://github.com/YMFE/yapi.git
synced 2025-01-12 12:54:48 +08:00
83 lines
2.2 KiB
JavaScript
83 lines
2.2 KiB
JavaScript
import yapi from '../yapi.js'
|
|
import projectModel from '../models/project.js'
|
|
import userModel from '../models/user.js'
|
|
const jwt = require('jsonwebtoken');
|
|
|
|
|
|
class baseController{
|
|
constructor(ctx){
|
|
|
|
}
|
|
|
|
async init(ctx){
|
|
this.$user = null;
|
|
if(ctx.path === '/user/login' || ctx.path === '/user/reg' || ctx.path === '/user/status'){
|
|
this.$auth = true;
|
|
}else{
|
|
await this.checkLogin(ctx)
|
|
}
|
|
|
|
}
|
|
|
|
getUid(ctx){
|
|
return this.$uid;
|
|
}
|
|
|
|
async checkLogin(ctx){
|
|
let token = ctx.cookies.get('_yapi_token');
|
|
let uid = ctx.cookies.get('_yapi_uid');
|
|
try{
|
|
if(!token || !uid) return false;
|
|
let userInst = yapi.getInst(userModel); //创建user实体
|
|
let result = await userInst.findById(uid);
|
|
let decoded = jwt.verify(token, result.passsalt)
|
|
if(decoded.uid == uid){
|
|
this.$uid = uid;
|
|
this.$auth = true;
|
|
console.log(11111)
|
|
this.$user = result;
|
|
return true;
|
|
}
|
|
return false;
|
|
}catch(e){
|
|
return false;
|
|
}
|
|
|
|
}
|
|
|
|
async getLoginStatus(ctx){
|
|
if(await this.checkLogin(ctx) === true){
|
|
return ctx.body = yapi.commons.resReturn(yapi.commons.fieldSelect(this.$user,['_id','username','email', 'up_time', 'add_time']));
|
|
}
|
|
return ctx.body = yapi.commons.resReturn(null, 400 , 'Please login.');
|
|
|
|
}
|
|
|
|
getRole(){
|
|
return 'admin'
|
|
}
|
|
|
|
async jungeProjectAuth(id){
|
|
let model = yapi.getInst(projectModel);
|
|
if(this.getRole() === 'admin') return true;
|
|
if(!id) return false;
|
|
let result = await model.get(id);
|
|
if(result.uid === this.getUid()){
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
async jungeMemberAuth(id, member_uid){
|
|
let model = yapi.getInst(projectModel);
|
|
if(this.getRole() === 'admin') return true;
|
|
if(!id || !member_uid) return false;
|
|
let result = await model.checkMemberRepeat(id, member_uid);
|
|
if(result > 0){
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
}
|
|
|
|
module.exports = baseController |