/**
* Copyright 2015 IBM Corp. All Rights Reserved.
*
* 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.
*/
'use strict';
var extend = require('extend');
var requestFactory = require('../../lib/requestwrapper');
function ToneAnalyzer(options) {
// Check if 'version_date' was provided
if (typeof options.version_date === 'undefined') {
throw new Error('Argument error: version_date was not specified, use 2016-02-11');
}
// Default URL
var serviceDefaults = {
url: 'https://gateway.watsonplatform.net/tone-analyzer-beta/api',
qs: {
version: options.version_date
}
};
// Replace default options with user provided
this._options = extend(serviceDefaults, options);
}
/**
* Main API call. Returns the different tone dimensions of a text.
*
* @param params: An object with a string 'text' element. This is the
* only field used. By this API call
*
* @return upon success, the callback function is called with an object
* containing the different tones (emotion, writing and social), traits
* and the evidence words found in the text.
*
* @see the API docs for a the full documentation.
*
*/
ToneAnalyzer.prototype.tone = function(params, callback) {
if (!params || !params.text){
callback(new Error('Missing required parameters: text'));
return;
}
var parameters = {
options: {
url: '/v3/tone',
method: 'POST',
body: params.text
},
defaultOptions: extend(this._options, {
headers: {
'accept': 'application/json',
'content-type': 'text/plain'
}
}),
};
return requestFactory(parameters, callback);
};
module.exports = ToneAnalyzer;