/***
* 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
*
* [Human-Detection] RAPP Platform front-end web service.
*
* @author Konstantinos Panayiotou
* @copyright Rapp Project EU 2015
*/
var path = require('path');
var Fs = require( path.join(ENV.PATHS.INCLUDE_DIR, 'common', 'fileUtils.js') );
var interfaces = require( path.join(__dirname, 'ihuman_obj.js') );
const rosSrvName = "/rapp/rapp_human_detection/detect_humans";
/**
* [Human-Detection]
* Handles requests to human_detection RAPP Platform Service
*
* Service Implementation.
*
*/
function svcImpl(req, resp, ros) {
if (! req.files.file) {
let response = new interfaces.client_res();
response.error = "No image file received";
resp.sendJson(response);
return;
}
var rosMsg = new interfaces.ros_req();
rosMsg.imageFilename = req.files.file[0];
// ROS-Service response callback.
function callback(data) {
Fs.rmFile(req.files.file[0]);
// Parse rosbridge message and craft client response
var response = parseRosbridgeMsg(data);
resp.sendJson(response);
}
// ROS-Service onerror callback.
function onerror(e) {
Fs.rmFile(req.files.file[0]);
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 {Array} response.humans - An array of face-objects.
* @returns {String} response.error - Error message string to be filled
* when an error has been occured during service call.
*/
function parseRosbridgeMsg(rosbridge_msg) {
const humans_up_left = rosbridge_msg.humans_up_left;
const humans_down_right = rosbridge_msg.humans_down_right;
const error = rosbridge_msg.error;
const numHumans = humans_up_left.length;
var response = new interfaces.client_res();
if (error) {
response.error = error;
return response;
}
for (let ii = 0; ii < numHumans; ii++)
{
/***
* @namespace human
* @property up_left_point - Face bounding box, up-left-point
*/
let human = {
up_left_point: {x: 0, y:0},
down_right_point: {x: 0, y: 0}
};
human.up_left_point.x = humans_up_left[ii].point.x;
human.up_left_point.y = humans_up_left[ii].point.y;
human.down_right_point.x = humans_down_right[ii].point.x;
human.down_right_point.y = humans_down_right[ii].point.y;
response.humans.push( human );
}
return response;
}
module.exports = svcImpl;