1AnyEvent::Handle::UDP(3Upsme)r Contributed Perl DocumentaAtniyoEnvent::Handle::UDP(3pm)
2
3
4

NAME

6       AnyEvent::Handle::UDP - client/server UDP handles for AnyEvent
7

VERSION

9       version 0.050
10

SYNOPSIS

12        my $echo_server = AnyEvent::Handle::UDP->new(
13            bind => ['0.0.0.0', 4000],
14            on_recv => sub {
15                my ($data, $ae_handle, $client_addr) = @_;
16                $ae_handle->push_send($data, $client_addr);
17            },
18        );
19

DESCRIPTION

21       This module is an abstraction around UDP sockets for use with AnyEvent.
22

ATTRIBUTES

24   on_recv
25       The callback for when a package arrives. It takes three arguments: the
26       datagram, the handle and the address the datagram was received from.
27
28   on_error
29       The callback for when an error occurs. It takes three arguments: the
30       handle, a boolean indicating the error is fatal or not, and the error
31       message.
32
33   on_bind
34       The callback for when the bind has been performed (this may be after
35       object construction if address lookup is involved).
36
37   on_connect
38       The callback for when the connect has been performed (this may be after
39       object construction if address lookup is involved).
40
41   on_drain
42       This sets the callback that is called when the send buffer becomes
43       empty. The callback takes the handle as its only argument.
44
45   autoflush
46       Always attempt to send data to the operating system immediately,
47       without waiting for the loop to indicate the filehandle is write-ready.
48
49   receive_size
50       The buffer size for the receiving in bytes. It defaults to 1500, which
51       is slightly more than the MTA on ethernet.
52
53   family
54       Sets the socket family. The default is 0, which means either IPv4 or
55       IPv6. The values 4 and 6 mean IPv4 and IPv6 respectively.
56
57   fh
58       The underlying filehandle. Note that this doesn't cooperate with the
59       "connect" and "bind" parameters.
60
61   reuse_addr
62       If true will enable quick reuse of the bound address
63
64   timeout
65   rtimeout
66   wtimeout
67       If non-zero, then these enables an "inactivity" timeout: whenever this
68       many seconds pass without a successful read or write on the underlying
69       file handle (or a call to "timeout_reset"), the on_timeout callback
70       will be invoked (and if that one is missing, a non-fatal ETIMEDOUT
71       error will be raised).
72
73       There are three variants of the timeouts that work independently of
74       each other, for both read and write (triggered when nothing was read OR
75       written), just read (triggered when nothing was read), and just write:
76       timeout, rtimeout and wtimeout, with corresponding callbacks
77       on_timeout, on_rtimeout and on_wtimeout, and reset functions
78       timeout_reset, rtimeout_reset, and wtimeout_reset.
79
80       Note that timeout processing is active even when you do not have any
81       outstanding read or write requests: If you plan to keep the connection
82       idle then you should disable the timeout temporarily or ignore the
83       timeout in the corresponding on_timeout callback, in which case
84       AnyEvent::Handle will simply restart the timeout.
85
86       Calling "clear_timeout" (or setting it to zero, which does the same)
87       disables the corresponding timeout.
88
89   on_timeout
90   on_rtimeout
91   on_wtimeout
92       The callback that's called whenever the inactivity timeout passes. If
93       you return from this callback, then the timeout will be reset as if
94       some activity had happened, so this condition is not fatal in any way.
95

METHODS

97   new
98       Create a new UDP handle. As arguments it accepts any attribute, as well
99       as these two:
100
101       •   connect
102
103           Set the address to which datagrams are sent by default, and the
104           only address from which datagrams are received. It must be either a
105           packed sockaddr struct or an arrayref containing a hostname and a
106           portnumber.
107
108       •   bind
109
110           The address to bind the socket to. It must be either a packed
111           sockaddr struct or an arrayref containing a hostname and a
112           portnumber.
113
114       All except "on_recv" are optional, though using either "connect" or
115       "bind" (or both) is strongly recommended unless you give it a
116       connected/bound "fh".
117
118   bind_to($address)
119       Bind to the specified addres. Note that a bound socket may be rebound
120       to another address. $address must be in the same form as the bind
121       argument to new.
122
123   connect_to($address)
124       Connect to the specified address. Note that a connected socket may be
125       reconnected to another address. $address must be in the same form as
126       the connect argument to new.
127
128   push_send($message, $to = undef, $cv = AnyEvent::CondVar->new)
129       Try to send a message. If a socket is not connected a receptient
130       address must also be given. If it is connected giving a receptient may
131       not work as expected, depending on your platform. It returns $cv, which
132       will become true when $message is sent.
133
134   timeout_reset
135   rtimeout_reset
136   wtimeout_reset
137       Reset the activity timeout, as if data was received or sent.
138
139   sockname
140       Get the local address, per "getsockname".
141
142   peername
143       Get the peer's address, per "getpeername".
144
145   destroy
146       Destroy the handle.
147

BACKWARDS COMPATIBILITY

149       This module is not backwards compatible in any way with the defunct
150       previous module of the same name by Jan Henning Thorsen.
151

AUTHOR

153       Leon Timmermans <leont@cpan.org>
154
156       This software is copyright (c) 2011 by Leon Timmermans.
157
158       This is free software; you can redistribute it and/or modify it under
159       the same terms as the Perl 5 programming language system itself.
160
161
162
163perl v5.36.0                      2022-07-22        AnyEvent::Handle::UDP(3pm)
Impressum