修改代码格式;

数据库查询加 lean 判断;
其它内容微调。
This commit is contained in:
liangtongchuan
2020-08-27 20:01:35 +08:00
parent 940879016f
commit c53db8634d
17 changed files with 710 additions and 323 deletions

View File

@@ -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);