feat(wip): 聯絡人
This commit is contained in:
@@ -8,6 +8,9 @@ export type CallMethod =
|
|||||||
"User.setAvatar" |
|
"User.setAvatar" |
|
||||||
"User.getMyInfo" |
|
"User.getMyInfo" |
|
||||||
|
|
||||||
|
"User.getMyContactGroups" |
|
||||||
|
"User.setMyContactGroups" |
|
||||||
|
|
||||||
"Chat.getInfo" |
|
"Chat.getInfo" |
|
||||||
"Chat.sendMessage" |
|
"Chat.sendMessage" |
|
||||||
"Chat.getMessageHistory"
|
"Chat.getMessageHistory"
|
||||||
|
|||||||
@@ -195,6 +195,50 @@ export default class UserApi extends BaseApi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
// 獲取聯絡人列表
|
||||||
|
this.registerEvent("User.getMyContactGroups", (args) => {
|
||||||
|
if (this.checkArgsMissing(args, ['token'])) return {
|
||||||
|
msg: "參數缺失",
|
||||||
|
code: 400,
|
||||||
|
}
|
||||||
|
|
||||||
|
const token = TokenManager.decode(args.token as string)
|
||||||
|
if (!this.checkToken(token)) return {
|
||||||
|
code: 401,
|
||||||
|
msg: "令牌無效",
|
||||||
|
}
|
||||||
|
|
||||||
|
const user = User.findById(token.author)
|
||||||
|
|
||||||
|
return {
|
||||||
|
msg: "成功",
|
||||||
|
code: 200,
|
||||||
|
data: {
|
||||||
|
contact_groups: user!.getContactGroups()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
// 更新聯絡人列表
|
||||||
|
this.registerEvent("User.setMyContactGroups", (args) => {
|
||||||
|
if (this.checkArgsMissing(args, ['token', 'contact_groups'])) return {
|
||||||
|
msg: "參數缺失",
|
||||||
|
code: 400,
|
||||||
|
}
|
||||||
|
|
||||||
|
const token = TokenManager.decode(args.token as string)
|
||||||
|
if (!this.checkToken(token)) return {
|
||||||
|
code: 401,
|
||||||
|
msg: "令牌無效",
|
||||||
|
}
|
||||||
|
|
||||||
|
const user = User.findById(token.author)
|
||||||
|
user!.setContactGroups(args.contact_groups as { [key: string]: string[] })
|
||||||
|
|
||||||
|
return {
|
||||||
|
msg: "成功",
|
||||||
|
code: 200,
|
||||||
|
}
|
||||||
|
})
|
||||||
/*
|
/*
|
||||||
* ================================================
|
* ================================================
|
||||||
* 公開資料
|
* 公開資料
|
||||||
|
|||||||
@@ -33,27 +33,28 @@ export default class User {
|
|||||||
/* 用戶名, 可選 */ username TEXT,
|
/* 用戶名, 可選 */ username TEXT,
|
||||||
/* 昵称 */ nickname TEXT NOT NULL,
|
/* 昵称 */ nickname TEXT NOT NULL,
|
||||||
/* 头像, 可选 */ avatar_file_hash TEXT,
|
/* 头像, 可选 */ avatar_file_hash TEXT,
|
||||||
|
/* 聯絡人組 */ contact_groups TEXT NOT NULL,
|
||||||
/* 设置 */ settings TEXT NOT NULL
|
/* 设置 */ settings TEXT NOT NULL
|
||||||
);
|
);
|
||||||
`)
|
`)
|
||||||
return db
|
return db
|
||||||
}
|
}
|
||||||
|
|
||||||
static createWithUserNameChecked(userName: string | null, password: string, nickName: string, avatar: Buffer | null) {
|
static createWithUserNameChecked(userName: string | null, password: string, nickName: string, avatar: Buffer | null) {
|
||||||
if (userName && User.findAllBeansByCondition('username = ?', userName).length > 0)
|
if (userName && User.findAllBeansByCondition('username = ?', userName).length > 0)
|
||||||
throw new DataWrongError(`用户名 ${userName} 已存在`)
|
throw new DataWrongError(`用户名 ${userName} 已存在`)
|
||||||
return User.create(
|
return User.create(
|
||||||
userName,
|
userName,
|
||||||
password,
|
password,
|
||||||
nickName,
|
nickName,
|
||||||
avatar
|
avatar
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
static create(userName: string | null, password: string, nickName: string, avatar: Buffer | null) {
|
static create(userName: string | null, password: string, nickName: string, avatar: Buffer | null) {
|
||||||
const user = new User(
|
const user = new User(
|
||||||
User.findAllBeansByCondition(
|
User.findAllBeansByCondition(
|
||||||
'count = ?',
|
'count = ?',
|
||||||
User.database.prepare(`INSERT INTO ${User.table_name} (
|
User.database.prepare(`INSERT INTO ${User.table_name} (
|
||||||
id,
|
id,
|
||||||
password,
|
password,
|
||||||
@@ -61,22 +62,29 @@ export default class User {
|
|||||||
username,
|
username,
|
||||||
nickname,
|
nickname,
|
||||||
avatar_file_hash,
|
avatar_file_hash,
|
||||||
|
contact_groups,
|
||||||
settings
|
settings
|
||||||
) VALUES (?, ?, ?, ?, ?, ?, ?);`).run(
|
) VALUES (?, ?, ?, ?, ?, ?, ?, ?);`).run(
|
||||||
crypto.randomUUID(),
|
crypto.randomUUID(),
|
||||||
password,
|
password,
|
||||||
Date.now(),
|
Date.now(),
|
||||||
userName,
|
userName,
|
||||||
nickName,
|
nickName,
|
||||||
null,
|
null,
|
||||||
|
'{}',
|
||||||
"{}"
|
"{}"
|
||||||
).lastInsertRowid
|
).lastInsertRowid
|
||||||
)[0]
|
)[0]
|
||||||
)
|
)
|
||||||
avatar && user.setAvatar(avatar)
|
avatar && user.setAvatar(avatar)
|
||||||
|
user.setContactGroups({
|
||||||
|
默認: [
|
||||||
|
user.bean.id
|
||||||
|
]
|
||||||
|
})
|
||||||
return user
|
return user
|
||||||
}
|
}
|
||||||
|
|
||||||
private static findAllBeansByCondition(condition: string, ...args: SQLInputValue[]): UserBean[] {
|
private static findAllBeansByCondition(condition: string, ...args: SQLInputValue[]): UserBean[] {
|
||||||
return User.database.prepare(`SELECT * FROM ${User.table_name} WHERE ${condition};`).all(...args) as unknown as UserBean[]
|
return User.database.prepare(`SELECT * FROM ${User.table_name} WHERE ${condition};`).all(...args) as unknown as UserBean[]
|
||||||
}
|
}
|
||||||
@@ -96,7 +104,7 @@ export default class User {
|
|||||||
console.error(chalk.red(`警告: 查询 username = ${userName} 时, 查询到多个相同用户名的用户`))
|
console.error(chalk.red(`警告: 查询 username = ${userName} 时, 查询到多个相同用户名的用户`))
|
||||||
return new User(beans[0])
|
return new User(beans[0])
|
||||||
}
|
}
|
||||||
|
|
||||||
declare bean: UserBean
|
declare bean: UserBean
|
||||||
constructor(bean: UserBean) {
|
constructor(bean: UserBean) {
|
||||||
this.bean = bean
|
this.bean = bean
|
||||||
@@ -112,6 +120,21 @@ export default class User {
|
|||||||
setUserName(userName: string) {
|
setUserName(userName: string) {
|
||||||
this.setAttr("username", userName)
|
this.setAttr("username", userName)
|
||||||
}
|
}
|
||||||
|
getContactGroups() {
|
||||||
|
try {
|
||||||
|
return JSON.parse(this.bean.contact_groups)
|
||||||
|
} catch (e) {
|
||||||
|
console.log(chalk.yellow(`警告: 聯絡人組解析失敗: ${(e as Error).message}`))
|
||||||
|
return {
|
||||||
|
默認: [
|
||||||
|
this.bean.id
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
setContactGroups(contactGroups: { [key: string]: string[] }) {
|
||||||
|
this.setAttr("contact_groups", JSON.stringify(contactGroups))
|
||||||
|
}
|
||||||
getNickName(): string {
|
getNickName(): string {
|
||||||
return this.bean.nickname
|
return this.bean.nickname
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ export default class UserBean {
|
|||||||
declare registered_time: number
|
declare registered_time: number
|
||||||
declare nickname: string
|
declare nickname: string
|
||||||
declare avatar_file_hash?: string
|
declare avatar_file_hash?: string
|
||||||
|
declare contact_groups: string
|
||||||
declare settings: string
|
declare settings: string
|
||||||
|
|
||||||
[key: string]: unknown
|
[key: string]: unknown
|
||||||
|
|||||||
Reference in New Issue
Block a user