3 # A thing that implements dxcluster 'protocol'
5 # This is a perl module/program that sits on the end of a dxcluster
6 # 'protocol' connection and deals with anything that might come along.
8 # this program is called by ax25d and gets raw ax25 text on its input
10 # Copyright (c) 1998 Dirk Koopman G1TLH
16 unshift @INC, "/spider/local";
17 unshift @INC, "/spider/perl";
23 $mode = 1; # 1 - \n = \r as EOL, 2 - \n = \n, 0 - transparent
24 $call = ""; # the callsign being used
25 @stdoutq = (); # the queue of stuff to send out to the user
26 $conn = 0; # the connection object for the cluster
27 $lastbit = ""; # the last bit of an incomplete input line
29 # cease communications
33 if (defined $conn && $sendz) {
34 $conn->send_now("Z$call|bye...\n");
39 # terminate program from signal
60 # handle incoming messages
63 my ($con, $msg, $err) = @_;
64 if (defined $err && $err) {
68 my ($sort, $call, $line) = $msg =~ /^(\w)(\S+)\|(.*)$/;
71 $nl = "" if $mode == 0;
72 $line =~ s/\n/\r/og if $mode == 1;
74 } elsif ($sort eq 'M') {
75 $mode = $line; # set new mode from cluster
77 } elsif ($sort eq 'Z') { # end, disconnect, go, away .....
92 $r = sysread($fh, $buf, 1024);
93 # print "sys: $r $buf";
96 $buf =~ s/\r/\n/og if $mode == 1;
97 $dangle = !($buf =~ /\n$/);
98 @lines = split /\n/, $buf;
99 if ($dangle) { # pull off any dangly bits
104 $first = shift @lines;
105 unshift @lines, ($lastbit . $first) if ($first);
106 foreach $first (@lines) {
107 $conn->send_now("D$call|$first");
111 $conn->send_now("D$call|$buf");
119 die "client.pl <call> [<mode>]\r\n" if (!$call);
120 $mode = $ARGV[1] if (@ARGV > 1);
124 #select STDOUT; $| = 1;
125 STDOUT->autoflush(1);
127 $SIG{'INT'} = \&sig_term;
128 $SIG{'TERM'} = \&sig_term;
129 $SIG{'HUP'} = \&sig_term;
131 $conn = Msg->connect("$clusteraddr", $clusterport, \&rec_socket);
132 $conn->send_now("A$call|start");
133 Msg->set_event_handler(\*STDIN, "read" => \&rec_stdin);