joyent/node-triton#80 would be nice if triton network list public=false
worked
Reviewed by: Trent Mick <trentm@gmail.com> Approved by: Trent Mick <trentm@gmail.com>
This commit is contained in:
parent
41b5c506ce
commit
c7c91aea83
@ -7,6 +7,9 @@ Known issues:
|
|||||||
|
|
||||||
## not yet released
|
## not yet released
|
||||||
|
|
||||||
|
- [joyent/node-triton#80] Add `triton network list public=true|false`
|
||||||
|
filtering. Note that this filtering is client-side.
|
||||||
|
|
||||||
- [joyent/node-triton#146] Add `--wait` flag to `triton instance rename`.
|
- [joyent/node-triton#146] Add `--wait` flag to `triton instance rename`.
|
||||||
|
|
||||||
- [joyent/node-triton#133] Add `triton inst fwrule list` and `triton fwrules` shortcuts
|
- [joyent/node-triton#133] Add `triton inst fwrule list` and `triton fwrules` shortcuts
|
||||||
|
@ -5,21 +5,20 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2016 Joyent, Inc.
|
* Copyright 2017 Joyent, Inc.
|
||||||
*
|
*
|
||||||
* `triton network list ...`
|
* `triton network list ...`
|
||||||
*/
|
*/
|
||||||
|
|
||||||
var tabula = require('tabula');
|
var tabula = require('tabula');
|
||||||
|
var vasync = require('vasync');
|
||||||
|
|
||||||
var common = require('../common');
|
var common = require('../common');
|
||||||
|
var errors = require('../errors');
|
||||||
|
|
||||||
|
|
||||||
// to be passed as query string args to /my/networks
|
|
||||||
var validFilters = [
|
var validFilters = [
|
||||||
'id',
|
'public'
|
||||||
'name',
|
|
||||||
'public',
|
|
||||||
'description'
|
|
||||||
];
|
];
|
||||||
|
|
||||||
// columns default without -o
|
// columns default without -o
|
||||||
@ -32,12 +31,10 @@ var columnsDefaultLong = 'id,name,subnet,gateway,fabric,vlan,public';
|
|||||||
var sortDefault = 'name';
|
var sortDefault = 'name';
|
||||||
|
|
||||||
function do_list(subcmd, opts, args, callback) {
|
function do_list(subcmd, opts, args, callback) {
|
||||||
|
var self = this;
|
||||||
if (opts.help) {
|
if (opts.help) {
|
||||||
this.do_help('help', {}, [subcmd], callback);
|
this.do_help('help', {}, [subcmd], callback);
|
||||||
return;
|
return;
|
||||||
} else if (args.length !== 0) {
|
|
||||||
callback(new Error('invalid args: ' + args));
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var columns = columnsDefault;
|
var columns = columnsDefault;
|
||||||
@ -49,18 +46,55 @@ function do_list(subcmd, opts, args, callback) {
|
|||||||
columns = columns.split(',');
|
columns = columns.split(',');
|
||||||
|
|
||||||
var sort = opts.s.split(',');
|
var sort = opts.s.split(',');
|
||||||
var tritonapi = this.top.tritonapi;
|
var filters;
|
||||||
|
try {
|
||||||
|
filters = common.kvToObj(args, validFilters);
|
||||||
|
} catch (e) {
|
||||||
|
callback(e);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (filters.hasOwnProperty('public')) {
|
||||||
|
filters.public =
|
||||||
|
common.boolFromString(filters.public, null, 'public');
|
||||||
|
}
|
||||||
|
|
||||||
common.cliSetupTritonApi({cli: this.top}, function onSetup(setupErr) {
|
vasync.pipeline({arg: {cli: this.top}, funcs: [
|
||||||
if (setupErr) {
|
common.cliSetupTritonApi,
|
||||||
callback(setupErr);
|
|
||||||
}
|
function searchNetworks(arg, next) {
|
||||||
tritonapi.cloudapi.listNetworks(function (err, networks) {
|
self.top.tritonapi.cloudapi.listNetworks(function (err, networks) {
|
||||||
if (err) {
|
if (err) {
|
||||||
callback(err);
|
next(err);
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
arg.networks = networks;
|
||||||
|
next();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
function filterNetworks(arg, next) {
|
||||||
|
var filteredNetworks = [];
|
||||||
|
var filterKeys = Object.keys(filters);
|
||||||
|
for (var i = 0; i < arg.networks.length; i++) {
|
||||||
|
var network = arg.networks[i];
|
||||||
|
var keepIt = true;
|
||||||
|
for (var j = 0; j < filterKeys.length; j++) {
|
||||||
|
var k = filterKeys[j];
|
||||||
|
if (network[k] !== filters[k]) {
|
||||||
|
keepIt = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (keepIt) {
|
||||||
|
filteredNetworks.push(network);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
arg.filteredNetworks = filteredNetworks;
|
||||||
|
next();
|
||||||
|
},
|
||||||
|
|
||||||
|
function doneNetworks(arg, next) {
|
||||||
|
var networks = arg.filteredNetworks;
|
||||||
if (opts.json) {
|
if (opts.json) {
|
||||||
common.jsonStream(networks);
|
common.jsonStream(networks);
|
||||||
} else {
|
} else {
|
||||||
@ -75,9 +109,9 @@ function do_list(subcmd, opts, args, callback) {
|
|||||||
sort: sort
|
sort: sort
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
callback();
|
next();
|
||||||
});
|
}
|
||||||
});
|
]}, callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
do_list.options = [
|
do_list.options = [
|
||||||
@ -91,13 +125,16 @@ do_list.options = [
|
|||||||
sortDefault: sortDefault
|
sortDefault: sortDefault
|
||||||
}));
|
}));
|
||||||
|
|
||||||
do_list.synopses = ['{{name}} {{cmd}}'];
|
do_list.synopses = ['{{name}} {{cmd}} [FILTERS...]'];
|
||||||
|
|
||||||
do_list.help = [
|
do_list.help = [
|
||||||
'List available networks.',
|
'List available networks.',
|
||||||
'',
|
'',
|
||||||
'{{usage}}',
|
'{{usage}}',
|
||||||
'',
|
'',
|
||||||
|
'Filters:',
|
||||||
|
' FIELD=true|false Boolean filter. Supported fields: public',
|
||||||
|
'',
|
||||||
'{{options}}',
|
'{{options}}',
|
||||||
'Fields (most are self explanatory, the client adds some for convenience):',
|
'Fields (most are self explanatory, the client adds some for convenience):',
|
||||||
' vlan A shorter alias for "vlan_id".',
|
' vlan A shorter alias for "vlan_id".',
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2016, Joyent, Inc.
|
* Copyright 2017 Joyent, Inc.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -66,6 +66,52 @@ test('triton networks', function (tt) {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
tt.test(' triton networks public=false', function (t) {
|
||||||
|
h.triton('networks public=false -H -o public',
|
||||||
|
function (err, stdout, stderr) {
|
||||||
|
if (h.ifErr(t, err))
|
||||||
|
return t.end();
|
||||||
|
var results = stdout.trim().split('\n');
|
||||||
|
results.forEach(function (result) {
|
||||||
|
t.equal(false, common.boolFromString(result, null, 'public'));
|
||||||
|
});
|
||||||
|
t.end();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
tt.test(' triton network list public=false', function (t) {
|
||||||
|
h.triton('network list public=false -H -o public',
|
||||||
|
function (err, stdout, stderr) {
|
||||||
|
if (h.ifErr(t, err))
|
||||||
|
return t.end();
|
||||||
|
var results = stdout.trim().split('\n');
|
||||||
|
results.forEach(function (result) {
|
||||||
|
t.equal(false, common.boolFromString(result, null, 'public'));
|
||||||
|
});
|
||||||
|
t.end();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
tt.test(' triton network list public=true', function (t) {
|
||||||
|
h.triton('network list public=true -H -o public',
|
||||||
|
function (err, stdout, stderr) {
|
||||||
|
if (h.ifErr(t, err))
|
||||||
|
return t.end();
|
||||||
|
var results = stdout.trim().split('\n');
|
||||||
|
results.forEach(function (result) {
|
||||||
|
t.equal(true, common.boolFromString(result, null, 'public'));
|
||||||
|
});
|
||||||
|
t.end();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
tt.test(' triton network list public=bogus', function (t) {
|
||||||
|
h.triton('network list public=bogus', function (err, stdout, stderr) {
|
||||||
|
t.ok(err, err);
|
||||||
|
t.end();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
tt.test(' triton networks -l', function (t) {
|
tt.test(' triton networks -l', function (t) {
|
||||||
h.triton('networks -l', function (err, stdout, stderr) {
|
h.triton('networks -l', function (err, stdout, stderr) {
|
||||||
if (h.ifErr(t, err))
|
if (h.ifErr(t, err))
|
||||||
|
Reference in New Issue
Block a user