UNPKG

agneta-platform

Version:

Agneta Platform - Integrate and customize business applications

100 lines (78 loc) 2.22 kB
/* Copyright 2017 Agneta Network Applications, LLC. * * Source file: portal/services/models/account/get.js * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ var _ = require('lodash'); module.exports = function(Model, app) { var rolesConfig = app.get('roles'); Model.get = function(req, id) { if (req.accessToken.roles.administrator) { return Model.__get(id, { include: Model.rolesInclude }) .then(function(account) { account = account.__data; //console.log(account); var roles = _.pick(account, Model.roleKeys); account = _.omit(account, Model.roleKeys.concat(['password'])); //console.log(roles); for (var roleKey in roles) { var role = roles[roleKey]; var config = rolesConfig[roleKey]; if (config.form) { role.editable = true; } } account.roles = roles; return account; }); } else { console.log('Not an administrator'); return Model.findById(id, { fields: { id: true, name: true, avatar: true, username: true } }); } }; Model.remoteMethod( 'get', { description: 'Get user\'s administrative settings', accepts: [{ arg: 'req', type: 'object', 'http': { source: 'req' } }, { arg: 'id', type: 'string', required: true }], returns: { arg: 'result', type: 'object', root: true }, http: { verb: 'get', path: '/get' } } ); };