Net::Libdnet.3pm

Langue: en

Autres versions - même langue

Version: 2004-09-06 (mandriva - 01/05/08)

Section: 3 (Bibliothèques de fonctions)

NAME

Net::Libdnet - Perl interface to libdnet

SYNOPSIS

use Net::Libdnet;

DESCRIPTION

All the following functions return undef and print a warning message to the standard error when a problem occurs.

Some of the functions in the original dnet were omited, because we only deal with the string representation of addresses. We also avoid passing handlers to the user, as we open and subsequently close them for each request. Moreover, the XXX_loop() functions are not implemented yet.

Network addressing

addr_cmp($address_a, $address_b) -> $int_distance

Compares network addresses a and b, returning an integer less than, equal to, or greater than zero if a is found, respectively, to be less than, equal to, or greater than b. Both addresses must be of the same address type.

addr_bcast($address/netmask) -> $address_broadcast

Computes the broadcast address for the specified network.

addr_net($address/netmask) -> $address_network

Computes the network address for the specified network.

Address Resolution Protocol

arp_add($protocol_address, $hardware_address) -> 1

Adds a new ARP entry.

arp_delete($protocol_address) -> 1

Deletes the ARP entry for the specified protocol address.

arp_get($protocol_address) -> $hardware_address

retrieves the ARP entry for the specified protocol address.

Binary buffers

Not implemented yet.

Ethernet

Not implemented yet.

Firewalling

Not implemented yet.

Network interfaces

Interfaces are manipulated as hashes with the following structure:

  {
      len => ... ,
      name => ... ,
      type => ... ,
      flags => ... ,
      mtu => ... ,
      addr => ... ,
      dst_addr => ... ,
      link_addr => ... ,
  #   alias_num => ... ,
  #   alias_addrs => ... ,
  };
 
 

Processing interface aliases is not implemented yet.

intf_get($name) -> %interface

Retrieves an interface configuration entry, keyed on name.

intf_get_src($local_address) -> %interface

Retrieves the configuration for the interface with the specified primary address.

intf_get_dst($remote_address) -> %interface

Retrieves the configuration for the best interface with which to reach the specified destination address.

intf_set(%interface) -> 1

Not implemented yet.

Sets the interface configuration entry. Please retrieve first the configuration, and do not build from scratch.

Internet Protocol

Not implemented yet.

Random number generation

Not implemented yet.

Routing

route_add($destination_address, $gateway_address) -> 1

Adds a new route, to the specified destination prefix over the given gateway.

route_delete($destination_address) -> 1

Deletes the routing table entry for the destination prefix.

route_get($destination_address) -> $gateway_address

Retrieves the routing table entry for the destination prefix.

TODO

intf_set, hash2intf

SEE ALSO

dnet(3)

POD ERRORS

Hey! The above document had some coding errors, which are explained below:
Around line 224:
'=item' outside of any '=over'
Around line 237:
You forgot a '=back' before '=head1'