forked from rramsden/TCP-IP-Stack
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathUDPmessenger.pl
executable file
·119 lines (110 loc) · 2.65 KB
/
UDPmessenger.pl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#!/usr/bin/perl -w
# UDPmessenger.pl
# Created Feb 28, 2011 - Andrew Walker
# This little gem of a program is for doing UDP testing on our yet-to-exist TCP/IP stack.
# It is using UDP sockets until we have enough functionality in 'NetStack' to do UDP testing.
# There is NO error checking. You break it, you bought it.
# There are 3 commands:
# 1. PORT {port} - set what port you want to listen for messages on
# 2. CONNECT {ip_address/url} {port} - set where to send messages
# 3. UNAME {user_name} - set your display name
#
# Anything else will be treated as a message.
# Use ^C to exit the program.
#
# ------------ Example Usage ---------------
# Terminal #1:
# ~/csci460/TCP-IP-Stack:./UDPmessenger.pl
# UDP_MESSENGER
# UNAME Walker
# Walker
# PORT 5674
# Walker
# CONNECT localhost 5675
# Walker
# Stalker
# Hey
# Walker
# What?
# Walker
# Stalker
# AAAAAAAAAAAAAHHHHHHHHHHHH!!!!!!!
# Walker
# BLOCKED
# Walker
# ^C
#
# Terminal #2:
# ~/csci460/TCP-IP-Stack:./UDPmessenger.pl
# UDP_MESSENGER
# PORT 5675
# UDP_MESSENGER
# CONNECT localhost 5674
# UDP_MESSENGER
# UNAME Stalker
# Stalker
# Hey
# Stalker
# Walker
# What?
# Stalker
# AAAAAAAAAAAAAHHHHHHHHHHHH!!!!!!!
# Stalker
# Walker
# BLOCKED
# Stalker
# ^C
use strict;
use IO::Select;
use IO::Socket;
my $UNAME = 'UDP_MESSENGER';
my $listen; # this will be the socket we listen for messages on
my $message; # this will be the socket we send messages to
# the select related junk
my $sel = new IO::Select();
$sel->add(\*STDIN);
my $fh;
my @ready;
print($UNAME, "\n"); # print the prompt
while(@ready = $sel->can_read) # grab the list of file handles that are ready with goodies
{
foreach $fh (@ready)
{
if($fh == \*STDIN) # thar be data on stdin!
{
my $input = <STDIN>;
my @cmd = split(/\s/, $input); # split on whitespace
if($cmd[0] eq 'PORT')
{
if(defined($listen)) # for the first time PORT is called
{
$sel->remove($listen); # stop listening on the old socket
}
$listen = new IO::Socket::INET(LocalPort=>$cmd[1],Proto=>'udp') or die("Can't make UDP socket: $@");
$sel->add($listen); # start listening on new socket
}
elsif($cmd[0] eq 'CONNECT')
{
$message = new IO::Socket::INET(Proto=>'udp',PeerAddr=>$cmd[1],PeerPort=>$cmd[2]) or die("Can't make UDP socket: $@");
}
elsif($cmd[0] eq 'UNAME')
{
#set user name
$UNAME = $cmd[1];
}
else
{
#send message
$message->send($UNAME."\n".$input);
}
}
else # thar be data on ye udp socket! yar!
{
my ($datagram,$flags);
$listen->recv($datagram, 1024, $flags); # read up to 1024 bytes from udp socket
print($datagram);
# STDOUT->flush();
}
}
print($UNAME, "\n"); # print the prompt
}