about summary refs log tree commit homepage
path: root/lib
diff options
context:
space:
mode:
authorEric Wong <e@80x24.org>2021-01-05 09:04:36 +0000
committerEric Wong <e@80x24.org>2021-01-06 10:45:08 +0000
commit27f8e2b161f4a8bb1ef030bd45e3f5ae7a9f0bb0 (patch)
tree63eda0889200ca0efe2dd10c88144fb2827e9ec0 /lib
parent8bad040482941cc424888f3cf48c17e48953342d (diff)
downloadpublic-inbox-27f8e2b161f4a8bb1ef030bd45e3f5ae7a9f0bb0.tar.gz
There may be subtle misbehaviours when mixing the existing
daemon env and the client-supplied env.  Just do the simplest
thing and use the client env as-is.

We'll also start the ->event_step callback since we'll need
to remember some things for long-lived commands.
Diffstat (limited to 'lib')
-rw-r--r--lib/PublicInbox/LEI.pm38
1 files changed, 12 insertions, 26 deletions
diff --git a/lib/PublicInbox/LEI.pm b/lib/PublicInbox/LEI.pm
index 6073a713..9c3308ad 100644
--- a/lib/PublicInbox/LEI.pm
+++ b/lib/PublicInbox/LEI.pm
@@ -149,8 +149,6 @@ our %CMD = ( # sorted in order of importance/use:
 'daemon-kill' => [ '[-SIGNAL]', 'signal the lei-daemon',
         opt_dash('signal|s=s', '[0-9]+|(?:[A-Z][A-Z0-9]+)') ],
 'daemon-pid' => [ '', 'show the PID of the lei-daemon' ],
-'daemon-env' => [ '[NAME=VALUE...]', 'set, unset, or show daemon environment',
-        qw(clear| unset|u=s@ z|0) ],
 'help' => [ '[SUBCOMMAND]', 'show help' ],
 
 # XXX do we need this?
@@ -230,12 +228,6 @@ my %OPTDESC = (
 # xargs, env, use "-0", git(1) uses "-z".  We support z|0 everywhere
 'z|0' => 'use NUL \\0 instead of newline (CR) to delimit lines',
 
-# note: no "--ignore-environment" / "-i" support like env(1) since that
-# is one-shot and this is for a persistent daemon:
-'clear|' => 'clear the daemon environment',
-'unset|u=s@' => ['NAME',
-        'unset matching NAME, may be specified multiple times'],
-
 'signal|s=s' => [ 'SIG', 'signal to send lei-daemon (default: TERM)' ],
 ); # %OPTDESC
 
@@ -538,24 +530,6 @@ sub lei_daemon_kill {
         kill($sig, $$) or fail($self, "kill($sig, $$): $!");
 }
 
-sub lei_daemon_env {
-        my ($self, @argv) = @_;
-        my $opt = $self->{opt};
-        if (defined $opt->{clear}) {
-                %ENV = ();
-        } elsif (my $u = $opt->{unset}) {
-                delete @ENV{@$u};
-        }
-        if (@argv) {
-                %ENV = (%ENV, map { split(/=/, $_, 2) } @argv);
-        } elsif (!defined($opt->{clear}) && !$opt->{unset}) {
-                my $eor = $opt->{z} ? "\0" : "\n";
-                my $buf = '';
-                while (my ($k, $v) = each %ENV) { $buf .= "$k=$v$eor" }
-                out $self, $buf;
-        }
-}
-
 sub lei_help { _help($_[0]) }
 
 # Shell completion helper.  Used by lei-completion.bash and hopefully
@@ -678,6 +652,7 @@ sub accept_dispatch { # Listener {post_accept} callback
         };
         my %env = map { split(/=/, $_, 2) } split(/\0/, $env);
         if (chdir($env{PWD})) {
+                local %ENV = %env;
                 $self->{env} = \%env;
                 $self->{pid} = $client_pid;
                 eval { dispatch($self, split(/\]\0\[/, $argv)) };
@@ -687,6 +662,17 @@ sub accept_dispatch { # Listener {post_accept} callback
         }
 }
 
+# for long-running results
+sub event_step {
+        my ($self) = @_;
+        local %ENV = %{$self->{env}};
+        eval {}; # TODO
+        if ($@) {
+                say { $self->{sock} } $@;
+                $self->close; # PublicInbox::DS::close
+        }
+}
+
 sub noop {}
 
 # lei(1) calls this when it can't connect