agneta-platform
Version:
Agneta Platform - Integrate and customize business applications
116 lines (96 loc) • 2.76 kB
JavaScript
/* Copyright 2017 Agneta Network Applications, LLC.
*
* Source file: portal/services/models/edit_page/loadOne.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.
*/
const fs = require('fs-extra');
const yaml = require('js-yaml');
const path = require('path');
const templateBase = require('./templateBase');
const loadTemplate = require('../edit/loadTemplate');
module.exports = function(Model, app) {
var source;
var template;
var clientHelpers = app.get('options').web.app.locals;
Model.loadOne = function(id, req) {
var page;
var log;
return Model.getPage(id)
.then(function(_page) {
//////////////////////////////////////////
page = _page;
source = Model.pageSource(page);
if (page.hasError) {
return Promise.reject({
statusCode: '400',
message: `This page has an error.\nFor more details visit the page:\n<a href="${clientHelpers.get_path(page.path)}" target="_blank">${page.path}</a>`
});
}
return app.git.log({
file: source
});
})
.then(function(_log) {
log = _log;
return loadTemplate({
path: path.join(Model.editConfigDir, page.template + '.yml'),
req: req,
app: app
});
})
.then(function(_template) {
template = _template;
template.id = page.template;
templateBase(template);
return fs.readFile(source);
})
.then(function(content) {
var data = yaml.safeLoad(content);
return {
page: {
data: data,
path: page.path,
id: id,
log: log
},
template: template
};
});
};
Model.remoteMethod(
'loadOne', {
description: 'Load page with specified ID',
accepts: [{
arg: 'id',
type: 'string',
required: true
}, {
arg: 'req',
type: 'object',
'http': {
source: 'req'
}
}],
returns: {
arg: 'result',
type: 'object',
root: true
},
http: {
verb: 'get',
path: '/load-one'
},
}
);
};