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,6 +33,7 @@ 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
|
||||||
);
|
);
|
||||||
`)
|
`)
|
||||||
@@ -61,19 +62,26 @@ 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
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -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