Class DatagramSocket

  • All Implemented Interfaces:
    io.vertx.lang.rx.RxDelegate, Measured

    public class DatagramSocket
    extends Object
    implements io.vertx.lang.rx.RxDelegate, Measured
    A datagram socket can be used to send DatagramPacket's to remote datagram servers and receive DatagramPackets .

    Usually you use a datagram socket to send UDP over the wire. UDP is connection-less which means you are not connected to the remote peer in a persistent way. Because of this you have to supply the address and port of the remote peer when sending data.

    You can send data to ipv4 or ipv6 addresses, which also include multicast addresses.

    Please consult the documentation for more information on datagram sockets.

    NOTE: This class has been automatically generated from the original non RX-ified interface using Vert.x codegen.

    • Field Detail

      • __TYPE_ARG

        public static final io.vertx.lang.rx.TypeArg<DatagramSocket> __TYPE_ARG
    • Constructor Detail

      • DatagramSocket

        public DatagramSocket​(Object delegate)
    • Method Detail

      • hashCode

        public int hashCode()
        Overrides:
        hashCode in class Object
      • getDelegate

        public DatagramSocket getDelegate()
        Specified by:
        getDelegate in interface Measured
        Specified by:
        getDelegate in interface io.vertx.lang.rx.RxDelegate
      • isMetricsEnabled

        public boolean isMetricsEnabled()
        Whether the metrics are enabled for this measured object
        Specified by:
        isMetricsEnabled in interface Measured
        Returns:
        true if metrics are enabled
      • send

        public Completable send​(Buffer packet,
                                int port,
                                String host)
        Write the given Buffer to the SocketAddress.
        Parameters:
        packet - the Buffer to write
        port - the host port of the remote peer
        host - the host address of the remote peer
        Returns:
        a future notified once the write completes.
      • rxSend

        public Completable rxSend​(Buffer packet,
                                  int port,
                                  String host)
        Write the given Buffer to the SocketAddress.
        Parameters:
        packet - the Buffer to write
        port - the host port of the remote peer
        host - the host address of the remote peer
        Returns:
        a future notified once the write completes.
      • sender

        public WriteStream<Buffer> sender​(int port,
                                          String host)
        Returns a WriteStream able to send to the SocketAddress.
        Parameters:
        port - the port of the remote peer
        host - the host address of the remote peer
        Returns:
        the write stream for sending packets
      • send

        public Completable send​(String str,
                                int port,
                                String host)
        Write the given String to the SocketAddress using UTF8 encoding.
        Parameters:
        str - the String to write
        port - the host port of the remote peer
        host - the host address of the remote peer
        Returns:
        a future notified once the write completes.
      • rxSend

        public Completable rxSend​(String str,
                                  int port,
                                  String host)
        Write the given String to the SocketAddress using UTF8 encoding.
        Parameters:
        str - the String to write
        port - the host port of the remote peer
        host - the host address of the remote peer
        Returns:
        a future notified once the write completes.
      • send

        public Completable send​(String str,
                                String enc,
                                int port,
                                String host)
        Write the given String to the SocketAddress using the given encoding.
        Parameters:
        str - the String to write
        enc - the charset used for encoding
        port - the host port of the remote peer
        host - the host address of the remote peer
        Returns:
        a future notified once the write completes.
      • rxSend

        public Completable rxSend​(String str,
                                  String enc,
                                  int port,
                                  String host)
        Write the given String to the SocketAddress using the given encoding.
        Parameters:
        str - the String to write
        enc - the charset used for encoding
        port - the host port of the remote peer
        host - the host address of the remote peer
        Returns:
        a future notified once the write completes.
      • close

        public Completable close()
        Closes the DatagramSocket implementation asynchronous and notifies the handler once done.
        Returns:
        a future notified once the socket is closed
      • rxClose

        public Completable rxClose()
        Closes the DatagramSocket implementation asynchronous and notifies the handler once done.
        Returns:
        a future notified once the socket is closed
      • listenMulticastGroup

        public Completable listenMulticastGroup​(String multicastAddress)
        Joins a multicast group and listens for packets send to it.
        Parameters:
        multicastAddress - the address of the multicast group to join
        Returns:
        a future notified once the operation completes
      • rxListenMulticastGroup

        public Completable rxListenMulticastGroup​(String multicastAddress)
        Joins a multicast group and listens for packets send to it.
        Parameters:
        multicastAddress - the address of the multicast group to join
        Returns:
        a future notified once the operation completes
      • listenMulticastGroup

        public Completable listenMulticastGroup​(String multicastAddress,
                                                String networkInterface,
                                                String source)
        Joins a multicast group and listens for packets send to it on the given network interface.
        Parameters:
        multicastAddress - the address of the multicast group to join
        networkInterface - the network interface on which to listen for packets.
        source - the address of the source for which we will listen for multicast packets
        Returns:
        a future notified once the operation completes
      • rxListenMulticastGroup

        public Completable rxListenMulticastGroup​(String multicastAddress,
                                                  String networkInterface,
                                                  String source)
        Joins a multicast group and listens for packets send to it on the given network interface.
        Parameters:
        multicastAddress - the address of the multicast group to join
        networkInterface - the network interface on which to listen for packets.
        source - the address of the source for which we will listen for multicast packets
        Returns:
        a future notified once the operation completes
      • unlistenMulticastGroup

        public Completable unlistenMulticastGroup​(String multicastAddress)
        Leaves a multicast group and stops listening for packets send to it.
        Parameters:
        multicastAddress - the address of the multicast group to leave
        Returns:
        a future notified once the operation completes
      • rxUnlistenMulticastGroup

        public Completable rxUnlistenMulticastGroup​(String multicastAddress)
        Leaves a multicast group and stops listening for packets send to it.
        Parameters:
        multicastAddress - the address of the multicast group to leave
        Returns:
        a future notified once the operation completes
      • unlistenMulticastGroup

        public Completable unlistenMulticastGroup​(String multicastAddress,
                                                  String networkInterface,
                                                  String source)
        Leaves a multicast group and stops listening for packets send to it on the given network interface.
        Parameters:
        multicastAddress - the address of the multicast group to join
        networkInterface - the network interface on which to listen for packets.
        source - the address of the source for which we will listen for multicast packets
        Returns:
        a future notified once the operation completes
      • rxUnlistenMulticastGroup

        public Completable rxUnlistenMulticastGroup​(String multicastAddress,
                                                    String networkInterface,
                                                    String source)
        Leaves a multicast group and stops listening for packets send to it on the given network interface.
        Parameters:
        multicastAddress - the address of the multicast group to join
        networkInterface - the network interface on which to listen for packets.
        source - the address of the source for which we will listen for multicast packets
        Returns:
        a future notified once the operation completes
      • blockMulticastGroup

        public Completable blockMulticastGroup​(String multicastAddress,
                                               String sourceToBlock)
        Block the given address for the given multicast address and notifies the once the operation completes.
        Parameters:
        multicastAddress - the address for which you want to block the source address
        sourceToBlock - the source address which should be blocked. You will not receive an multicast packets for it anymore.
        Returns:
        a future notified once the operation completes
      • rxBlockMulticastGroup

        public Completable rxBlockMulticastGroup​(String multicastAddress,
                                                 String sourceToBlock)
        Block the given address for the given multicast address and notifies the once the operation completes.
        Parameters:
        multicastAddress - the address for which you want to block the source address
        sourceToBlock - the source address which should be blocked. You will not receive an multicast packets for it anymore.
        Returns:
        a future notified once the operation completes
      • blockMulticastGroup

        public Completable blockMulticastGroup​(String multicastAddress,
                                               String networkInterface,
                                               String sourceToBlock)
        Block the given address for the given multicast address on the given network interface and notifies the once the operation completes.
        Parameters:
        multicastAddress - the address for which you want to block the source address
        networkInterface - the network interface on which the blocking should occur.
        sourceToBlock - the source address which should be blocked. You will not receive an multicast packets for it anymore.
        Returns:
        a future notified once the operation completes
      • rxBlockMulticastGroup

        public Completable rxBlockMulticastGroup​(String multicastAddress,
                                                 String networkInterface,
                                                 String sourceToBlock)
        Block the given address for the given multicast address on the given network interface and notifies the once the operation completes.
        Parameters:
        multicastAddress - the address for which you want to block the source address
        networkInterface - the network interface on which the blocking should occur.
        sourceToBlock - the source address which should be blocked. You will not receive an multicast packets for it anymore.
        Returns:
        a future notified once the operation completes
      • listen

        public Single<DatagramSocket> listen​(int port,
                                             String host)
        Start listening on the given port and host. The handler will be called when the socket is listening.
        Parameters:
        port - the port to listen on
        host - the host to listen on
        Returns:
        a future notified once the operation completes
      • rxListen

        public Single<DatagramSocket> rxListen​(int port,
                                               String host)
        Start listening on the given port and host. The handler will be called when the socket is listening.
        Parameters:
        port - the port to listen on
        host - the host to listen on
        Returns:
        a future notified once the operation completes