[API] Better appdata get/set endpoints (BREAKING)

This commit is contained in:
syuilo 2017-03-19 15:21:43 +09:00
parent fcd84fb44a
commit 95ab0977f3
2 changed files with 35 additions and 18 deletions

View file

@ -1,6 +1,7 @@
/** /**
* Module dependencies * Module dependencies
*/ */
import $ from 'cafy';
import Appdata from '../../../models/appdata'; import Appdata from '../../../models/appdata';
/** /**
@ -14,10 +15,8 @@ import Appdata from '../../../models/appdata';
*/ */
module.exports = (params, user, app, isSecure) => new Promise(async (res, rej) => { module.exports = (params, user, app, isSecure) => new Promise(async (res, rej) => {
// Get 'key' parameter // Get 'key' parameter
let key = params.key; const [key = null, keyError] = $(params.key).optional.nullable.string().match(/[a-z_]+/).$;
if (key === undefined) { if (keyError) return rej('invalid key param');
key = null;
}
if (isSecure) { if (isSecure) {
if (!user.data) { if (!user.data) {
@ -38,7 +37,9 @@ module.exports = (params, user, app, isSecure) => new Promise(async (res, rej) =
const appdata = await Appdata.findOne({ const appdata = await Appdata.findOne({
app_id: app._id, app_id: app._id,
user_id: user._id user_id: user._id
}, select); }, {
fields: select
});
if (appdata) { if (appdata) {
res(appdata.data); res(appdata.data);

View file

@ -1,6 +1,7 @@
/** /**
* Module dependencies * Module dependencies
*/ */
import $ from 'cafy';
import Appdata from '../../../models/appdata'; import Appdata from '../../../models/appdata';
import User from '../../../models/user'; import User from '../../../models/user';
import serialize from '../../../serializers/user'; import serialize from '../../../serializers/user';
@ -16,17 +17,37 @@ import event from '../../../event';
* @return {Promise<any>} * @return {Promise<any>}
*/ */
module.exports = (params, user, app, isSecure) => new Promise(async (res, rej) => { module.exports = (params, user, app, isSecure) => new Promise(async (res, rej) => {
const data = params.data; // Get 'set' parameter
if (data == null) { const [set, setError] = $(params.set).optional.object()
return rej('data is required'); .pipe(obj => {
return Object.entries(obj).some(kv => {
const k = kv[0];
const v = kv[1];
return $(k).string().match(/[a-z_]+/).isNg() && $(v).string().isNg();
});
}).$;
if (setError) return rej('invalid set param');
// Get 'key' parameter
const [key, keyError] = $(params.key).optional.string().match(/[a-z_]+/).$;
if (keyError) return rej('invalid key param');
// Get 'value' parameter
const [value, valueError] = $(params.value).optional.string().$;
if (valueError) return rej('invalid value param');
let data = {};
if (set) {
data = set;
} else {
data[key] = value;
} }
if (isSecure) { if (isSecure) {
const _user = await User.findOneAndUpdate(user._id, { const _user = await User.findOneAndUpdate(user._id, {
$set: { $set: { data }
data: Object.assign(user.data || {}, JSON.parse(data))
}
}); });
res(204); res(204);
// Publish i updated event // Publish i updated event
@ -35,10 +56,6 @@ module.exports = (params, user, app, isSecure) => new Promise(async (res, rej) =
includeSecrets: true includeSecrets: true
})); }));
} else { } else {
const appdata = await Appdata.findOne({
app_id: app._id,
user_id: user._id
});
await Appdata.update({ await Appdata.update({
app_id: app._id, app_id: app._id,
user_id: user._id user_id: user._id
@ -46,12 +63,11 @@ module.exports = (params, user, app, isSecure) => new Promise(async (res, rej) =
app_id: app._id, app_id: app._id,
user_id: user._id user_id: user._id
}, { }, {
$set: { $set: { data }
data: Object.assign((appdata || {}).data || {}, JSON.parse(data))
}
}), { }), {
upsert: true upsert: true
}); });
res(204); res(204);
} }
}); });