From 10cb2a833273fc84db5ab0525068f93f01472c1e Mon Sep 17 00:00:00 2001 From: syuilo Date: Sun, 12 Nov 2017 03:04:04 +0900 Subject: Optimization --- src/api/endpoints/i/update_home.ts | 42 ++++++++++++++++++++++++++++++-------- 1 file changed, 34 insertions(+), 8 deletions(-) (limited to 'src/api') diff --git a/src/api/endpoints/i/update_home.ts b/src/api/endpoints/i/update_home.ts index b9a7642b8e..429e88529a 100644 --- a/src/api/endpoints/i/update_home.ts +++ b/src/api/endpoints/i/update_home.ts @@ -15,7 +15,7 @@ import User from '../../models/user'; */ module.exports = async (params, user, _, isSecure) => new Promise(async (res, rej) => { // Get 'home' parameter - const [home, homeErr] = $(params.home).array().each( + const [home, homeErr] = $(params.home).optional.array().each( $().strict.object() .have('name', $().string()) .have('id', $().string()) @@ -23,12 +23,38 @@ module.exports = async (params, user, _, isSecure) => new Promise(async (res, re .have('data', $().object())).$; if (homeErr) return rej('invalid home param'); - await User.update(user._id, { - $set: { - 'client_settings.home': home - } - }); + // Get 'id' parameter + const [id, idErr] = $(params.id).optional.string().$; + if (idErr) return rej('invalid id param'); - // Send response - res(); + // Get 'data' parameter + const [data, dataErr] = $(params.data).optional.object().$; + if (dataErr) return rej('invalid data param'); + + if (home) { + await User.update(user._id, { + $set: { + 'client_settings.home': home + } + }); + + res(); + } else { + if (id == null && data == null) return rej('you need to set id and data params if home param unset'); + + const _home = user.client_settings.home; + const widget = _home.find(w => w.id == id); + + if (widget == null) return rej('widget not found'); + + widget.data = data; + + await User.update(user._id, { + $set: { + 'client_settings.home': _home + } + }); + + res(); + } }); -- cgit v1.2.3-freya