X-Git-Url: http://dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=perl%2FDXCommandmode.pm;h=f6049236703af8b3a3b6ddbf187bd6126c3473cd;hb=23e3e6f8dc328ab0dd7f9ddae444126b0af12867;hp=1c581b5fdc12d48a1430d608fda77529077aa8e6;hpb=9c9e4ae46b36d4e85bf8b969647079140667502b;p=spider.git diff --git a/perl/DXCommandmode.pm b/perl/DXCommandmode.pm index 1c581b5f..f6049236 100644 --- a/perl/DXCommandmode.pm +++ b/perl/DXCommandmode.pm @@ -42,7 +42,7 @@ use Thingy::Bye; use strict; use vars qw(%Cache %cmd_cache $errstr %aliases $scriptbase $maxerrors %nothereslug - $maxbadcount $msgpolltime $default_pagelth); + $maxbadcount $msgpolltime $default_pagelth $cmdimportdir); %Cache = (); # cache of dynamically loaded routine's mod times %cmd_cache = (); # cache of short names @@ -53,6 +53,8 @@ $maxerrors = 20; # the maximum number of concurrent errors allowed before dis $maxbadcount = 3; # no of bad words allowed before disconnection $msgpolltime = 3600; # the time between polls for new messages $default_pagelth = 20; # the default page length 0 = unlimited +$cmdimportdir = "$main::root/cmd_import"; # the base directory for importing command scripts + # this does not exist as default, you need to create it manually @@ -531,6 +533,8 @@ sub process delete $nothereslug{$k}; } } + + import_cmd(); } # @@ -614,14 +618,6 @@ sub get_all return grep {$_->{sort} eq 'U'} DXChannel::get_all(); } -# run a script for this user -sub run_script -{ - my $self = shift; - my $silent = shift || 0; - -} - # # search for the command in the cache of short->long form commands # @@ -963,5 +959,79 @@ sub store_startup_script return @out; } +# Import any commands contained in any files in import_cmd directory +# +# If the filename has a recogisable callsign as some delimited part +# of it, then this is the user the command will be run as. +# +sub import_cmd +{ + # are there any to do in this directory? + return unless -d $cmdimportdir; + unless (opendir(DIR, $cmdimportdir)) { + dbg("can\'t open $cmdimportdir $!"); + Log('err', "can\'t open $cmdimportdir $!"); + return; + } + + my @names = readdir(DIR); + closedir(DIR); + my $name; + foreach $name (@names) { + next if $name =~ /^\./; + + my $s = Script->new($name, $cmdimportdir); + if ($s) { + + dbg("Run import cmd file $name"); + Log('DXCommand', "Run import cmd file $name"); + my @cat = split /[^A-Za-z0-9]+/, $name; + my ($call) = grep {is_callsign(uc $_)} @cat; + $call ||= $main::mycall; + $call = uc $call; + my @out; + + + $s->inscript(0); # switch off script checks + + if ($call eq $main::mycall) { + @out = $s->run($main::me, 1); + } else { + my $dxchan = DXChannel::get($call); + if ($dxchan) { + @out = $s->run($dxchan, 1); + } else { + my $u = DXUser->get($call); + if ($u) { + $dxchan = $main::me; + my $old = $dxchan->{call}; + my $priv = $dxchan->{priv}; + my $user = $dxchan->{user}; + $dxchan->{call} = $call; + $dxchan->{priv} = $u->priv; + $dxchan->{user} = $u; + @out = $s->run($dxchan, 1); + $dxchan->{call} = $call; + $dxchan->{priv} = $priv; + $dxchan->{user} = $user; + } else { + Log('err', "Trying to run import cmd for non-existant user $call"); + dbg( "Trying to run import cmd for non-existant user $call"); + } + } + } + $s->erase; + for (@out) { + Log('DXCommand', "Import cmd $name/$call: $_"); + dbg("Import cmd $name/$call: $_"); + } + } else { + Log("Failed to open $cmdimportdir/$name $!"); + dbg("Failed to open $cmdimportdir/$name $!"); + unlink "$cmdimportdir/$name"; + } + } +} + 1; __END__