root/fwknop/tags/fwknop-1.9.11/ChangeLog

Revision 1433, 66.5 kB (checked in by mbr, 9 months ago)

tagged fwknop-1.9.11

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1 fwknop-1.9.11 (05/11/2009):
2     - (Julien Picalaus) Contributed patches to implement a proper interface to
3       use ipfw 'sets' on systems running ipfw firewalls.  This involved
4       changes to fwknopd, knoptm, and the fwknop.conf file like so:
5       Added a test to see if the local ipfw firewall policy is using dynamic
6       rules. Added ipfw_move_rule() so that rules can be moved from one set to
7       another. Added ipfw_disable() set subroutine and it is called at init for
8       IPFW_SET_NUM (except when ipfw isn't using dynamic rules).  Made sure
9       that rule finding includes disabled rules (ipfw list -S and changes to
10       regexp) and returning the set in addition to the rule number.  When
11       granting access, if a corresponding disabled rule already exists, enable
12       it instead of adding a new one (except when ipfw isn't using dynamic
13       rules). When adding rules, only use keep-state if there are already
14       dynamic rules.  Added IPFW_SET_NUM so that the set number for new ipfw
15       can be specified, and add IPFW_DYNAMIC_INTERVAL so that the interval
16       over which rules that have no associated dynamic rules are removed (the
17       default is 60 seconds).
18     - (Franck Joncourt) Bug fix to add -O command line arg to knopwatchd to
19       specify an override config file if one is given on the fwknopd command
20       line.
21     - Added --icmp-type and --icmp-code command line arguments for the fwknop
22       client in order to manually set the ICMP type/code values when using
23       "--Spoof-proto icmp" or "--Server-proto icmp".  Also restructured how
24       SPA packets are sent over the various protocols.  Here is an example of
25       sending an SPA packet over an ICMP packet with type "123" and code
26       "123" (not normal ICMP type/code values) with the pcap trace shown:
27
28       # fwknop -A tcp/22 -s --Server-proto icmp --icmp-type 123 --icmp-code
29       123 -D 127.0.0.1
30
31       # tcpdump -i lo -l -nn icmp or udp -s 0 -X
32       tcpdump: verbose output suppressed, use -v or -vv for full protocol
33       decode listening on lo, link-type EN10MB (Ethernet), capture size 65535
34       bytes
35
36       07:24:32.527221 IP 127.0.0.1 > 127.0.0.1: ICMP type-#123, length 169
37         0x0000:  4510 00bd 0000 4000 4001 3c2e 7f00 0001  E.....@.@.<.....
38         0x0010:  7f00 0001 7b7b e66f 0000 0000 2b63 6a6f  ....{{.o....+cjo
39         0x0020:  5049 6138 7345 7a35 4864 7955 5176 624b  PIa8sEz5HdyUQvbK
40         0x0030:  6637 6f51 5934 4e36 4c6c 3454 6931 4453  f7oQY4N6Ll4Ti1DS
41         0x0040:  2b4f 3756 6636 4775 6234 756f 6738 4432  +O7Vf6Gub4uog8D2
42         0x0050:  3155 4377 5259 6b52 2b30 354b 7043 6b33  1UCwRYkR+05KpCk3
43         0x0060:  4f66 452f 4f32 6737 6d37 5064 4846 4842  OfE/O2g7m7PdHFHB
44         0x0070:  7a32 4745 3766 7a31 4a4c 7652 764e 626c  z2GE7fz1JLvRvNbl
45         0x0080:  7a4a 7250 5355 3665 5051 5375 7a54 394b  zJrPSU6ePQSuzT9K
46         0x0090:  702b 4446 4a79 7a6b 3847 6c51 6a70 3564  p+DFJyzk8GlQjp5d
47         0x00a0:  3957 3673 4f52 7945 3771 6f57 6b56 634e  9W6sORyE7qoWkVcN
48         0x00b0:  4e41 6167 6231 5a79 6a63 4834 49         NAagb1ZyjcH4I
49
50     - Updated all unpack() calls for packet decoding in fwknopd to use the
51       "mN" format instead of "m[N]" format for proper operation on older
52       versions of perl.  On FreeBSD 7.0 with perl-5.6.2 the following error
53       is generated without this fix: "Invalid type in unpack: '['".
54     - Bug fix to not require that gpg is installed in order to install fwknop.
55     - (Franck Joncourt) Documentation updates for the knopwatchd.8 man page
56       to include the latest command line options.
57     - (Martin Ferrari) Bug fix to provide a work around for fwknopd segfaults
58       on Debian systems when the version of Net::Pcap that is installed comes
59       from doing 'apt-get install fwknop-server'.  See the thread at
60       http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=508432 for more info.
61     - Bug fix to ensure that UDP rules in ipfw firewalls are timed out
62       correctly by knoptm (the problem was that 'keep-state' was required).
63     - (Test suite): Added tests for multi-port access requests.  So, to gain
64       access to tcp/22,udp/1194 with one SPA packet, the test suite verifies
65       that the code support this.
66     - (Test suite): Started on updates to handle the upcoming libfko C
67       implementation of Single Packet Authorization (the command line args
68       are somewhat different).
69     - (Test suite): Added support for multiple include/exclude test
70       identifying strings (separated by commas).  For example, to run the
71       'Setup', 'Basic', and 'Replay' tests, just do:
72
73       ./fwknop_test.pl --include Setup,Basic,Replay
74
75     - (Test suite): Added the ability to test sending SPA packets over ICMP.
76     - (Test suite): Added import_perl_modules() routine from fwknop itself to
77       enforce the usage of the same perl modules as those that fwknop
78       references.  The main application of this is for the Net::RawIP module
79       which is used by the test suite for the SPA over ICMP tests.
80
81 fwknop-1.9.10 (01/12/2009):
82     - Added the ability to send SPA packet over HTTP to a webserver.  This
83       requires that the same running fwknopd is also running a webserver, or
84       that ENABLE_TCP_SERVER is enabled so that fwknopd spawns fwknop_serv to
85       listen on a real TCP socket.  Sending SPA packets over HTTP is
86       accomplished with a new command line argument --HTTP on the fwknop
87       client command line, and via a new configuration variable
88       ENABLE_SPA_OVER_HTTP in the fwknop.conf file.
89     - Added ENABLE_EXTERNAL_CMDS for fwknopd to control whether the
90       EXTERNAL_CMD_OPEN and EXTERNAL_CMD_CLOSE directives are used (instead of
91       just checking whether they are set to __NONE__);
92     - Bug fix to make sure to properly construct hash reference for the
93       "include" command list for the check_commands() function when checking
94       for the mail command.
95     - Bug fix for fwknopd to not require Net::Pcap::lookupnet() to succeed on
96       interfaces with no IPv4 address assigned.  This function sets the IP and
97       netmask of the local interface, but if fwknopd sniffs an interface
98       without any IP assigned, then such information will not necessarily
99       exist.
100     - Bug fix to add --Override config support to knopwatchd (Franck
101       Joncourt).
102     - Bug fix to add client timeout (--fw-timeout) support to both forward
103       NAT and local NAT modes (Damien Stuart).  This required increasing the
104       number of expected fields in decrypted SPA packets in fwknopd.
105     - Bug fix in the install.pl script for Cygwin systems (or others where a
106       client-mode only install is done) to take into account the newer perl
107       library path handling code.
108     - Updated minimum ICMP header length to 8 bytes in fwknopd to accept
109       spoofed SPA packets over ICMP echo requests.
110     - Added config dumping support to knopwatchd with -D (Franck Joncourt).
111     - Minor code cleanups and updates to knopwatched (such as the usage of
112       isspace() to allow tab chars between variable names and values in the
113       fwknop.conf file (Franck Joncourt).
114     - Added ENABLE_COOKED_INTF to force fwknopd to always treat the sniffing
115       interface as the "cooked" interface type found on Linux.
116     - Updated knopwatchd to allow more than one overwrite file (Franck
117       Joncourt).
118     - Added --Single-mod-install to the perl installer so that individual
119       module dependencies can be installed piecemeal.
120     - (Test suite): Bug fix for the proper usage of the 'ps' command on
121       FreeBSD and Mac OS X systems.  The test suite now runs successfully on
122       these systems after this fix.
123     - (Test suite): Added the ability to test sending SPA packets over
124       established TCP connections with the fwknop_serv daemon.
125     - (Test suite): Added support for collecting *.warn and *.die output for
126       each test as it is executed and appending this data to each test output
127       file.
128
129 fwknop-1.9.9 (11/13/2008):
130     - Added support to fwknop for the Linux 'any' interface which allows SPA
131       packets to be received on multiple interfaces on a Linux system.  This
132       is useful for running fwknop on a dual-homed Linux host, and then
133       accepting SPA packets on either the internal or external interface so
134       that SPA packets can influence the packet filter from either network.
135     - Added support for interfacing fwknop with third party software through
136       the addition of three new variables in the access.conf file (or set
137       globally in the fwknop.conf file): EXTERNAL_CMD_OPEN,
138       EXTERNAL_CMD_CLOSE, and EXTERNAL_CMD_ALARM.
139             The "open" and "close" commands might be manually supplied firewall
140       commands, and both support variable substitution of any of the variables
141       in the access.conf file with "$VAR".  Also, three special variables are
142       supported: $SRC, $PORT, and $PROTO, which are derived from actual values
143       from within valid SPA packets (as opposed to $SOURCE from access.conf
144       which may contain a list of networks instead of a single IP address).
145         Here are some examples:
146         - Execute a specific iptables command on behalf of the source IP
147           in a valid SPA packet to add a new ACCEPT rule, and execute another
148           command (to delete the same rule after a timeout):
149                 EXTERNAL_CMD_OPEN       iptables -A INPUT -s $SRC -j ACCEPT
150                 EXTERNAL_CMD_CLOSE      iptables -D INPUT -s $SRC -j ACCEPT
151         - Execute a custom binary with the SOURCE and OPEN_PORTS variables from
152           the access.conf file as input on the command line, and after a
153           timeout execute a different program but use the real SPA source IP:
154                 EXTERNAL_CMD_OPEN       /path/someprog $SOURCE $OPEN_PORTS
155                 EXTERNAL_CMD_OPEN       /path/otherprog $SRC
156     - Added IPT_CMD_ALARM to control the number of seconds that the
157       IPTables::ChainMgr module uses to wrap alarm() calls around iptables
158       commands (for IPTables::ChainMgr 0.8 and later, although this does not
159       interfere with earlier versions of the module).
160     - Added IPT_EXEC_STYLE to control the execution method used for iptables
161       commands in the IPTables::ChainMgr module.  The default is "waitpid",
162       but "system", and "popen" are also supported.
163     - Added IPT_EXEC_SLEEP to control the number of seconds that the
164       IPTables::ChainMgr module uses to delay between each iptables command.
165       The default is zero (no delay), but this can be increased to ensure that
166       iptables commands are issued at a slower pace.
167     - Added IPT_EXEC_TRIES to allow critical iptables commands to be tried
168       multiple times (with a default of 1) in case there are any errors from
169       iptables execution.
170     - Added --Override-config to fwknopd (suggested by Franck Joncourt) to
171       allow config variables in the normal /etc/fwknop/fwknop.conf file to be
172       superseded by values from other specified files.  The --Override-config
173       command line argument accepts a comma-separated list of multiple files
174       from which to import configuration variables from.
175     - Added code to prefer the usage of the /usr/sbin/sendmail binary to send
176       email alerts before falling back to the mail binary (suggested by
177       Alexander Perlis).
178     - Added --Dump-config to fwknopd (suggested by Franck Joncourt).
179     - Added execution of --Dump-config to the test suite to collect the
180       installed version of the fwknop.conf and access.conf files (personal
181       information is anonymized).
182     - Updated fwknopd to use the POSIX sys_wait_h API for SIGCHLD handling in
183       order to be more consistent with an example from the perlipc man page.
184     - Updated fwknopd to pass in a reference to the SIGCHLD signal handler to
185       the IPTables::ChainMgr module so that all command executions via fork()
186       and exec() are associated with the same signal handler.
187     - Updated to IPTables::ChainMgr version 0.8.
188     - Updated to IPTables::Parse version 0.7.
189     - (Test suite): Added time stamps to MSG and TEST lines for each test
190       (useful to see the relative time if an alarm expires).
191     - (Test suite): Added tests for fwknopd --Override-config, --Dump-config,
192       and writing SPA packets to disk with the --Save-packet functionality (in
193       the fwknop client).
194     - (Test suite): Added tests for IPT_EXEC_SLEEP delays for executing
195       iptables commands.
196     - (Test suite): Added tests for Linux 'any' interface capture of SPA
197       packets on all interfaces.
198     - (Test suite): Added the ability to collect output from knoptm to see
199       when requests are received from fwknopd and when rules are added and
200       removed.
201     - Added version information for fwknopd to syslog startup message.
202     - Bug fix for the fwknop client in symmetric key mode where the terminal
203       would not be taken out of 'noecho' mode if a password less than 8
204       characters long is provided.  Previous to this fix, it was necessary to
205       blindly type 'reset'.  (Reported by Alexander Perlis.)
206
207 fwknop-1.9.8 (09/30/2008):
208     - Added GPG_NO_REQUIRE_PREFIX to access.conf to control whether the GnuPG
209       'hQ' prefix is added before base64 decoding and decrypting.  Normally
210       this is not needed, but if there appear to be communications issues
211       between the fwknop client and the fwknopd server then this option can be
212       useful to ensure that encrypted SPA data is sent through the GnuPG
213       decryption routine.  The 'hQ' prefix is a heuristic derived from the
214       file 'magic' database for describing data encrypted with GnuPG, and the
215       fwknop client normally strips this data from outgoing SPA packets
216       (unless the --Include-gpg-prefix option is used).
217     - Added 'GPG_PATH <path>' to fwknopd (via access.conf) so that different
218       paths to the gpg binary can be specified on a per-SOURCE basis.  This
219       allows one SOURCE stanza to apply one gpg binary to decrypt incoming SPA
220       packets (say /usr/bin/gpg), and another SOURCE stanza to apply to another
221       gpg binary (say /usr/bin/gpg2).  In this way, fwknop/fwknopd now
222       supports gpg2 in addition to gpg.
223     - Bugfix to make sure that neither fwknop nor fwknopd reference any
224       options file in GnuPG mode, and this is now the default (which overrides
225       the now unnecessary --gpg-no-options arg).  There is a new option
226       --gpg-use-options and GPG_USE_OPTIONS to restore the usage of an options
227       file by GnuPG by fwknop and fwknopd (not normally needed).
228     - Added '--gpg-prefix <bytes>' to the fwknop client so that the
229       predictable prefix for GnuPG encrypted data can be changed.  Normally
230       this prefix is 'hQ' (base64 encoded), or the raw bytes 0x8502.
231     - Added the ability to control the path used for the gpg binary on the
232       client side with a new argument '--gpg-path <path>', and on the server
233       side with gpgCmd in the fwknop.conf file.  The GnuPG::Interface module
234       normally just takes the first instance of gpg that is the current path,
235       but this new feature allows the path to the binary to be explicitly set.
236     - Added --Save-packet-append to allow SPA packets to be appended to the
237       --Save-packet-file in --Save-packet mode.  This allows multiple SPA
238       packets to more easily be stored for closer examination (i.e. to make
239       sure randomness is high or to test encryption properties over large
240       sets of SPA packets).
241     - Updated fwknopd to enforce the DIGEST_TYPE variable more strictly by not
242       accepting SPA packets that do not include digest of the specified type.
243       The DIGEST_TYPE default is 'ALL', so normally fwknopd accepts any
244       supported digest.
245     - Bugfix to make sure to apply BLACKLIST checks to IP addresses specified
246       with -a (or derived via -R) in addition to the source IP in the IP
247       header (which can be modified via --Spoof-src).  (Franck Joncourt
248       submitted a patch for this.)
249     - Bugfix to ensure that the permissions for the
250       /var/run/fwknop/knopwatchd.pid file are set to 0600 (noticed by Franck
251       Joncourt).
252     - Bugfix to remove the Net::IPv4Addr dependency in the fwknop client and
253       knoptm daemon (Franck Joncourt).
254     - (Test suite) Added the base64_byte_frequency.pl script to the test/
255       directory.  This script parses files that contain base64 encoded data
256       (one record per line), and produces data files that can be graphed with
257       Gnuplot in order to visualize SPA packets.  The new --Save-packet-append
258       argument makes it easy to generate large collections of SPA packets with
259       the fwknop client, and this data can then be parsed by
260       base64_byte_frequency.pl to look for features that are common across SPA
261       packets (this should be minimized because every fwknop SPA packet contains
262       16 bytes of random data).  Some analysis of randomness in SPA packets
263       generated by fwknop is presented in this blog post:
264
265       http://www.cipherdyne.org/blog/2008/09/visualizing-spa-packet-randomness.html
266
267     - (Test suite) Added tests for GPG_NO_REQUIRE_PREFIX functionality and for
268       the expected GnuPG prefix.
269     - (Test suite) Added tests for GnuPG version 2 (a check is made to see if
270       it is installed before these tests are run).
271
272 fwknop-1.9.7 (08/24/2008):
273     - Mirek Trmac from Red Hat contributed several patches so that fwknop can
274       be bundled within the Fedora Linux distribution.  These patches
275       implemented the following changes:
276
277         Updates to fwknopd to remove the NetPacket module as a dependency
278       (this is a particularly important update since it assists with getting
279       fwknop bundled with Debian as well).  The patch manually decodes the
280       network and transport layer headers.
281         A patch to make the fwknop init script not start fwknopd by default
282       on Red Hat systems.  This patch also supports Fedora init script
283       conventions better (i.e. fwknop instead of the fwknopd name for the lock
284       file in /var/lock/subsys).
285         Updated the fwknop Makefile to respect the OPTS variable which is used
286       in the RPM spec file.
287         Bugfix in fwknop_serv to support the variable expansion code from
288       fwknopd.  This was important for the TCPSERV_PID_FILE file which is
289       defined as $FWKNOP_RUN_DIR/fwknop_serv.pid.
290         Updated fwknopd to use the Net::Pcap API valid in Net::Pcap-0.14 for
291       the datalink() function (used to detect the datalink layer type).
292
293     - Updated fwknop, fwknopd, and knoptm to import perl modules out of the
294       /usr/lib/fwknop/ directory if it exists.  This allows the perl module
295       path to be manipulated via the --Lib-dir command line argument and
296       'require' statements instead of the old 'use module' strategy.
297     - Added module version output for each non-core perl module used by fwknop
298       and fwknopd in --debug mode.  This is mostly useful for the test suite
299       to see which versions of the modules are being used.
300     - Added the ability to ignore any local GnuPG 'options' file with a new
301       command line argument --gpg-no-options (for the fwknop client) and a new
302       access.conf config variable GPG_NO_OPTIONS (for the fwknopd daemon).
303       This fixes a problem reported by Mike Holzmann where the 'encrypt-to'
304       option in the default options file was causing SPA packets to exceed
305       1500 bytes when encrypted with a 2048-bit GnuPG key.  Also added the
306       MAX_SNIFF_BYTES to the fwknop.conf file and --Max-packet-size to the
307       fwknop command line to alter the default of 1500 bytes if needed (but
308       this shouldn't really be necessary).
309     - Bugfix for 'Premature end of base64 data' and 'Premature padding of
310       base64 data' warning messages from MIME::Base64 errors.  Now fwknopd
311       applies more rigorous checks for base64 encoded characters, and either
312       of these two messages above will result in the packet data being
313       discarded before it is sent through any decryption function.  Mike
314       Holzmann reported this issue.
315     - (Test suite) Added --test-system-fwknop to allow any installed version
316       of fwknop to be installed instead of the scripts bundled within the
317       local source distribution.
318
319 fwknop-1.9.6 (07/18/2008):
320     - SPA packets are base64-encoded by the fwknop client, and this encoding
321       pads data with '=' chars until the total length of the encoded data is a
322       multiple of four.  This characteristic can be used within a Snort rule
323       to assist in the detection of SPA communications.  The 1.9.6 release of
324       fwknop strips out these padding characters before the client sends an
325       SPA packet, and the fwknopd server adds them back in (to form a multiple
326       of four) before base64 decoding the packet data.  This reduces the level
327       of identifying information in SPA packets and therefore makes it more
328       difficult to detect the usage of SPA for service access.  For reference,
329       a Snort rule that would detect SPA packets via the trailing '=' chars
330       (previous to this release) would be:
331
332         alert udp any any -> any 62201 (msg:"fwknop SPA traffic"; \
333         dsize:>150; pcre:"/==$/"; sid:20080001; rev:1;)
334
335     - According to the 'file' command (via it's 'magic') database, files that
336       are encrypted with GnuPG begin with 0x8502, and this is true for SPA
337       packets generated by fwknop (previous to this release).  In
338       fwknop-1.9.6, the "hQ" prefix is removed by the fwknop client and added
339       back in by the fwknopd server if it doesn't exist.  This measure is
340       another effort to make SPA packets more difficult to detect on the wire,
341       such as with the following Snort rule:
342
343         alert udp any any -> any 62201 (msg:"fwknop GnuPG encrypted SPA
344         traffic"; content:"hQ"; depth:2; dsize:>1000; sid:20080003; rev:1;)
345
346     - Updated the fwknop client to randomize the UDP source port for default
347       SPA packet generation.  There is also a new command line argument
348       --Source-port <port> to allow the user to manually set the source port
349       on the fwknop client command line.  A lot more attention is given now to
350       source ports after the Dan Kaminsky DNS caching exploit, and it turns
351       out that even on Linux that the kernel did not randomize UDP source
352       ports until the 2.6.24 kernel.  Of course, any userspace process is free
353       to request a random port itself, but if a userspace application did not
354       build this in then it would be up to the kernel to assign a source port.
355       In the case of Linux, here are two links that show the change to the
356       kernel code as well as the ChangeLog entry for UDP source port
357       randomization:
358
359         http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;\
360         a=commit;h=32c1da70810017a98aa6c431a5494a302b6b9a30
361         http://www.kernel.org/pub/linux/kernel/v2.6/ChangeLog-2.6.24
362
363     - (Test suite): Added the ability to explicitly run major classes of tests
364       with two new command line arguments to the fwknop_test.pl script:
365       --test-include <test>, and --test-exclude <test>.  In each case the
366       <test> string is used as a sub-string match against the main identifying
367       string for the name of the test.  For example, to run all tests for
368       replay attacks, use "--test-include Replay", and for all port
369       randomization tests use "--test-include random".  To see all possible
370       classes of tests, run the test suite without any command line arguments
371       and examine the test.log file.
372     - (Test suite): Added tests for the legacy shared and encrypted port
373       knocking modes.
374     - (Legacy port knocking mode): Updated to not require iptables log
375       messages to be written to the fwknopfifo named pipe and just parse the
376       /var/log/messages file directly by default.  This can be configured via
377       two new variables ENABLE_SYSLOG_FILE and IPT_SYSLOG_FILE (similarly to
378       the psad project).  In support of this feature, install.pl now does not
379       create the fwknopfifo or reconfigure the syslog daemon unless the
380       --install-syslog-fifo argument is used, and the knopmd does not have to
381       run.
382     - (Legacy port knocking mode): Added the ability to re-open the
383       /var/log/messages file if it is rotated by an external program such as
384       logrotate.
385     - (Test suite): Bugfix to use --fw-type argument on fwknopd command line.
386       This fixes various tests on Mac OS X and FreeBSD systems running ipfw.
387     - Minor bugfix to require a space character after variable names when
388       parsing the fwknop.conf file via knopmd and knopwatchd (implemented in
389       fwknop_funcs.c)
390
391 fwknop-1.9.5 (06/08/2008):
392     - Updated to Class::MethodMaker 2.11 from CPAN.  This helps with systems
393       running perl-5.10.0 and greater (such as Fedora 9).
394     - Added the LOCALE variable to fwknop.conf and made the "C" locale set by
395       default so that gpg process output would always be correctly
396       interpreted.
397     - Updated to Net::RawIP 0.23 from 0.21_03 and removed List::MoreUtils
398       since Net::RawIP no longer requires it
399     - Updated to Crypt::Rijndael 1.06 from 1.04.
400     - Updated to Crypt::CBC 2.29 from 2.19.
401     - Updated to GnuPG::Interface 0.36 from 0.34.
402     - Removed legacy knopmd.conf file since knopmd uses the fwknop.conf file
403       instead.  Also, note that knopmd only runs in the legacy port knocking
404       mode to collect iptables log information from syslog.  The default
405       authentication/authorization method used by fwknop is SPA which exhibits
406       far better security properties than port knocking (see
407       http://www.cipherdyne.org/fwknop/docs/SPA.html).
408
409 fwknop-1.9.4 (06/01/2008):
410     - Added two new port randomization options.  The first instructs the
411       fwknop client to select a random port between 10,000 and 65,535 as the
412       destination port over which to send an SPA packet.  This feature is
413       enabled with a new command line argument "--rand-port" like so:
414
415       $ fwknop -A tcp/22 --rand-port -R -D 11.1.1.1
416
417       On the fwknopd server side, the default PCAP_FILTER setting of "udp port
418       62201" should be changed to "udp dst portrange 10000-65535" so that
419       fwknopd can sniff SPA packets that are sent over randomized destination
420       ports.  Randomizing the destination port makes it more difficult to
421       write IDS signatures to detect fwknop SPA communications.
422
423       The second port randomization technique uses a new SPA message type to
424       tell the fwknopd daemon to create a NAT rule for access to a local
425       socket via the iptables INPUT chain.  This allows an SSH client to meet
426       the local SSHD daemon running on the fwknopd server system by SSH'ing to
427       the random port.  This functionality is implemented via two new command
428       line arguments on the fwknop client command line: "--NAT-rand-port" to
429       instruct fwknop to select a random port over which the follow-on
430       connection will be made), and "--NAT-local" (to instruct the fwknopd
431       server that new firewall rules should NAT an incoming connection to the
432       randomly selected port).  Here is an example:
433
434       $ fwknop -A tcp/22 --NAT-rand-port --NAT-local -R -D 11.1.1.1
435
436       Now the fwknop client will select a random port to NAT the incoming
437       connection.  So say it selects port 31001 (as indicated by the output of
438       fwknop on the command line as displayed below) - then you would SSH to
439       this port to access the real SSH daemon on the system where fwknopd is
440       running:
441
442       [+] Sending 206 byte message to 127.0.0.1 over udp/46245...
443       Requesting NAT access to tcp/22 on 127.0.0.1 via port 31001
444
445       $ ssh -p 31001 <user>@11.1.1.1
446
447       Note that in this case it is not necessary to use --NAT-access since the
448       fwknopd daemon knows that access is requested to a local service (so an
449       internal IP address does not have to be specified).
450
451     - Added the ability to specify the port that SPA packets are sent over
452       with the fwknop client by using the syntax "<host|IP>:<port>".  So, for
453       example, to have the client send an SPA packet to 11.1.1.1 over UDP port
454       12345 (instead of the default of 62201), one could use the following
455       command:
456
457       $ fwknop -A tcp/22 -R -D 11.1.1.1:12345
458
459     - Bugfix to add a check for "keep-state" in ipfw policies in addition to
460       the existing "check-state" check (noticed by Sebastien Jeanquier).
461     - Updated the install.pl script to try to determine the OS type as early
462       as possible during the install process.
463     - Added the MIN_SPA_PKT_LEN variable with 150 (bytes) as the default.
464       This allows fwknopd to ignore packets that are not at least this many
465       bytes (including packet headers) before any decryption attempt is made.
466     - Added --time-offset-plus and --time-offset-minus args to the fwknop
467       client command line.  This allows the time stamp within an SPA packet to
468       be influenced without setting the system clock (which normal users
469       cannot usually do).  This is useful for when the client and server
470       systems have clocks that are out of sync.
471     - Bugfix on Ubuntu systems to make sure that the fwknop init script is
472       installed with a priority of 99 instead of 20 - this puts fwknop as late
473       as possible within the boot sequence so that the system is ready to run
474       fwknop.
475     - Bugfix to not open ports that are not specifically requested in an SPA
476       packet even if those ports are listed in the OPEN_PORTS variable in the
477       access.conf file.
478     - Updated to version 5.47 of the Digest::SHA module.
479     - Updated to version 0.7 of the IPTables::ChainMgr module (includes
480       perldoc documentation).
481     - Updated to version 0.6 of the IPTables::Parse module (includes perldoc
482       documentation).
483     - Added NAT, port randomization, and and time offset option discussions to
484       fwknop(8) man page.
485
486 fwknop-1.9.3 (04/05/2008):
487     - Added MASQUERADE and SNAT support to complement inbound DNAT connections
488       for SPA packets that request --Forward-access to internal systems.  This
489       functionality is only enabled when both ENABLE_IPT_FORWARDING and
490       ENABLE_IPT_SNAT are set, and is configured by two new variables
491       IPT_MASQUERADE_ACCESS and IPT_SNAT_ACCESS which define the iptables
492       interface to creating SNAT rules.  The SNAT supplements of DNAT rules
493       are not usually necessary because internal systems usually have a route
494       back out to the Internet, but this feature accommodates those systems
495       that do not have such a route.  By default, the MASQUERADE target is
496       used if ENABLE_IPT_SNAT is enabled because this means that the external
497       IP does not have to be manually defined.  However, the external IP can
498       be defined by the SNAT_TRANSLATE_IP variable.
499     - Added hex_dump() feature for fwknop client so that raw encrypted SPA
500       packet data can be displayed in --verbose mode.
501     - When ENABLE_IPT_FORWARDING is set, added a check for the value of the
502       /proc/sys/net/ipv4/ip_forward file to ensure that the local system
503       allows packets to be forwarded.  Unless ENABLE_PROC_IP_FORWARD is
504       disabled, then fwknopd will automatically set the ip_forward file to "1"
505       if it is set to "0" (again, only if ENABLE_IPT_FORWARDING is enabled).
506     - Minor bugfix to remove sys_log() call in legacy port knocking mode.
507     - Minor bugfix to expand both the Id and Revision tags via the
508       svn:keywords directive.
509
510 fwknop-1.9.2 (03/12/2008):
511     - Crypt::CBC adds the string "Salted__" to the beginning of the encrypted
512       text (at least for how fwknop interfaces with Crypt::CBC), so the fwknop
513       client was updated to delete the encoded version of this string
514       "U2FsdGVkX1" before sending a Rijndael-encrypted SPA packet on the wire.
515       The fwknopd server will add this string back in before decrypting.  This
516       makes it harder to write an IDS signature that looks for fwknop traffic;
517       e.g. look for the default prefix string "U2FsdGVkX1" over UDP port 62201,
518       which would work for fwknop clients < 1.9.2 (as long as the port number
519       is not changed with --Server-port).
520     - Added more granular source IP and allowed IP tests so that access to
521       particular internal IP addresses can be excluded in --Forward-access
522       mode.  A new keyword "INTERNAL_NET_ACCESS" is now parsed from the
523       access.conf file in order to implemented these restrictions.
524     - (SPAPICT Group) Added BLACKLIST functionality to allow source IP
525       addresses to easily be excluded from the authentication process.
526     - (Grant Ferley) Submitted patch to handle SIGCHLD in IPTables::ChainMgr.
527     - (Grant Ferley) Submitted patch to handle Linux "cooked" interfaces for
528       packet capture (e.g. PPPoE interfaces).
529     - (SPAPICT Group) Applied modified version of the client-defined access
530       timeout patches submitted by the PICT SPA Group.  There are two new
531       message types to facilitate client timeouts; one for normal access mode,
532       and the other for the FORWARD access mode.  In the access.conf file,
533       there is also a new variable "PERMIT_CLIENT_TIMEOUT" to allow each
534       SOURCE stanza to allow client-defined timeouts or not.
535     - (SPAPICT Group) Submitted patches to include support for the SHA1 digest
536       algorithm for SPA packet replay attack detection.  I modified these
537       patches for maximum configurability (see the --digest-alg argument on
538       the fwknop command line), and the ability to use the SHA256 algorithm as
539       well.  The default path to the /var/log/fwknop/md5sums file has been
540       changed to /var/log/fwknop/digest.cache, and the default digest
541       algorithm is now SHA256 (but this is tunable via the DIGEST_TYPE
542       variable in the fwknop.conf file).
543     - Added the Digest::SHA perl module in support of the SHA1 and SHA256
544       digest algorithms for replay attack detection and SPA message integrity.
545     - Added full packet hex dumps (including packet headers) to fwknopd in
546       --debug --verbose mode.  This is to help diagnose packet sniffing issues
547       over the loopback interface on Mac OS X (first reported by Sebastien
548       Jeanquier).
549     - (Test suite) Bugfix to ensure that the FWKNOP_DIR variable is set to the
550       local output/ directory in several of the test config files in the
551       test/conf/ directory.
552     - (Test suite) Added several tests for configurable digest algorithms in
553       support for the SHA256, SHA1, and MD5 digest changes made by the SPAPICT
554       Group.
555     - Updated the fwknop client to always call encode_base64() with the string
556       to encode along with a second null-string argument to force all encoded
557       data to not include line breaks.
558     - Bugfix in install.pl to not test for the iptable command on non-Linux
559       systems, and to not test for the ipfw command on systems that are Linux.
560     - (Test suite) Updated to include the /proc/config.gz file so that the
561       kernel config can be reviewed (not all Netfilter hooks are necessarily
562       compiled in).
563
564 fwknop-1.9.1 (01/26/2008):
565     - Added ENABLE_OUTPUT_ACCESS keyword to access.conf file parsing. This
566       provides a similar configuration gate for the iptables OUTPUT chain to
567       the ENABLE_FORWARD_ACCESS keyword, and adds the abiliy to control which
568       access.conf SOURCE blocks interface to the OUTPUT chain.
569     - Better installation support for various Linux distributions including
570       Fedora 8 and Ubuntu.  The current runlevel is now acquired via the
571       "runlevel" command instead of attempting to read /etc/inittab (which
572       does not even exist on Ubuntu 7.10), and there are new command line
573       arguments --init-dir, --init-name, and --runlevel to allow the init
574       directory, init script name, and the runlevel to be manually specified
575       on the install.pl command line.
576     - Added command line argument display to fwknop client --verbose mode.
577     - Updated the test suite to include OUTPUT chain tests, reference
578       access.conf files in the test/conf/ directory, and perform SPA packet
579       format validation tests by parsing fwknopd output.
580     - Updated fwknopd to use always use the -c argument on the knoptm command
581       line (this makes sure that the test suite usage of fwknopd causes knoptm
582       to reference the correct configuration).
583     - Updated IPTables::ChainMgr to print iptables command output to stdout or
584       stderr if running in debug or verbose mode.
585     - Added --Exclude-mod-regex to install.pl so that the installation of
586       particular perl modules that match the supplied regex can be skipped.
587     - Added SIGALRM wrapper to the test suite since some libpcap and system
588       combinations break the ability of fwknopd to sniff packets.
589     - Added srand() call to the fwknop client (this is useful for older
590       versions of perl which do not automatically call srand() at the first
591       rand() call if srand() was not already called).
592     - Added a test to the test suite for sniffing packets over the loopback
593       interface.
594     - Added SPA packet aging test to the test suite to ensure that packet
595       expirations work properly (this feature protects against MITM attacks
596       where a valid SPA packet is stopped by an inline attacker and
597       retransmitted at a later time to acquire access).
598     - Added a file (test.log) to collect test suite console output.
599     - Added --Prepare-results argument to test suite to anonymize test results
600       and create a tarball that can be emailed to a third party to assist in
601     - Added full firewall policy dumps and the collection of system specifics
602       to the test suite. This makes it easy to send the output directory and
603       the test.log file to developers to assist in debugging (no information
604       is sent anywhere except as part of a manual process of course, and
605       addresses can be anonymized with --Prepare-results - loopback addresses
606       are not modified).
607     - Added --fw-del-ip <IP> argument to fwknopd so that a specific IP address
608       can be removed from the local firewall policy (this is used by the test
609       suite to ensure that if a test for removed firewall rules fails then
610       subsequent tests will not also fail because they are no longer tracked
611       by a running knoptm instance).
612     - Added a test to the test suite to collect fwknopd syslog output.  This
613       is useful to see if a mechanism such as SELinux is deployed in a manner
614       that prevents normal fwknop communications.
615     - Bugfix to track MD5 digest for SPA command mode packets.
616     - Bugfix in fwknopd to not open ports listed in OPEN_PORTS in the absence
617       of the PERMIT_CLIENT_PORTS directive when an SPA packet contains a
618       request for access to a port not listed in OPEN_PORTS.
619       debugging fwknop if there are any issues.
620     - Added --verbose flag to fwknopd commands issued by the test suite so
621       that more data is collected for debugging analysis.
622     - Added GnuPG tests to the test suite with dedicated keys (for use only
623       with the test suite) in the test/conf/client-gpg and
624       test/conf/server-gpg directories.
625     - Added digest file validation to test suite to make sure that fwknopd
626       correctly tracks SPA packet MD5 digests.
627     - Updated to search state tracking rule in any iptables chain (many
628       iptables policies have user-defined chains that can be a bit complicated
629       to parse).
630     - Updated install.pl to be more strict in stopping any running fwknopd
631       processes.
632
633 fwknop-1.9.0 (12/15/2007):
634     - Added a test suite so that fwknop and fwknopd functionality can be
635       automatically tested over the loopback interface (see the fwknop_test.pl
636       script in the test/ directory).
637     - Major update to allow SPA packets to create DNAT connections to internal
638       systems through the FORWARD chain (iptables only).  This is useful to
639       connect through to internal systems (that may be running on non-routable
640       IP addresses) via a border firewall or router that is running fwknopd to
641       create inbound DNAT rules.
642     - Added support for the iptables OUTPUT chain via two new variable in the
643       fwknop.conf file: ENABLE_IPT_OUTPUT and IPT_OUTPUT_ACCESS. This is
644       useful for iptables firewalls that are not running the conntrack modules
645       and that have a restrictive OUTPUT chain (so SYN/ACK responses are not
646       allowed out without an explicit ACCEPT rule).
647     - Added the ability to force the fwknopd and knoptm daemons to restart
648       themselves (via knopwatchd) after a configurable timeout (see the
649       ENABLE_VOLUNTARY_EXITS and EXIT_INTERVAL variables in the
650       /etc/fwknop/fwknop.conf file). This feature is for those that want
651       fwknopd to go through its initialization routine periodically just in
652       case there is a logic (or other) bug that might result in fwknopd not
653       accepting a valid SPA packet. NOTE: This feature is disabled by default,
654       and is not normally needed since fwknopd is quite stable in most
655       deployments.
656     - Major update to perform all firewall rule expirations with knoptm, which
657       is now started in all data collection modes.  Older versions of fwknopd
658       maintained its own firewall rule expiration code for the FILE_PCAP,
659       ULOG_PCAP, and KNOCK modes, so two mechanisms were being maintained for
660       the same purpose.  The 1.9.0 release fixes this oversight.
661     - Minor bugfix to have knopwatchd generate syslog messages whenever an
662       fwknop daemon needs to be restarted.
663     - Added --interface command line argument to install.pl to allow the
664       sniffing interface to be specified from the command line. Also updated
665       install.pl to enforce a 10-try maximum for attempting to accept a valid
666       interface name from the command line (LANG env issues can exist
667       sometimes).
668     - Updated SPA packet format for server_auth and forward_info elements;
669       the internal MD5 sum is now always the last field in an SPA packet. This
670       makes extensions of the SPA protocol much easier, and the generation of
671       SPA packets more elegant. Also, SPA packet validation has been improved
672       to ensure that fields that are supposed to be digits really only contain
673       integer data.
674     - Added ENABLE_FORWARD_ACCESS variable to the access.conf file, and added
675       ENABLE_IPT_FORWARDING to the fwknop.conf file. These variables provide
676       the per-SOURCE ability to create DNAT connnections through the FORWARD
677       chain..
678     - Replaced the IPT_AUTO_CHAIN1 variable with IPT_INPUT_ACCESS and
679       IPT_FORWARD_ACCESS in fwknop.conf.
680     - Added --Forward-access argument to the fwknop client.
681     - Added client version number to syslog messages generated by fwknopd when
682       a valid SPA packet is received.
683     - Added human readable timestamp to MD5 cache. Here is an example of the
684       update format:
685         127.0.0.1 X6WF2C29kEgAv4aDJ8TDeQ [Wed Nov 28 09:24:46 2007]
686     - Added --Count argument to fwknopd so that it calls exit() when the
687       specified number of packets is monitored.
688     - Added --no-logs argument to knoptm in support of the test suite so that
689       no emails are generated.
690     - Bugfix in fwknopd to account for non-Ethernet link layer header over
691       *BSD loopback interfaces.
692     - Added --Save-dst argument to the fwknop client to add a priority file to
693       store client command line arguments (~/.fwknop.save). This file is only
694       overwritten when --Save-dst is used.
695     - Added fwknopd --fw-del-chains to allow the fwknopd iptables chains to
696       easily be deleted.
697     - Minor fwknopd bugfix to set process exit status to 0 when --Kill is
698       used.
699
700 fwknop-1.8.3 (11/17/2007):
701     - Updated external IP resolution to point to http://www.whatismyip.org,
702       and added http://www.cipherdyne.org/cgi/clientip.cgi as a backup site
703       for fwknop IP resolution.
704     - Added storage of source IP along with SPA MD5 sum. This allows the user
705       to infer which networks are more hostile if an SPA packet is replayed.
706     - Added SPA packet hex dumps in 'fwknopd --debug' mode so that the
707       integration of third-party encryption algorithms is easier to
708       troubleshoot. Sean Greven contributed a patch for this.
709     - Reinstated the legacy port knocking mode. It appears that all encrypted
710       output from the updated Crypt::Rijndael module is at least 32 bytes
711       long, so port knocking sequences are now 32 bytes long as well (they
712       were previously 16 bytes long in old versions of fwknop).
713     - Bugfix to ensure the key length is at least 8 chars in --get-key mode.
714     - Minor update to remove init message on OS X install.
715     - Updated install.pl to set the LANG environmental variable to
716       "en_US.UTF-8". This should fix the problem where the output of ifconfig
717       was not interpreted correctly if the locale LANG setting is not English.
718     - Implemented verbose email alerting by setting the ALERTING_METHODS
719       variable to "verbose". This instructs fwknopd to generate a new email
720       message for each message that it normally logs vis syslog (this feature
721       is not the default, and must be manually enabled).
722
723 fwknop-1.8.2 (09/15/2007):
724     - Added fwknopd server support for Mac OS X. The Darwin uname return
725       string is detected and this enables Darwin-specific installation code in
726       install.pl.
727     - Updated to not print sensitive key/password information in --debug mode
728       with fwknopd.
729     - Bugfix for install.pl on Windows 2003 Server running under Cygwin where
730       'uname -o' output is reported 'Gygwin' for some reason.
731     - Added --Cygwin-install command line argument to install.pl to force
732       client-only fwknop install on Cygwin systems.
733     - Added --OS-type command line argument to install.pl to allow the user to
734       force the installation type.
735     - Updated to version 1.04 of Crypt::Rijndael. This fixes incompatibilities
736       between SPA packets between 64-bit and 32-bit platorms.
737     - Bugfix to enforce a maximum of 20 tries to read a password from stdin.
738     - Applied TCP options parsing fix from psad for invalid zero or one length
739       fields that break TLV encoding (this is for fwknopd, and only applies to
740       the legacy port knocking mode).
741     - Added code to fwknopd to check to see if there are any state tracking
742       rules in place within the local iptables or ipfw policy.
743     - Made syslog identity, facility, and priority configurable (applied code
744       from the psad project).
745     - Implemented --fw-list for ipfw firewalls.
746     - Bugfix for knoptm removing ipfw rules too quickly after not timing out
747       previously instantiated rules properly.
748     - Implemented smarter cache removal strategy in knoptm so that rules that
749       are manually removed from the running iptables or ipfw policy are also
750       removed from the cache.
751     - Added /var/log/fwknop/errs/fwknopd.{warn,die} tracking to the fwknopd
752       daemon for the PCAP modes of collecting packet data. Added
753       knoptm{warn,die} files for knoptm as well.
754     - Bugfix to import the GnuPG::Interface module in --get-key mode.
755     - Bugfix to send source IP as a part of the command message in command
756       mode so that REQUIRE_SOURCE_ADDRESS controls can be applied.
757     - Added --Test-mode to fwknop client so that SPA packets can be built but
758       never sent over the network.
759
760 fwknop-1.8.1 (06/06/2007):
761     - Bugfix to ensure that the "keep-state" directive is added to firewall
762       rules on systems running the ipfw firewall.
763     - Added the --Save-packet and --Save-packet-file command line arguments
764       to the fwknop client. These options instruct fwknop to save a copy of
765       an encrypted SPA packet before it is sent across the network.
766     - Bugfix to find minimal unused ipfw rule number for ipfw firewalls. This
767       fixes an issue where ipfw rules added by fwknopd could be inserted at
768       the same position as rules from an existing ipfw policy. While ipfw
769       allows duplicate rules, whenever such a rule is deleted by its rule
770       number all matching rules are deleted.
771
772 fwknop-1.8 (06/03/2007):
773     - Added support for ipfw firewalls (found on *BSD systems).  The
774       IPTables::Parse and IPTables::ChainMgr modules are not installed on
775       such systems.
776     - Added gpg-agent support for both the fwknop client and fwknopd SPA
777       server.
778     - Updated client-only installation mode to restrict perl module
779       installation to those module that are actually required by the fwknop
780       client. This results in clean installs of the fwknop client on Windows
781       systems running Cygwin.
782     - Added --Defaults to install.pl so that fwknop can be installed without
783       prompting the user to answer any questions. This is to make it easier
784       to install fwknop on the Source Mage Linux distro.
785     - Consolidated daemon config files into the fwknop.conf file (except for
786       the access.conf file). This simplifies the configuration of fwknop.
787     - Added recursive variable resolution in the parsing routines for the
788       fwknop.conf file. This allows variable values to contain embedded
789       variables.
790     - Added init script for FreeBSD systems.
791     - Added --BSD-install command line argument to install.pl. This is not
792       normally necessary since the installer should detect installations on
793       *BSD systems, but this option can force this behavior.
794     - Updated knopmd and knopwatchd to use safe_malloc() instead of malloc().
795     - Bugfix to never time out rules from SOURCE blocks with FW_ACCESS_TIMEOUT
796       set to zero
797
798 fwknop-1.0.1 (01/09/2007):
799     - Updated fwknopd to allow the GPG_REMOTE_ID variable to have the value
800       "ANY" to allow a SOURCE block to match on arbitrary remote gpg signing
801       keys (Leland Weathers).
802     - Bugfix to allow OPEN_PORTS to be omitted in access.conf in favor of
803       having only PERMIT_CLIENT_PORTS enabled (reported by Raul Siles).
804     - Added the cd_rpmbuilder script to make it easy to build RPM's out of
805       CipherDyne projects by automatically downloading the project .tar.gz and
806       .spec files from http://www.cipherdyne.org/.
807
808 fwknop-1.0 (11/05/2006):
809     - Bugfix for OpenSSH-4.3p2 patch to make sure to include the spa.h header
810       file.
811     - Bugfix for access hashes accumluating when multiple ports are requested
812       to be opened by a client.
813     - Better validation of IPT_AUTO_CHAIN variable so that the from_chain
814       cannot be identical to the to_chain.
815     - Bugfix in RPM to install List::MoreUtils.
816     - Bugfix so that the MD5 sum for an SPA packet is not examined for each
817       SOURCE block.  This fixes a problem where an SPA packet could appear to
818       be replayed if multiple SOURCE blocks are defined in
819       /etc/fwknop/access.conf.
820     - Refactored main SPA access loop so that it is clearer how and when SPA
821       clients are granted access.
822     - Better handling of GnuPG key identifier strings (they can now contain
823       spaces, and syslog messages wrap the identifiers with double quotes).
824     - Added source IP address to command string in the SPA packet so that
825       the REQUIRE_SOURCE_ADDRESS criteria can be applied by the fwknopd
826       server.
827     - Added --Show-last-cmd and --Show-host-cmd args to fwknop so that the
828       last fwknop command and the last fwknop host commands can be viewed.
829     - Added the svn revision number to --Version and --help output.
830
831 fwknop-0.9.9 (10/15/2006):
832     - Added REQUIRE_SOURCE_ADDRESS (disabled by default) to force fwknop
833       clients to know their source IP address (i.e. -s cannot be used).  So,
834       either fwknop clients have to use -R to resolve their externally
835       routable address, or they must just know what it is.
836     - Updated to Net-RawIP-0.21_03 for compatibility with gcc-4.x compilers.
837     - Added List-MoreUtils-0.22 which is a dependency of the new Net::RawIP
838       module.
839     - Bugfix to restore "start" functionality in Gentoo init script.
840     - Bugfix to use the IPT_OUTPUT_FILE and IPT_ERROR_FILE configuration
841       variables in fwknopd.
842     - Added KNOPTM_IPT_OUTPUT_FILE and KNOPTM_IPT_ERROR_FILE variables
843       specifically for the knoptm daemon so that it can use IPTables::ChainMgr
844       completely independently of fwknopd (this removes a potential race
845       condition between fwknopd and knoptm).
846
847 fwknop-0.9.8 (09/17/2006):
848     - Added the ability to ignore old SPA packets through use of the
849       client-side time stamp.  This means that an attacker cannot intercept an
850       SPA packet, prevent it from being forwarded to its intended destination,
851       and then put the packet on the wire at some time outside of the allowed
852       time window.  There are two new configuration options in fwknop.conf
853       "ENABLE_SPA_PACKET_AGING" and "MAX_SPA_PACKET_AGE" that control the
854       length of the acceptable time window (2 minutes by default).  This
855       requires some level of synchronization between the fwknop client and the
856       fwknopd server, but this is not onerous through the use of NTP.  This
857       feature is enabled by default, and the idea for it was contributed by
858       Sebastien J.
859     - Completely re-worked IPTables::ChainMgr to support the return of
860       iptables error messages that are collected via stderr.  This is critical
861       to fixing any bugs where fwknopd could die as a result of a poorly
862       crafted iptables command.
863       but no information would be returned to the user.
864     - Added the ability to specify the position for both the jump rule into
865       the fwknopd chains as well as the position for new rules within the
866       fwknopd chains via the -I argument to iptables.  This fixes a bug where
867       the user was given the impression that the IPTABLES_AUTO_RULENUM would
868       accomplish this (IPTABLES_AUTO_RULENUM has been removed).
869     - Updated fwknopd to require < 1500 byte payload length before attempting
870       to decrypt.  Also, GnuPG decrypts are not attempted unless the encrypted
871       payload is at least 400 bytes long (this is conservative since even
872       encrypting a single byte with a 1024-bit key will result in about 340
873       bytes of encrypted data).
874     - Added the --gpg-default-key option to have fwknop use the default GnuPG
875       key that is defined in the ~/.gnupg/options file.
876     - Added the --URL command line argument so that a URL other than the
877       default http://www.whatismyip.com/ can be provided by the user for
878       external IP resolution (suggested by Sebastien J.).
879     - Updated to be more rigorous with md5 sums; we now require that the
880       md5_base64() function actually returns a non-null result.
881     - Bugfix to make sure that only the users associated with the a specific
882       REQUIRE_USERNAME value (in a specific SOURCE block in access.conf) are
883       granted the appropriate access even if a valid encrypted packet is
884       constructed from a different user name (by an fwknop client).
885     - Populated the _debug option in the IPTables::ChainMgr module, and also
886       added a _verbose option so that the specific iptables commands can
887       actually be seen as IPTables::ChainMgr functions are called.
888     - Added code to install.pl to update command paths in fwknop.conf and
889       knopwatchd.conf if any of the paths are broken (i.e. the local system
890       does not conform to the default paths).  By default this only happens if
891       the user does not want old configs to be merged, but to override this
892       use the new --path-update command line argument to install.pl.
893     - Added the --Skip-mod-install command line argument to install.pl to
894       allow all perl module installs to be skipped.
895     - Added the --force-mod-regex command line argument to install.pl to allow
896       a regex match on perl module names to force matching modules to be
897       installed.
898     - Minor bugfix to generate better (i.e. closer to those that Firefox
899       generates) http requests to http://www.whatismyip.com/).
900     - Adapted Mate Wierdl's RPM patch from the psad project so that the fwknop
901       RPM builds on x86_64 systems.
902     - Removed iptables requirement in RPM spec file because fwknop may be
903       installed on a system just to run the fwknop client.
904     - Updated to email username mismatch errors.
905
906 fwknop-0.9.7 (08/04/2006):
907     - Added fwknop_serv to function as minimal TCP server over which SPA
908       packets can be sent.  This allows SPA to be compatible with the Tor
909       network, which requires that a virtual circuit is established before
910       traffic can be sent.
911     - Updated to Crypt::CBC-2.18 after a vulnerability was discovered in
912       previous versions of Crypt::CBC that caused weak ciphertext to be
913       generated for algorithms that have blocksizes greater than 8 bytes (such
914       as Rijndael used by fwknop).  Manually specifying initialization vectors
915       is not necessary now.
916     - Updated SSH patch to support OpenSSH-4.3p2.
917     - Bugfix to make sure to create /var/* directories if they don't exist
918       (such as when /var is a tmpfs).
919     - Bugfix (Dwayne Rightler) to restore -w IP lookup functionality after
920       format change on data returned by whatismyip.com.
921     - Bugfix to wrap SPA Rijndael decryption with eval{} so that fwknopd does
922       not die if there are problems trying to decrypt data.  This is necessary
923       because of the security vulnerability fix in Crypt::CBC that creates
924       some incompatibilities in different versions of Crypt::CBC.
925     - Added "--L-host" command line argument so that the arguments used for
926       multiple hosts are preserved and can be recalled.
927     - Changed default user-agent setting for whatismyip.com lookups to
928       Firefox/1.0.5.4; there is no need to gratuitously advertise fwknop
929       traffic.
930     - Updated GunPG HOWTO to provide a step-by-step guide to getting fwknop
931       Single Packet Authorization working with GnuPG.
932     - Updated to derive perl module versions from the VERSION files within
933       each of the perl module source directories.
934
935 fwknop-0.9.6 (01/13/2006):
936     - Added GPG based authentication capability for SPA packets.  This new
937       mode can be configured to require that a GPG message be signed with a
938       particular key or set of keys.
939     - In GPG mode, the fwknop client now prints GPG errors to stdout if not
940       running with --gpg-no-batch-mode.
941     - Added the ability to require that the client know the UNIX crypt()
942       password associated with a username on the server side.  This
943       functionality is enabled on the fwknop client with the "--Server-auth
944       crypt" command line argument, and the REQUIRE_AUTH_METHOD variable in
945       /etc/fwknop/access.conf on the fwknopd server.
946     - Added patch against OpenSSH-4.2p1 to integrate SPA mode.  This patch
947       adds a "-K <fwknop cmd line>" argument to the SSH client so that
948       fwknop can be executed directly before an SSH connection is made.
949     - Separated server and client portions of fwknop into "fwknopd" and
950       fwknop repectively.  This will allow better portability to be
951       developed since the client and server pieces can be developed more
952       independently.  NOTE: With so many changes, it is probably a good idea
953       to not preserve old fwknop configs via install.pl.
954     - Renamed all relevant fwknopd command and file paths to support new
955       fwknopd server component.
956     - Added --quiet mode (this is used by default in the OpenSSH patch).
957     - Removed legacy port knocking installation in install.pl (fwknopfifo,
958       and fwdata file) unless the data collection mode is set to syslog or
959       syslog-ng for legacy iptables log messages.
960     - Added inode checking for PCAP_PKT_FILE. This helps to ensure that log
961       rotation schemes don't interfere with reading packets out of the file
962       since this check is size independent.
963     - Bugfix for Makefile debug mode.
964     - Added compilation check for perl programs in install.pl before
965       installation into the filesystem.
966     - Bugfix for knopwatchd to make sure it can actually restart all running
967       daemons properly.
968     - Added --force-mod command line argument to install.pl to allow the user
969       to force all perl modules to be be installed regardless of whether a
970       module exists in the system perl lib tree.
971     - Added --no-save-args to fwknop so that existing .fwknop.run file can
972       be preserved (helps to testing new features of fwknop client).
973     - Removed useless --encrypt command line argument (only the old shared
974       port knock sequences are not encrypted).
975
976 fwknop-0.9.5 (10/02/2005):
977     - Added the ability to resolve the external IP associated with the
978       local network via http://www.whatismyip.com.  This is a more secure
979       method of accomplishing what the -s option performs.  The new
980       command line option is --whatismyip (or just -w).
981     - Updated fwknop to communicate with knoptm via a UNIX domain socket
982       instead of the previous file-based communication.
983     - Updated to flush the fwknop iptables chains at start time.
984     - Bugfix for removing the wrong hash key in the knoptm IP cache.
985
986 fwknop-0.9.4 (09/17/2005):
987     - Bugfix for knoptm timing out new entries based on old time values
988       (this caused new rules to timed out too quickly).
989     - Added support for multiple users in REQUIRE_USERNAME keyword in
990       access.conf.
991     - Added the ability to display raw encrypted packet data in client
992       mode with --verbose.
993     - Created fwknop RPM for RPM-based Linux distributions.
994     - Bugfix for inappropriate redirects in command mode where the command
995       already contained a redirect.
996
997 fwknop-0.9.3 (08/27/2005):
998     - Added an on-disk cache of md5 sums so that the md5 sum check can
999       survive restarts of fwknop.
1000     - Updated install.pl to be more friendly to Mac OS X (Blair Zajac).
1001     - Updated to allow access.conf variables to have values instead of just
1002       being defined.
1003     - Started on additional server authentication mode code (re-worked MD5
1004       sum calculation to allow packet format to be extended by taking into
1005       account the fwknop version number).
1006
1007 fwknop-0.9.2 (08/06/2005):
1008     - Added FILE_PCAP data collection method when running in server mode.
1009       This is a more general way of getting packets than the ULOG_PCAP
1010       mode since then a normal ethernet sniffer can be used to build the
1011       file.
1012     - Added the ability to re-open a pcap file if its size shrinks (i.e.
1013       it gets rotated out or something).
1014     - Bugfix for multiple rules with the same timestamp not being timed out
1015       by knoptm.
1016     - Integrated spoofing capability directly within fwknop (instead of
1017       using the knopspoof command) through the use of "require Net::RawIP".
1018     - Better multi-protocol support in server mode.  Tcp and icmp packets
1019       are properly decoded now.
1020
1021 fwknop-0.9.1 (07/29/2005):
1022     - Added the ability to specify multiple ports/protocols to access on a
1023       server with the --Access command line option.
1024     - Added the ability to spoof SPA packets over icmp and tcp protocols.
1025     - Added the ability to restrict access at the server to only those
1026       ports defined in the OPEN_PORTS keyword.  This option is controled by
1027       a new keyword "PERMIT_CLIENT_PORTS".
1028     - Bugfix for MD5 sum not being properly calculated over decrypted data.
1029       This allowed old packets that contained additional garbage data to
1030       be replayed against an fwknop server.
1031     - Updated to fall back to getpwuid() if getlogin() fails (Blair Zajac).
1032     - Added --ipt-list to list all current rules in the FWKNOP iptables
1033       chains.
1034     - Added --ipt-flush to flush all current rules in the FWKNOP iptables
1035       chains.
1036     - Bugfix for the installer dying if ~/lib already exists (Blair Zajac).
1037     - Updated to delay the loading of server perl modules (Net::Pcap, etc.)
1038       only if we are running in server mode.
1039     - Bugfix for module directory paths in install.pl.
1040
1041 fwknop-0.9.0 (05/29/2005):
1042     - Added new authorization mode that uses Net::Pcap to read packets
1043       out of a file that is written to by the ulogd pcap writer (also
1044       stubbed in code to sniff packets directly off the wire).  This
1045       authorization mode only requires single packets, and has many
1046       characteristics that are better than simple port knocking, including
1047       being non-replayable, and much more data can be sent.  This mode
1048       is now the default for both the server and the client.
1049     - Made the execution of knopmd optional depending on whether AUTH_MODE
1050       is a pcap mode (e.g. ULOG_PCAP or PCAP).
1051     - Added --Spoof-src argument so that encrypted packets can be spoofed
1052       via /usr/sbin/knopspoof.
1053     - Added /usr/sbin/knoptm so that firewall rules can be timed-out when
1054       the server is running in PCAP mode even if new packets don't appear
1055       on the wire.
1056     - Updated fwknop man page to talk about the new pcap-based
1057       authorization mode.
1058
1059 fwknop-0.5.0 (03/19/2005):
1060     - Added ALERTING_METHOD to allow syslog and/or email reporting to be
1061       disabled (there is a dedicated file /etc/fwknop/alert.conf that
1062       governs this behavior, and both fwknop and knopwatchd reference this
1063       file).
1064     - Bugfix for distinguishing OPT field associated with --log-tcp-options
1065       vs. --log-ip-options.
1066     - Added install_perl_module() install.pl from psad to provide a
1067       consistent installation interface.
1068     - Applied patch to only install perl modules that are not already
1069       installed (Blair Zajac).
1070     - Added --last-cmd option to allow fwknop to be executed with command
1071       line arguments from the previous execution (they are saved in
1072       ~/.fwknop.run).
1073     - Added --Home-dir option to allow the home directory to be manually
1074       specified.
1075     - Re-worked get_homedir() to be more friendly to systems that do not
1076       necessarily have /etc/passwd (e.g. OS X).
1077     - Added configuration preservation and querying for which syslog
1078       daemon is running to install.pl.  These features were adapted from the
1079       psad installer (http://www.cipherdyne.org/psad).
1080     - Added IPTables::ChainMgr.  Fwknop uses this module to maintain
1081       dedicated chains to which access rules are added.
1082     - Added IPTables::Parse, which is used internally by IPTables::ChainMgr.
1083     - Added __WARN__ and __DIE__ handlers so errors can easily be collected.
1084
1085 fwknop-0.4.2 (09/27/2004):
1086     - Added init script for Fedora systems.
1087     - Added --Kill, --Restart, and --Status modes (this fixes the generic
1088       init script which depends on these arguments).
1089
1090 fwknop-0.4.1 (09/14/2004):
1091     - Bugfix for legacy posf code in fwknop and variable in fwknop.conf.
1092
1093 fwknop-0.4 (09/10/2004):
1094     - Added ability to specify multiple IPs/networks in a single SOURCE
1095       definition.
1096     - Better examples section in the fwknop manpage.
1097     - Bugfix to make sure EMAIL_ADDRESSES variable does not contain commas
1098       (any commas are translated into spaces).
1099     - Added LICENSE file.
1100
1101 fwknop-0.3 (08/21/2004):
1102     - Bugfix for tracking knock sequences by source IP address.
1103     - Bugfix for knock sequence timeouts.
1104     - Removed old passive OS fingerprinting code in favor of the p0f
1105       strategy.
1106     - Added support for taking encryption keys from a file specified on
1107       the command line.
1108     - Update to send "sequence decrypt failed" email message only if
1109       decryption failed for all encrypt sequence SOURCE blocks.
1110
1111 fwknop-0.2 (07/31/2004):
1112     - Implemented remote username checking in encrypted sequences.
1113     - Added support for icmp in knock sequences.
1114     - Added protocol rotation option for encrypted sequences.
1115     - Added code for multiple SOURCE access blocks with the same source
1116       net/IP.
1117     - Added KNOCK_LIMIT access control variable to limit the number of
1118       times a particular knock sequence is honored.
1119     - Added email alerts.
1120
1121 fwknop-0.1 (07/08/2004):
1122     - Initial release.
Note: See TracBrowser for help on using the browser.