megaco_udp (megaco v4.8)
View SourceInterface module to UDP transport protocol for Megaco/H.248.
This module contains the public interface to the UDP/IP version transport protocol for Megaco/H.248.
Summary
Types
Defines the different counters handled by this transport.
An opaque data type representing an UDP socket.
An opaque data type representing an UDP socket, used when sending.
Functions
Stop receiving incoming messages on the socket.
This function is used for closing an active UDP socket.
Creates a send handle from a transport handle. The send handle is intended to be used by megaco_udp:send_message/2.
Get all counter values for all known connections.
Get all counter values for a given handle.
Get the value of a specific counter.
This function is used to open an UDP/IP socket.
Reset all counters for all UDP handles.
Reset all counters for the given UDP handle.
Sends a message on a socket. The send handle is obtained by megacoudp:create_send_handle/3. Increments the NumOutMessages and NumOutOctets counters if message successfully sent. In case of a failure to send, the NumErrors counter is _not incremented. This is done elsewhere in the megaco app.
This function is used to convert a socket handle() to a inet socket().
This function is used for starting the UDP/IP transport service. Use exit(TransportRef, Reason) to stop the transport service.
Starting to receive incoming messages from the socket again.
Update the receive handle of the control process (e.g. after having changed protocol version).
Types
-type counter() ::
          medGwyGatewayNumInMessages | medGwyGatewayNumInOctets | medGwyGatewayNumOutMessages |
          medGwyGatewayNumOutOctets | medGwyGatewayNumErrors.
      Defines the different counters handled by this transport.
-opaque handle()
      An opaque data type representing an UDP socket.
-opaque send_handle()
      An opaque data type representing an UDP socket, used when sending.
Functions
-spec block(Handle) -> ok when Handle :: handle() | send_handle().
Stop receiving incoming messages on the socket.
-spec close(Handle) -> ok when Handle :: handle() | send_handle().
This function is used for closing an active UDP socket.
-spec create_send_handle(Handle, Host, Port) -> send_handle() when Handle :: handle(), Host :: inet:ip4_address() | inet:hostname(), Port :: inet:port_number().
Creates a send handle from a transport handle. The send handle is intended to be used by megaco_udp:send_message/2.
-spec get_stats() -> {ok, TotalStats} | {error, Reason} when TotalStats :: [{SH, [{Counter, integer()}]}], SH :: send_handle(), Counter :: counter(), Reason :: term().
Get all counter values for all known connections.
-spec get_stats(SH) -> {ok, Stats} | {error, Reason} when SH :: send_handle(), Stats :: [{Counter, integer()}], Counter :: counter(), Reason :: term().
Get all counter values for a given handle.
-spec get_stats(SH, Counter) -> {ok, integer()} | {error, Reason} when SH :: send_handle(), Counter :: counter(), Reason :: term().
Get the value of a specific counter.
-spec open(TransportRef, Opts) -> {ok, Handle, ControlPid} | {error, Reason} when TransportRef :: pid(), Opts :: {inet_backend, default | inet | socket} | {port, PortNum} | {options, list()} | {receive_handle, term()} | {module, atom()}, PortNum :: inet:port_number(), Handle :: handle(), ControlPid :: pid(), Reason :: term().
This function is used to open an UDP/IP socket.
- module- The option makes it possible for the user to provide their own callback module. The functions- receive_message/4or- process_received_message/4of this module is called when a new message is received. Which one depends on the size of the message:- small- receive_message
- large- process_received_message
 - Default value is megaco. 
- inet_backend- Choose the inet-backend.- This option make it possible to use a different inet-backend ('default', 'inet' or 'socket'). - Default is - default(system default).
-spec reset_stats() -> megaco:void().
Reset all counters for all UDP handles.
-spec reset_stats(SH) -> megaco:void() when SH :: send_handle().
Reset all counters for the given UDP handle.
-spec send_message(SH, Msg) -> ok when SH :: send_handle(), Msg :: binary() | iolist().
Sends a message on a socket. The send handle is obtained by megacoudp:create_send_handle/3. Increments the NumOutMessages and NumOutOctets counters if message successfully sent. In case of a failure to send, the NumErrors counter is _not incremented. This is done elsewhere in the megaco app.
-spec socket(Handle) -> Socket when Handle :: handle() | send_handle(), Socket :: inet:socket().
This function is used to convert a socket handle() to a inet socket().
-spec start_transport() -> {ok, TransportRef} when TransportRef :: pid().
This function is used for starting the UDP/IP transport service. Use exit(TransportRef, Reason) to stop the transport service.
-spec unblock(Handle) -> ok when Handle :: handle() | send_handle().
Starting to receive incoming messages from the socket again.
-spec upgrade_receive_handle(ControlPid, NewRecvHandle) -> ok when ControlPid :: pid(), NewRecvHandle :: term().
Update the receive handle of the control process (e.g. after having changed protocol version).