/*** * Copyright 2015 RAPP * * 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. * * Authors: Konstantinos Panayiotou * Contact: klpanagi@gmail.com * */ /** * @fileOverview * * [Cognitive-Test-Chooser] RAPP Platform web service implementation. * * @author Konstantinos Panayiotou * @copyright Rapp Project EU 2015 * */ var path = require('path'); var interfaces = require( path.join(__dirname, 'iface_obj.js') ); const rosSrvName = "/rapp/rapp_cognitive_exercise/cognitive_exercise_chooser"; /** * [Cognitive-Test-Selector] * Handles requests to cognitive_test_chooser RAPP Platform Service * * Service Implementation. * */ function svcImpl (req, resp, ros) { var rosMsg = new interfaces.ros_req(); rosMsg.username = req.username; rosMsg.testType = req.body.test_type; rosMsg.testSubType = req.body.test_subtype; rosMsg.testDifficulty = req.body.test_diff; rosMsg.testIndex = req.body.test_index; // ROS-Service response callback. function callback(data) { // Parse rosbridge message and craft client response var response = parseRosbridgeMsg( data ); resp.sendJson(response); } // ROS-Service onerror callback. function onerror(e) { var response = new interfaces.client_res(); response.error = e; resp.sendJson(response); } // Call ROS-Service. ros.callService(rosSrvName, rosMsg, {success: callback, fail: onerror}); } /*** * Crafts response object. * * @param {Object} rosbridge_msg - Return message from rosbridge * * @returns {Object} response - Response Object. * @returns {String} response.lang - Language. * @returns {Array} response.questions - Vector of questions, for selected * exercise. * @returns {Array} response.possib_ans - Array of possible answers, for * selected exercise. * @returns {Array} response.correct_ans - Vector of correct answers, for * selected exercise. * @returns {String} response.test_instance - Selected Exercise's * test instance name. * @returns {String} response.test_type - Test-type of selected exercise. * @returns {String} response.test_subtype - Test-subtype of selected * exercise. * @returns {String} response.error - Error message string to be filled * when an error has been occured during service call. */ function parseRosbridgeMsg(rosbridge_msg) { const success = rosbridge_msg.success; const error = rosbridge_msg.error; const questions = rosbridge_msg.questions; const answers = rosbridge_msg.answers; const correctAnswers = rosbridge_msg.correctAnswers; const test = rosbridge_msg.test; const testType = rosbridge_msg.testType; const testSubType = rosbridge_msg.testSubType; const language = rosbridge_msg.language; var response = new interfaces.client_res(); if (error) { response.error = error; return response; } response.questions = questions; response.correct_ans = correctAnswers; response.test_instance = test; response.test_type = testType; response.test_subtype = testSubType; response.lang = language; response.error = error; for (let ii = 0; ii < answers.length; ii++) { response.possib_ans.push( answers[ii].s ); } return response; } module.exports = svcImpl;