diff --git a/Shorewall/changelog.txt b/Shorewall/changelog.txt index e4a7b01ee..d83816bb2 100644 --- a/Shorewall/changelog.txt +++ b/Shorewall/changelog.txt @@ -1,354 +1,2 @@ -Changes in 3.2.4 +Changes in 3.3.0 -1) Move 'do_initialize()' to functions. - -2) Move common config file parsing to functions. - -3) Fix handling of 'start' command with directory name. - --------------------------------------------------------------------------------- -Changes in 3.2.3 - -1) Add 'export' command. - -2) Apply Cedric Schieli's patch for the functions file. - -3) Implement TC_EXPERT. - -4) Correct 'del_ip_addr' screwup. - -5) Make 'detectnets' fatal with default route. - -6) Make 'check -e' behave properly with TC - -7) Fix SUBSYSLOCK. - -8) Fix mss= and the firewall zone. - -9) Add Natanael Copa's fix for BusyBox ash. - -10) Ensure that interface is UP and configured in multi-ISP 'optional' - detection. - -11) Fix "shorewall add" command - -12) Fix "shorewall refresh" so that subsequent "shorewall save" works - correctly. - -13 Fix DETECT_DNAT_IPADDRS=Yes address detection bug. - --------------------------------------------------------------------------------- -Changes in 3.2.2 - -1) Correct handling of shorewall.conf options in exported scripts. - -2) Avoid creating empty files /nat and /proxyarp. - -3) Add -f option to 'show' command. - -4) Avoid enabling deferred output hook processing during capabilities - probe. - -5) Add -n option to install.sh - -6) Add -s option to "shorewall [re]load" - -7) Add 'optional' option to providers file. - -8) Add 'reset' command to prog.footer. --------------------------------------------------------------------------------- -Changes in 3.2.1 - -1) Change the detection of physdev match to use - --physdev-out. Preparation for removal of physdev-out match - capability. - -2) Add missing edits to configuration parameters in firewall script. - -3) Fix 'hits' formatting under BusyBox 1.2.0. - -4) Remove requirement for extended marks with 'track'. - -5) Fixed output of 'hits' with spaces as delimiters in /etc/services. - -6) Fixed modules/xmodules snafu. - -7) Fix version in shorewall.conf. - -8) Add /usr/share/shorewall-lite: to the front of CONFIG_PATH in - /usr/share/shorewall/configfiles/shorewall.conf. - -------------------------------------------------------------------------------- -Changes in 3.2.0 Final - -1) Avoid extraneous double quotes in log rules generated at run-time. - -Changes in 3.2.0 RC 6 - -1) Correct generation of the balanced default route. - -2) Allow 'detect' in the ADDRESS column of the masq file. - -3) Correct some permission problems. - -------------------------------------------------------------------------------- -Changes in 3.2.0 RC 5 - -1) Fix DOA 'LITEDIR' problem in /sbin/shorewall. - -2) Stop the compiler from running iptables. - -3) Avoid problem with ash. - -4) Make the 'try' command use the correct SHOREWALL_SHELL. - -5) Don't defer Action/chain extension script processing until - run-time. - -6) Run extension script for policy chains. - -------------------------------------------------------------------------------- -Changes in 3.2.0 RC 4 - -1) Fix permissions on Limit file. - -2) Make progress messages product-specific. - -3) Add 'reload' command. - -------------------------------------------------------------------------------- -Changes in 3.2.0 RC 3 - -1) Remove hard directory references from compiled programs. - -2) Fix /nat <-> /proxyarp typo. - -3) Avoid use of symbolic link for /sbin/shorewall - -------------------------------------------------------------------------------- -Changes in 3.2.0 RC 2 - -1) Update versions. - -2) Rationalize the use of IPTABLES and LOGFORMAT. - -3) Allow Shorewall/Shorewall-lite coexistance under RPM - -------------------------------------------------------------------------------- -Changes in 3.2.0 RC 1 - -1) Update versions. - -------------------------------------------------------------------------------- -Changes in 3.2.0 Beta 8 - -1) Issue more helpful BRIDGING=No error messages. - -2) Implement "all-" in rules file. - -3) Add xmodules file. - -4) Detect devices in tcdevices entries. - -5) Fix for white-space in log prefix. - -6) Fix rule parsing of single excluded MAC address. - -------------------------------------------------------------------------------- -Changes in 3.2.0 Beta 7 - -1) Fix mark/mask validation. - -2) Restore traffic control to 'refresh'. - -3) Detect MTU for entries in /etc/shorewall/tcdevices. - -4) Avoid fatal error after missing forwardUPnP rule warning. - -------------------------------------------------------------------------------- -Changes in 3.2.0 Beta 6 - -1) Fix tc "notfound" errors when 'restart' is run out of ip-up.local. - -2) Allow 'detectnets' to work. - -3) Add TOS column to tcrules. - -4) Fix 'proxyarp' interface attribute handling. - -5) Fix default route generation in providers handling. - -6) Change interraction of 'track' and PREROUTING marking. - -------------------------------------------------------------------------------- -Changes in 3.2.0 Beta 5 - -1) Fix compilation problem on LEAF Bering. - -2) Remove traffic shaping code from the 'firewall' script to avoid - unmaintainable code duplication. - -3) Fix DETECT_DNAT_IPADDRS=No bug. - -4) Handle absense of mangle FORWARD chain. - -5) Rename the rtrules file to route_rules. - -6) Fix deletion of SNAT ip addresses. - -7) Accomodate ancient kernel's with no FORWARD or POSTROUTING in mangle. - -8) Clear SUBSYSLOCK on Debian/Ubuntu installs. - -------------------------------------------------------------------------------- -Changes in 3.2.0 Beta 4 - -1) Fix 'routeback' with bridge ports. - -2) Add support for explicit routing rules. - -3) Fix mktempdir problem. - -4) Implement HIGH_ROUTE_MARKS - -Changes in 3.2.0 Beta 3 - -1) Correct handling of verbosity in the 'try' command. - -2) Add IMPLICIT_CONTINUE option to shorewall.conf. - -3) Fix SAME/ADD_SNAT_ALIASES interaction. - -------------------------------------------------------------------------------- -Changes in 3.2.0 Beta 2 - -1) Make "shorewall start -f" work correctly. - -2) Remove SUBSYSLOCK code from default and debian footers. - -3) Add 'refreshed' extension script. - -4) Implement 'logdrop' and 'logreject' - -------------------------------------------------------------------------------- -Changes in 3.1.x. and 3.2.x - -1) Removal of dynamic zones. - -2) Implement 'generate' command. - -3) Implement 'super-quiet' mode using multiple -q options (e.g., -qq). - -4) Add back dynamic zones. - -5) Allow remote compiles. - -6) Change output of 'generate' to always be the file name entered (do not - prepend /var/lib/shorewall/) - -7) Remove some restrictions on remote compiles. - -8) Add error checking to generated script. - -9) Merge Fabio Longerai's 'length' patch. - -10) Add the "-p" option to the compile command. - -11) Fix 'check' bug in setup_masq - -12) Break compiler/firewall into two files - -13) Make Shoreall quiet for a change. - -14) Make "Compile-and-go" the only mode of operation. - -15) Remove -p - -16) Apply Tuomo's patches for IPSEC and Noecho. - -17) Fix bridging - -18) Fix QUEUE when used in the ESTABLISHED section. - -19) Apply Ed Suominen's patch to tcrules. -------------------------------------------------------------------------------- -3.1.5 - -20) Speed up compilation by rewriting 'fix_bang()'. - -21) Correct GATEWAY handling in the providers file. - -22) Remove sub-zone exclusion from DNAT/REDIRECT. - -23) Add compiled-program/library versioning scheme. - -------------------------------------------------------------------------------- -3.1.6 - -24) Apply Steven Springl's help patch. - -25) Fix 'allow/drop/reject' while Shorewall not running. - -26) Implement bi-directional macros. - -27) Fix TC bridge port handling. - -28) Fix/document "check -e" - -29) Automatically use capabilities file when non-root. - -30) Correct typo in help file ("help drop"). - -31) Added 'tcpsyn' - -------------------------------------------------------------------------------- -3.1.7 - -32) Change 'tcpsyn' to 'tcp:syn' - -33) Remove superfluous rules in MAC validation. - -34) Correct Makefile. - -35) Add -t option - -36) Restore log messages. - -37) Fix "shorewall capabilities" with VERBOSITY < 2. - -------------------------------------------------------------------------------- -3.1.8 - -38) Remove compile-time running of extension scripts. - -39) Correctly handle interfaces named 'inet'. - -40) SUBSYSLOCK functionality restored. - -------------------------------------------------------------------------------- -3.1.9 - -41) Fix Provider route generation when a specific gateway is specified. - -42) Be sure that restore file name is preserved regardless of 'set --' in - define_firewall().) - -43) Add Simon's redhat prog files. - -44) Add 'delete_nat' to compiled program. - -45) Move 'shorecap' to /usr/share/shorewall - -46) Add debian prog files. - -47) Correct syntax error in validate_policy() -------------------------------------------------------------------------------- -3.2.0 Beta 1. - -48) Streamlined some code in setup_tc1() - -49) Process /etc/shorewall/params at run-time. - -50) Add new modules to /etc/shorewall/modules. - -51) Make default behavior of "compile" distribution-neutral. diff --git a/Shorewall/fallback.sh b/Shorewall/fallback.sh index b7616e7ee..c0e4b6171 100755 --- a/Shorewall/fallback.sh +++ b/Shorewall/fallback.sh @@ -28,7 +28,7 @@ # shown below. Simply run this script to revert to your prior version of # Shoreline Firewall. -VERSION=3.2.3 +VERSION=3.3.0 usage() # $1 = exit status { diff --git a/Shorewall/install.sh b/Shorewall/install.sh index eb7bd998a..fc46e7696 100755 --- a/Shorewall/install.sh +++ b/Shorewall/install.sh @@ -22,7 +22,7 @@ # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA # -VERSION=3.2.3 +VERSION=3.3.0 usage() # $1 = exit status { diff --git a/Shorewall/releasenotes.txt b/Shorewall/releasenotes.txt index 6674061d5..4aa6301e4 100644 --- a/Shorewall/releasenotes.txt +++ b/Shorewall/releasenotes.txt @@ -1,6 +1,6 @@ -Shorewall 3.2.4 +Shorewall 3.3.0 - Note to users upgrading from Shorewall 2.x or 3.0 + Note to users upgrading from Shorewall 3.0 or 3.2 Most problems associated with upgrades come from two causes: @@ -31,816 +31,14 @@ Shorewall 3.2.4 Please see the "Migration Considerations" below for additional upgrade information. -Problems Corrected in 3.2.4 +Problems Corrected in 3.3.0 -1) Previously, the directory name in the command "shorewall start - " was being dropped by "/sbin/shorewall". +None. -Other changes in 3.2.4 +Other changes in 3.3.0 None. Migration Considerations: - 1) If you are upgrading from Shorewall 2.x, it is essential that you read - the Shorewall 3.0.8 (or later) release notes: - - http://www.shorewall.net/pub/shorewall/3.0/shorewall-3.0.8/releasenotes.txt - - 2) A number of macros have been split into two. The macros affected are: - - IMAP LDAP NNTP POP3 SMTP - - Each of these macros now handles only traffic on the native (plaintext) - port. There is a corresponding macro with S added to the end of the - name for the SSL version of the same protocol. Thus each macro results - in the insertion of only one port per invocation. - - The Web macro has not been split, but two new macros, HTTP and HTTPS have - been created. The Web macro is deprecated in favour of these new macros, - and may be removed from future Shorewall releases. - - These changes have been made to ensure no unexpected ports are opened due - to the use of macros. - - 3) In previous Shorewall releases, DNAT and REDIRECT rules supported a - special syntax for exclusion of a sub-zone from the effect of the rule. - - Example: - - Z2 is a subzone of Z1: - - DNAT Z1!Z2 loc:192.168.1.4 ... - - That feature has never worked correctly when Z2 is a dynamic zone. - Furthermore, now that Shorewall supports exclusion lists, the capability - is redundant since the above rule can now be written in the form: - - DNAT Z1:! loc:192.168.1.4 ... - - Beginning with Shorewall 3.2.0, the special exclusion syntax will no - longer be supported. - - 4) Important if you use the QUEUE target. - - In the /etc/shorewall/rules file and in actions, you may now specify - 'tcp:syn' in the PROTO column. 'tcp:syn' is equivalent to 'tcp' but also - requires that the SYN flag is set and the RST, FIN and ACK flags be - off ("--syn" is added to the iptables rule). - - As part of this change, Shorewall no longer adds the "--syn" option - to TCP rules that specify QUEUE as their target. - - 5) Extension Scripts may require change - - In previous releases, extension scripts were executed during [re]start - by using the Bourne Shell "." operator. In addition to executing commands - during [re]start, these scripts had to "save" the commands to be executed - during "shorewall restore". - - This clumsiness has been eliminated in Shorewall 3.2. In Shorewall 3.2, - extension scripts are copied in-line into the compiled program and are - executed in-line during "start", "restart" and "restore". This - applies to all extension scripts except those associated with a - chain or action -- those extension scripts continue to be processed - at compile time. - - This new approach has two implications for existing scripts. - - a) It is no longer necessary to save the commands; so functions like - 'save_command', 'run_and_save_command' and 'ensure_and_save_command' - need no longer be called. For convenience, the generated program will - supply functions with these names: - - save_command() - does nothing - run_and_save_command() - runs the passed command - ensure_and_save_command() - runs the passed command and - stops/restores the firewall if the - command fails. - - These functions should provide for transparent migration of - scripts that use them until you can get around to eliminating - their use completely. - - b) When the extension script is copied into the compiled program, it - is indented to line up with the surrounding code. If you have 'awk' - installed on your system, the Shorewall compiler will correctly handle - line continuation (last character on the line = "\"). If you do not - have awk, it will not be possible to use line-continuation in your - extension scripts. - - In no case is it possible to continue a quoted string over multiple lines - without having additional whitespace inserted into the string. - - 6) Beginning with this release, the way in which packet marking in the - PREROUTING chain interracts with the 'track' option in /etc/shorewall/providers - has changed in two ways: - - a) Packets arriving on a tracked interface are now passed to the PREROUTING - marking chain so that they may be marked with a mark other than the - 'track' mark (the connection still retains the 'track' mark). - - b) When HIGH_ROUTE_MARKS=Yes, you can still clear the mark on packets - in the PREROUTING chain (i.e., you can specify a mark value of zero). - - 7) Kernel version 2.6.16 introduces 'xtables', a new common packet - filtering and connection tracking facility that supports both IPv4 - and IPv6. Because a different set of kernel modules must be loaded - for xtables, Shorewall now includes two 'modules' files: - - a) /usr/share/shorewall/modules -- the former - /etc/shorewall/modules - - b) /usr/share/shorewall/xmodules -- a new file that support - xtables. - - If you wish to use the new file, then simply execute this command: - - cp -f /usr/share/shorewall/xmodules /etc/shorewall/modules - - 8) Previously, CLASSIFY tcrules were always processed out of the - POSTROUTING chain. Beginning with this release, they are processed - out of the POSTROUTING chain *except* when the SOURCE is - $FW[:
] in which case the rule is processed out of the - OUTPUT chain. - - With correctly-coded rulesets, this change should have no - effect. Users having incorrectly-coded tcrules may need to change - them. - - Example: - - #MARK/ SOURCE DEST PROTO DEST SOURCE - #CLASSIFY PORTS(S) PORT(S) - 1:110 $FW eth3 tcp - 22 - - While the user may have expected this rule to only affect traffic - from the firewall itself, the rule was really equivalent to this one: - - #MARK/ SOURCE DEST PROTO DEST SOURCE - #CLASSIFY PORTS(S) PORT(S) - 1:110 0.0.0.0/0 eth3 tcp - 22 - - So after this change, the second rule will be required rather than - the first if that is what was really wanted. - - New Features: - - 1) Shorewall has always been very noisy (lots of messages). No longer. - - You set the default level of verbosity using the VERBOSITY option in - shorewall.conf. If you don't set it (as would be the case if you use your - old shorewall.conf file) then VERBOSITY defaults to a value of 2 which - results in behavior compatible with previous Shorewall versions. - A value of 1 suppresses some of the output (like the old -q option did) - while a value of 0 makes Shorewall almost silent. A value of -1 - suppresses all output except warning and error messages. - - The value specified in the 3.2 shorewall.conf is 1. So you can make - Shorewall as verbose as previously using a single -v and you can make it - almost silent by using a single -q. - - If VERBOSITY is set at 2, you can still make a command nearly - silent by using two "q"s (e.g., shorewall -qq restart). - - In summary, each "q" subtracts one from VERBOSITY while each "v" adds one - to VERBOSITY. - - The "shorewall show log", "shorewall logwatch" and "shorewall dump" - commands require VERBOSITY to be greater than or equal to 3 to - display MAC addresses.This is consistent with the previous - implementation which required a single -v to enable MAC display but - means that if you set VERBOSITY=0 in shorewall.conf, then you will - need to include -vvv in commands that display log records in order - to have MACs displayed. - - To make the display of MAC addresses less cumbersome, a '-m' option has - been added to the "show" and logwatch commands: - - shorewall show -m log - shorewall logwatch -m - - 2) A new 'shorewall compile' command has been added. - - shorewall compile [ -e ] [ ]