const { findUser } = require('../../lib/utils/account') const { ERROR } = require('../../common/error') const { userCollection } = require('../../common/constants') const PasswordUtils = require('../../lib/utils/password') /** * 修改用户 * @tutorial https://uniapp.dcloud.net.cn/uniCloud/uni-id-pages.html#update-user * @param {Object} params * @param {String} params.uid 要更新的用户id * @param {String} params.username 用户名 * @param {String} params.password 密码 * @param {String} params.nickname 昵称 * @param {Array} params.authorizedApp 允许登录的AppID列表 * @param {Array} params.role 用户角色列表 * @param {String} params.mobile 手机号 * @param {String} params.email 邮箱 * @param {Array} params.tags 用户标签 * @param {Number} params.status 用户状态 * @returns */ module.exports = async function (params = {}) { const schema = { uid: 'string', username: 'username', password: { required: false, type: 'password' }, authorizedApp: { required: false, type: 'array' }, // 指定允许登录的app,传空数组或不传时表示可以不可以在任何端登录 nickname: { required: false, type: 'nickname' }, role: { require: false, type: 'array' }, mobile: { required: false, type: 'mobile' }, email: { required: false, type: 'email' }, tags: { required: false, type: 'array' }, status: { required: false, type: 'number' } } this.middleware.validate(params, schema) const { uid, username, password, authorizedApp, nickname, role, mobile, email, tags, status } = params // 更新的用户数据字段 const data = { username, dcloud_appid: authorizedApp, nickname, role: role, mobile, email, tags: tags, status } const realData = Object.keys(data).reduce((res, key) => { const item = data[key] if (item) { res[key] = item } return res }, {}) // 更新用户名时验证用户名是否重新 if (username) { const { userMatched } = await findUser({ userQuery: { username }, authorizedApp }) if (userMatched.filter(user => user._id !== uid).length) { throw { errCode: ERROR.ACCOUNT_EXISTS } } } if (password) { const passwordUtils = new PasswordUtils({ clientInfo: this.getUniversalClientInfo(), passwordSecret: this.config.passwordSecret }) const { passwordHash, version } = passwordUtils.generatePasswordHash({ password }) data.password = passwordHash data.password_secret_version = version } await userCollection.doc(uid).update(realData) return { errCode: 0 } }