root/fwknop/tags/fwknop-1.9.8/ChangeLog

Revision 1281, 53.9 KB (checked in by mbr, 2 years ago)

- Made the updated UI from Sean Greven available on cipherdyne.org. This
update fixes the timezone problem so that SPA packets generated by the
UI will be properly handled by an fwknopd server.

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