Monday, 2024/09/16, 3:45 AM


Main
Registration
Login
Hackersoft Welcome Guest | RSS  
Site menu

Our poll
Rate my site
Total of answers: 11048

Statistics

Total online: 1
Guests: 1
Users: 0

Firewall

Introduction

The Linux kernel includes the Netfilter subsystem, which is used to manipulate or decide the fate of network traffic headed into or

through your server. All modern Linux firewall solutions use this system for packet filtering.The kernel's packet filtering system

would be of little use to administrators without a userspace interface to manage it. This is the purpose of iptables. When a packet

reaches your server, it will be handed off to the Netfilter subsystem for acceptance, manipulation, or rejection based on the rules supplied

to it from userspace via iptables. Thus, iptables is all you need to manage your firewall if you're familiar with it, but many frontends

are available to simplify the task.

ufw - Uncomplicated Firewall

The default firewall configuration tool for Ubuntu is ufw. Developed to ease iptables firewall configuration, 

ufw provides a user friendly way to create an

IPv4 or IPv6 host-based firewall.

ufw by default is initially disabled. From the ufw man page:

" ufw is not intended to provide complete firewall functionality via its command interface, but instead provides

an easy way to add or remove simple rules.

It is currently mainly used for host-based firewalls. 

The following are some examples of how to use ufw:

  • First, ufw needs to be enabled. From a terminal prompt enter:

  • sudo ufw enable

  • To open a port (ssh in this example):

  • sudo ufw allow 22
  • Similarly, to close an opened port:

  • sudo ufw deny 22
  • To remove a rule, use delete followed by the rule:

    sudo ufw delete deny 22
  • It is also possible to allow access from specific hosts or networks to a port. The following example

  • Allows ssh access from host 192.168.0.2 to any ip address on this host:

    sudo ufw allow proto tcp from 192.168.0.2 to any port 22

    Replace 192.168.0.2 with 192.168.0.0/24 to allow ssh access from the entire subnet.

  • ufw can be disabled by: sudo ufw disable

[Note]

If the port you want to open or close is defined in /etc/services, you can use the port name instead of the number. In the above examples, replace 22 with ssh.

This is a quick introduction to using ufw. Please refer to the ufw man page for more information.

IP Masquerading

The purpose of IP Masquerading is to allow machines with private, non-routable IP addresses on your network to access

the Internet through the machine doing the masquerading. Traffic from your private network destined for the Internet must

be manipulated for replies to be routable back to the machine that made the request. To do this, the kernel must modify

thesource IP address of each packet so that replies will be routed back to it, rather than to the private IP address that

made the request, which is impossible over the Internet. Linux uses Connection Tracking (conntrack) to keep track of

which connections belong to which machines and reroute each return packet accordingly. Traffic leaving your private

network is thus "masqueraded" as having originated from your Ubuntu gateway machine. This process is referred to

in Microsoft documentation as Internet Connection Sharing.

ufw Masquerading

IP Masquerading can be achieved using custom ufw rules. This is possible because the current back-end for 

ufw isiptables-restore with the rules files located in /etc/ufw/*.rules. These files are a great place to add

legacy iptables rules used without ufw, and rules that are more network gateway or bridge related.The rules are split

into two different files, rules that should be executed before ufw command line rules, and rules that are executed after 

ufw command line rules.

  • First, packet forwarding needs to be enabled in ufw. Two configuration files will need to be adjusted,

  • in/etc/default/ufw change the DEFAULT_FORWARD_POLICY to "ACCEPT”:

    DEFAULT_FORWARD_POLICY="ACCEPT"

    Then edit /etc/ufw/sysctl.conf and uncomment: net.ipv4.ip_forward=1

  • Similarly, for IPv6 forwarding uncomment: net.ipv6.conf.default.forwarding=1

  • Now we will add rules to the /etc/ufw/before.rules file. The default rules only configure the filter table,

  • And to enable masquerading the nat table will need to be configured.

  • Add the following to the top of the file just after the header comments:

    # nat Table rules
    *nat
    :POSTROUTING ACCEPT [0:0]

    # Forward traffic from eth1 through eth0.
    -A POSTROUTING -s 192.168.0.0/24 -o eth0 -j MASQUERADE

    # don't delete the 'COMMIT' line or these nat table rules won't be processed
    COMMIT

    The comments are not strictly necessary, but it is considered good practice to document your configuration.

  • Also, when modifying any of the rules files in /etc/ufw,

  • make sure these lines are the last line for each table modified:

  • # don't delete the 'COMMIT' line or these rules won't be processed
    COMMIT
  • Finally, disable and re-enable ufw to apply the changes:

  • sudo ufw disable && sudo ufw enable

IP Masquerading should now be enabled. You can also add any additional FORWARD rules to the /etc/ufw/before.rules.

It is recommended that these additional

rules be added to the ufw-before-forward chain.

iptables Masquerading

iptables can also be used to enable masquerading.

  • Similar to ufw, the first step is to enable IPv4 packet forwarding by editing /etc/sysctl.conf and uncomment the following line

    net.ipv4.ip_forward=1

    If you wish to enable IPv6 forwarding also uncomment: net.ipv6.conf.default.forwarding=1

  • Next, execute the sysctl command to enable the new settings in the configuration file:

    sudo sysctl -p
  • IP Masquerading can now be accomplished with a single iptables rule, which may differ slightly based on your network configuration:

    sudo iptables -t nat -A POSTROUTING -s 192.168.0.0/16 -o ppp0 -j MASQUERADE

    The above command assumes that your private address space is 192.168.0.0/16 and that your Internet-facing device is ppp0.

  • The syntax is broken down as follows:

    • -t nat -- the rule is to go into the nat table

    • -A POSTROUTING -- the rule is to be appended (-A) to the POSTROUTING chain

    • -s 192.168.0.0/16 -- the rule applies to traffic originating from the specified address space

    • -o ppp0 -- the rule applies to traffic scheduled to be routed through the specified network device

    • -j MASQUERADE -- traffic matching this rule is to "jump" (-j) to the MASQUERADE target to be manipulated as described above

  • Also, each chain in the filter table (the default table, and where most or all packet filtering occurs) has a default policyof ACCEPT,

  • but if you are creating a firewall in addition to a gateway device,

  • you may have set the policies to DROP or REJECT, in which case your masqueraded traffic needs to be allowed

  • Through the FORWARD chain for the above rule to work:

  • sudo iptables -A FORWARD -s 192.168.0.0/16 -o ppp0 -j ACCEPT
    sudo iptables -A FORWARD -d 192.168.0.0/16 -m state --state ESTABLISHED,RELATED -i ppp0 -j ACCEPT

    The above commands will allow all connections from your local network to the Internet and all traffic related to those

  • Connections to return to the machine that initiated them.

  • If you want masquerading to be enabled on reboot, which you probably do, edit /etc/rc.local and add any commands used above.

  • For example add the first command with no filtering:

    iptables -t nat -A POSTROUTING -s 192.168.0.0/16 -o ppp0 -j MASQUERADE

Logs

Firewall logs are essential for recognizing attacks, troubleshooting your firewall rules, and noticing unusual activity on your

network. You must include logging rules in your firewall for them to be generated, though, and logging rules must come

before any applicable terminating rule (a rule with a target that decides the fate of the packet, such as ACCEPT, DROP, or REJECT).

If you are using ufw, you can turn on logging by entering the following in a terminal:

sudo ufw logging on

To turn logging off in ufw, simply replace on with off in the above command.

If using iptables instead of ufw, enter:

sudo iptables -A INPUT -m state --state NEW -p tcp --dport 80 -j LOG --log-prefix "NEW_HTTP_CONN: "

A request on port 80 from the local machine, then, would generate a log in dmesg that looks like this:

[4304885.870000] NEW_HTTP_CONN: IN=lo OUT= MAC=00:00:00:00:00:00:00:00:00:00:00:00:08:00 SRC=127.0.0.1 DST=127.0.0.1
LEN=60 TOS=0x00 PREC=0x00 TTL=64 ID=58288 DF PROTO=TCP SPT=53981 DPT=80 WINDOW=32767 RES=0x00 SYN URGP=0

The above log will also appear in /var/log/messages, /var/log/syslog, and /var/log/kern.log.

This behavior can be modified by editing /etc/syslog.conf appropriately or by installing and configuring ulogd and using the

ULOG target instead of LOG. The ulogd daemon is a userspace server that listens for logging instructions from the kernel specifically for

firewalls, and can log to any file you like, or even to a PostgreSQL or MySQL database. Making sense of your firewall logs can be simplified by using a log analyzing

tool such as fwanalog, fwlogwatch, or lire.

Other Tools

There are many tools available to help you construct a complete firewall without intimate knowledge of iptables. For the GUI-inclined:

  • Firestarter is quite popular and easy to use.

  • fwbuilder is very powerful and will look familiar to an administrator who has used a commercial firewall utility such asCheckpoint FireWall-1.

If you prefer a command-line tool with plain-text configuration files:

  • Shorewall is a very powerful solution to help you configure an advanced firewall for any network.

  • ipkungfu should give you a working firewall "out of the box" with zero configuration, and will allow you to easily set up a more advanced firewall

  • By editing simple, well-documented configuration files.

  • fireflier is designed to be a desktop firewall application. It is made up of a server (fireflier-server) and your choice of GUI clients (GTK or QT),

  • and behaves like many popular interactive firewall applications for Windows.

Sign in

Calendar
«  September 2024  »
SuMoTuWeThFrSa
1234567
891011121314
15161718192021
22232425262728
2930

IP

Copyright Hackerssoft © 2024