Fwctl::Services::dhcp - Fwctl module to handle the dhcp protocol.


Fwctl documentation Contained in the Fwctl distribution.

Index


Code Index:

NAME

Top

Fwctl::Services::dhcp - Fwctl module to handle the dhcp protocol.

SYNOPSIS

Top

    accept  dhcp -src INTERNAL_NET -dst DHCP_SERVER
    deny    dhcp -src INTERNAL_NET -nolog
    account dhcp -src INTERNAL_NET

DESCRIPTION

Top

This module is used to handle the DHCP protocol. It adds rules to handle the special addresses used by the DHCP protocol. Since DHCP is a broadcast based protocol restricted to local segment, so which by definition doesn't cross a firewall, who would want to use such a module ?

Two use, first to prevent clutter of log files which denied dhcp broadcast packets when you are using DHCP on the internal network. Second, when your firewall is acting as a DHCP server to the internal network. ??? Who would want to do that ??? Someone trying to replace all WinGate installations with linux based solutions ;-).

AUTHOR

Top

Francis J. Lacoste <francis.lacoste@iNsu.COM>

COPYRIGHT

Top

SEE ALSO

Top

fwctl(8) Fwctl(3) Fwctl::RuleSet(3)


Fwctl documentation Contained in the Fwctl distribution.

#
#    dhcp.pm: Fwctl service module to handle the dhcp protocol.
#
#    This file is part of Fwctl.
#
#    Author: Francis J. Lacoste <francis@iNsu.COM>
#
#    Copyright (c) 1999,2000 iNsu Innovations Inc.
#
#    This program is free software; you can redistribute it and/or modify
#    it under the terms of the GNU General Public License as published by
#    the Free Software Foundation; either version 2 of the License, or
#    (at your option) any later version.
#
package Fwctl::Services::dhcp;

use strict;

use Fwctl::RuleSet qw(:ip_rulesets :ports);
use IPChains;

sub new {
  my $proto = shift;
  my $class = ref $proto || $proto;
  bless {}, $class;
}

sub prototypes {
  my ($self,$target,$options) = @_;

  # Build prototype rule
  (
   # Client
   IPChains->new(
		 Rule	    => $target,
		 Prot	    => 'udp',
		 SourcePort => 'bootpc',
		 DestPort   => 'bootps',
		 %{$options->{ipchains}},
		),
   # Server
   IPChains->new(
		 Rule	    => $target,
		 Prot	    => 'udp',
		 SourcePort => 'bootps',
		 DestPort   => 'bootpc',
		 %{$options->{ipchains}},
		),
  );
}

sub block_rules {
  my $self = shift;
  my ( $target, $src, $src_if, $dst, $dst_if, $options ) = @_;

  my ($client,$server) = $self->prototypes( $target, $options );
  block_ip_ruleset( $client, "0.0.0.0", $src_if, "255.255.255.255", $dst_if );
  block_ip_ruleset( $server, $dst, $dst_if, "255.255.255.255", $src_if );
  block_ip_ruleset( $client, $src, $src_if, $dst, $dst_if );
  block_ip_ruleset( $client, $src, $src_if, "255.255.255.255", $dst_if );
  block_ip_ruleset( $server, $dst, $dst_if, $src, $src_if );
}

sub accept_rules {
  my $self = shift;
  my ( $target, $src, $src_if, $dst, $dst_if, $options ) = @_;

  my ($client,$server) = $self->prototypes( $target, $options );
  accept_ip_ruleset( $client, "0.0.0.0", $src_if, "255.255.255.255", $dst_if );
  accept_ip_ruleset( $server, $dst, $dst_if, "255.255.255.255", $src_if );
  accept_ip_ruleset( $client, $src, $src_if, $dst, $dst_if );
  accept_ip_ruleset( $client, $src, $src_if, "255.255.255.255", $dst_if );
  accept_ip_ruleset( $server, $dst, $dst_if, $src, $src_if );

}

sub account_rules {
  my $self = shift;
  my ( $target, $src, $src_if, $dst, $dst_if, $options ) = @_;

  my ($client,$server) = $self->prototypes( $target, $options );
  acct_ip_ruleset( $client, "0.0.0.0", $src_if, "255.255.255.255", $dst_if );
  acct_ip_ruleset( $server, $dst, $dst_if, "255.255.255.255", $src_if );
  acct_ip_ruleset( $client, $src, $src_if, $dst, $dst_if );
  acct_ip_ruleset( $client, $src, $src_if, "255.255.255.255", $dst_if );
  acct_ip_ruleset( $server, $dst, $dst_if, $src, $src_if );

}

sub valid_options {
  my  $self = shift;
  ( );
}

1;