/* * Copyright (c) 2016 MariaDB Corporation Ab * * Use of this software is governed by the Business Source License included * in the LICENSE.TXT file and at www.mariadb.com/bsl11. * * Change Date: 2025-02-16 * * On the date above, in accordance with the Business Source License, use * of this software will be governed by version 2 or later of the General * Public License. */ require('./common.js')() exports.command = 'api ' exports.desc = 'Raw REST API access' exports.handler = function() {} exports.builder = function(yargs) { yargs .group(['sum'], 'API options:') .option('sum', { describe: 'Calculate sum of API result. Only works for arrays of numbers ' + 'e.g. `api get --sum servers data[].attributes.statistics.connections`.', type: 'boolean', default: false }) .command('get [path]', 'Get raw JSON', function(yargs) { return yargs.epilog('Perform a raw REST API call. ' + 'The path definition uses JavaScript syntax to extract values. ' + 'For example, the following command extracts all server states ' + 'as an array of JSON values: maxctrl api get servers data[].attributes.state') .usage('Usage: get [path]') }, function(argv) { maxctrl(argv, function(host) { return doRequest(host, argv.resource, (res) => { if (argv.path) { res = _.getPath(res, argv.path) } if (argv.sum && Array.isArray(res) && typeof(res[0]) == 'number') { res = res.reduce((sum, value) => value ? sum + value : sum) } return JSON.stringify(res) }) }) }) .usage('Usage: api ') .help() .command('*', 'the default command', {}, function(argv) { maxctrl(argv, function(host) { return error('Unknown command. See output of `help api` for a list of commands.') }) }) }