From a7e6b766be6b30b37839beb13f31d96b141cc25a Mon Sep 17 00:00:00 2001 From: syuilo Date: Fri, 2 Nov 2018 12:49:08 +0900 Subject: Resolve #2623 --- .../api/endpoints/i/update_client_setting.ts | 27 ++++++++++++++-------- 1 file changed, 17 insertions(+), 10 deletions(-) (limited to 'src/server/api/endpoints/i/update_client_setting.ts') diff --git a/src/server/api/endpoints/i/update_client_setting.ts b/src/server/api/endpoints/i/update_client_setting.ts index 2c05299dff..a1631b1d95 100644 --- a/src/server/api/endpoints/i/update_client_setting.ts +++ b/src/server/api/endpoints/i/update_client_setting.ts @@ -1,23 +1,30 @@ import $ from 'cafy'; import User, { ILocalUser } from '../../../../models/user'; import { publishMainStream } from '../../../../stream'; +import getParams from '../../get-params'; export const meta = { requireCredential: true, - secure: true + + secure: true, + + params: { + name: { + validator: $.str + }, + + value: { + validator: $.any.nullable + } + } }; export default async (params: any, user: ILocalUser) => new Promise(async (res, rej) => { - // Get 'name' parameter - const [name, nameErr] = $.str.get(params.name); - if (nameErr) return rej('invalid name param'); - - // Get 'value' parameter - const [value, valueErr] = $.any.nullable.get(params.value); - if (valueErr) return rej('invalid value param'); + const [ps, psErr] = getParams(meta, params); + if (psErr) return rej(psErr); const x: any = {}; - x[`clientSettings.${name}`] = value; + x[`clientSettings.${name}`] = ps.value; await User.update(user._id, { $set: x @@ -28,6 +35,6 @@ export default async (params: any, user: ILocalUser) => new Promise(async (res, // Publish event publishMainStream(user._id, 'clientSettingUpdated', { key: name, - value + value: ps.value }); }); -- cgit v1.2.3-freya