修改代码格式;
数据库查询加 lean 判断; 其它内容微调。
This commit is contained in:
@@ -10,70 +10,65 @@ import { index, getModelForClass, prop } from '@typegoose/typegoose';
|
||||
@index({ uid: 1 })
|
||||
export default class User extends BaseModel {
|
||||
|
||||
@prop({ required: true})
|
||||
@prop({ required: true })
|
||||
uid: number;
|
||||
|
||||
@prop({ required: true})
|
||||
@prop({ required: true })
|
||||
username: string;
|
||||
|
||||
@prop({ required: true})
|
||||
@prop({ required: true })
|
||||
token: string;
|
||||
|
||||
@prop({ required: true})
|
||||
@prop({ required: true })
|
||||
tel: string;
|
||||
|
||||
@prop({ required: true})
|
||||
@prop({ required: true })
|
||||
telHash: string;
|
||||
|
||||
@prop({ required: true})
|
||||
@prop({ required: true })
|
||||
lastLoginTime: Date;
|
||||
|
||||
@prop({ required: true})
|
||||
@prop({ required: true })
|
||||
createTime: Date;
|
||||
|
||||
// 平台:ios, android, web, pc
|
||||
@prop({ required: true})
|
||||
@prop({ required: true })
|
||||
platform: string;
|
||||
|
||||
@prop({ required: true})
|
||||
@prop({ required: true })
|
||||
pkgName: string;
|
||||
|
||||
// 服务器类型:official, channel, ios, oversea
|
||||
@prop({ required: true})
|
||||
@prop({ required: true })
|
||||
serverType: string;
|
||||
|
||||
public static async createUser() {
|
||||
|
||||
}
|
||||
|
||||
public static async updateToken(tel: string, token: string, platform: string, pkgName: string, serverType: string) {
|
||||
let user = await UserModel.findOne({tel}).lean();
|
||||
public static async updateToken(tel: string, token: string, platform: string, pkgName: string, serverType: string, lean = true) {
|
||||
let user = await UserModel.findOne({ tel }).lean();
|
||||
const curTime: Date = new Date();
|
||||
let update = {};
|
||||
if (!user) {
|
||||
const uid = await CounterModel.getNewCounter(COUNTER.UID);
|
||||
update = Object.assign(update, {platform, pkgName, serverType, createTime: curTime, uid, username: `用户${uid}`});
|
||||
update = Object.assign(update, { platform, pkgName, serverType, createTime: curTime, uid, username: `用户${uid}` });
|
||||
}
|
||||
update = Object.assign(update, {token, lastLoginTime: curTime});
|
||||
user = await UserModel.findOneAndUpdate({tel}, update, {upsert: true, new: true}).lean();
|
||||
update = Object.assign(update, { token, lastLoginTime: curTime });
|
||||
user = await UserModel.findOneAndUpdate({ tel }, update, { upsert: true, new: true }).lean(lean);
|
||||
return user;
|
||||
}
|
||||
|
||||
public static async findUserByToken(token: string) {
|
||||
const user = await UserModel.findOne({token}).select('uid token').lean();
|
||||
public static async findUserByToken(token: string, lean = true) {
|
||||
const user = await UserModel.findOne({ token }).select('uid token').lean(lean);
|
||||
return user;
|
||||
}
|
||||
|
||||
public static async findUserByTel(tel: string) {
|
||||
const user = await UserModel.findOne({tel}).select('uid tel').lean();
|
||||
public static async findUserByTel(tel: string, lean = true) {
|
||||
const user = await UserModel.findOne({ tel }).select('uid tel').lean(lean);
|
||||
return user;
|
||||
}
|
||||
|
||||
public static async findUserByUid(uid: number) {
|
||||
const user = await UserModel.findOne({uid}).select('uid tel').lean();
|
||||
public static async findUserByUid(uid: number, lean = true) {
|
||||
const user = await UserModel.findOne({ uid }).select('uid tel').lean(lean);
|
||||
return user;
|
||||
}
|
||||
//#endregion
|
||||
}
|
||||
|
||||
export const UserModel = getModelForClass(User);
|
||||
export const UserModel = getModelForClass(User);
|
||||
|
||||
Reference in New Issue
Block a user