the-bastion/bin/plugin/open/batch

72 lines
1.8 KiB
Text
Raw Normal View History

2020-10-16 00:32:37 +08:00
#! /usr/bin/env perl
# vim: set filetype=perl ts=4 sw=4 sts=4 et:
use common::sense;
use File::Basename;
use lib dirname(__FILE__) . '/../../../lib/perl';
use OVH::Result;
use OVH::Bastion;
use OVH::Bastion::Plugin qw( :DEFAULT help );
my $remainingOptions = OVH::Bastion::Plugin::begin(
argv => \@ARGV,
header => "clush",
options => {},
helptext => <<'EOF',
Run a batch of osh commands fed through STDIN
Usage: --osh SCRIPT_NAME
**Examples:**
(replace ``bssh`` by your bastion alias)
- run 3 simple commands in a oneliner:
::
printf "%b\n%b\n%b" info selfListIngressKeys selfListEgressKeys | bssh --osh batch
- run a lot of commands written out line by line in a file:
::
bssh --osh batch < cmdlist.txt
- add 3 users to a group:
::
for i in user1 user2 user3; do echo "groupAddMember --account $i --group grp4"; done | bssh --osh batch
EOF
);
my $fnret;
osh_info "Feed me osh commands line by line on stdin, I'll execute them sequentially.";
osh_info "Use 'exit', 'quit' or ^D to stop.";
osh_info "--- waiting for input";
my @ret;
while (my $line = <STDIN>) {
chomp $line;
last if (lc($line) eq 'exit' || lc($line) eq 'quit');
# we remove any json param, because we add --json ourselves so that we can decode
# what the osh plugin had to say, and add it to our global @ret json
$line =~ s/ --json[a-z-]*//g;
my @cmd = ($ENV{'SHELL'}, '-c', "--osh $line --json");
osh_info "--- launching command: $line";
do {
# notify that we're under batch mode, hence if plugin requires MFA,
# we'll require --proactive-mfa, see comment in lib/perl/OVH/Bastion.pm
local $ENV{'OSH_BATCH'} = 1;
$fnret = OVH::Bastion::helper(cmd => \@cmd);
};
2020-10-16 00:32:37 +08:00
if (!$fnret) {
osh_warn "--- command failed!";
}
push @ret, {command => $line, result => $fnret};
}
osh_ok(\@ret);