-Add short section to Filter Files to tie in with +filter action.
[privoxy.git] / doc / source / user-manual.sgml
index c75aa4a..15ac7f6 100644 (file)
@@ -25,7 +25,7 @@
                 This file belongs into
                 ijbswa.sourceforge.net:/home/groups/i/ij/ijbswa/htdocs/
                 
- $Id: user-manual.sgml,v 1.92 2002/04/25 18:55:13 hal9 Exp $
+ $Id: user-manual.sgml,v 1.95 2002/04/26 17:23:29 swa Exp $
 
  Written by and Copyright (C) 2001 the SourceForge
  Privoxy team. http://www.privoxy.org/
@@ -46,7 +46,7 @@
 <artheader>
 <title>Privoxy User Manual</title>
 
-<pubdate>$Id: user-manual.sgml,v 1.92 2002/04/25 18:55:13 hal9 Exp $</pubdate>
+<pubdate>$Id: user-manual.sgml,v 1.95 2002/04/26 17:23:29 swa Exp $</pubdate>
 
 <authorgroup>
  <author>
@@ -99,7 +99,6 @@
 </sect1>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-
 <sect1 label="1" id="introduction"><title>Introduction</title>
 <para>
  This documentation is included with the current &p-status; version of
 ]]>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="newfeatures">
-<title>New Features</title>
+<sect2 id="features"><title>Features</title>
 <para>
  In addition to <application>Internet Junkbuster's</application> traditional
  features of ad and banner blocking and cookie management,
  <application>Privoxy</application> provides new features<![%p-not-stable;[,
  some of them currently under development]]>:
 </para>
-
 <!-- Include newfeatures.sgml boilerplate here: -->
  &newfeatures;
 <!-- end boilerplate -->
  <application>Privoxy</application> is available both in convenient pre-compiled
  packages for a wide range of operating systems, and as raw source code.
  For most users, we recommend using the packages, which can be downloaded from our
- <ulink url="http://sourceforge.net/projects/ijbswa/">Privoxy Project Page</ulink>.
+ <ulink url="http://sourceforge.net/projects/ijbswa/">Privoxy Project
+ Page</ulink>. For installing and compiling the source code, please look 
+ into our Developer Manual.
 </para>
 
 <para>
  version directly from <ulink url="http://sourceforge.net/cvs/?group_id=11118">the
  CVS repository</ulink> or simply download <ulink
  url="http://cvs.sourceforge.net/cvstarballs/ijbswa-cvsroot.tar.gz">the nightly CVS
- tarball.</ulink>
+ tarball.</ulink> Again, we refer you to the Developer Manual.
 </para>
 
 <!-- Include supported.sgml boilerplate -->
  &supported; 
 <!-- end boilerplate -->
 
-<!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="installation-packages"><title>Binary Packages</title>
-
 <para>
  Note: If you have a previous <application>Junkbuster</application> or
  <application>Privoxy</application> installation on your system, you
 <para>
  In any case <emphasis>be sure to backup your old configuration
  if it is valuable to you.</emphasis> See the
- <link linkend="upgradersnote">note to upgraders</link>.
-</para>
-
-<para>
- How to install the binary packages depends on your operating system:
+ <link linkend="upgradersnote">note to upgraders</link> section
+ below.
 </para>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect3 id="installation-pack-rpm"><title>Red Hat and SuSE RPMs</title>
+<sect2 id="installation-pack-rpm"><title>Red Hat and SuSE RPMs</title>
 
 <para>
  RPMs can be installed with <literal>rpm -Uvh privoxy-&p-version;-1.rpm</literal>,
 </para>
 
 <para>
- Note that on Red Hat, <application>Privoxy</application> will not be
- automatically started on system boot. You will need to enable that using
- <command>chkconfig</command>, <command>ntsysv</command>, or similar method.
+ Note that on Red Hat, <application>Privoxy</application> will
+ <emphasis>not</emphasis> be automatically started on system boot. You will
+ need to enable that using <command>chkconfig</command>,
+ <command>ntsysv</command>, or similar methods. Note that SuSE will 
+automatically start Privoxy in the boot process.
 </para>
 
 <para>
  Otherwise, RPM will try to remove <application>Junkbuster</application>
  automatically, before installing <application>Privoxy</application>.
 </para>
-</sect3>
+</sect2>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect3 id="installation-deb"><title>Debian</title>
+<sect2 id="installation-deb"><title>Debian</title>
 <para>
  FIXME.
 </para>
-</sect3>
+</sect2>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect3 id="installation-pack-win"><title>Windows</title>
+<sect2 id="installation-pack-win"><title>Windows</title>
 
 <para>
  Just double-click the installer, which will guide you through
- the installation process.
+ the installation process. You will find the configuration files
+ in the same directory as you installed Privoxy in. We do not
+ use the registry of Windows. 
 </para>
-</sect3>
+</sect2>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect3 id="installation-pack-bintgz"><title>Solaris, NetBSD, FreeBSD, HP-UX</title>
+<sect2 id="installation-pack-bintgz"><title>Solaris, NetBSD, FreeBSD, HP-UX</title>
 
 <para>
  Create a new directory, <literal>cd</literal> to it, then unzip and
  untar the archive. For the most part, you'll have to figure out where
  things go. FIXME.
 </para>
-</sect3>
+</sect2>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect3 id="installation-os2"><title>OS/2</title>
+<sect2 id="installation-os2"><title>OS/2</title>
 
 <para>
  First, make sure that no previous installations of
  The directory you choose to install <application>Privoxy</application>
  into will contain all of the configuration files.
 </para>
-</sect3>
+</sect2>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect3 id="installation-mac"><title>Max OSX</title>
+<sect2 id="installation-mac"><title>Max OSX</title>
 <para>
  Unzip the downloaded package (you can either double-click on the file
  in the finder, or on the desktop if you downloaded it there).  Then,
  automatically on system bring-up via
  <literal>/System/Library/StartupItems/Privoxy</literal>.
 </para>
-</sect3>
+</sect2>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect3 id="installation-amiga"><title>AmigaOS</title>
+<sect2 id="installation-amiga"><title>AmigaOS</title>
 <para>
  Copy and then unpack the <filename>lha</filename> archive to a suitable location. 
  All necessary files will be installed into <application>Privoxy</application>
  TCP/IP stack (just ignore the harmless warning your TCP/IP stack may display that
  <application>Privoxy</application> is still running).
 </para>
-</sect3>
 </sect2>
-
-<!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="installation-source"><title>Building from Source</title>
-
-<!-- include buildsource.sgml boilerplate: -->
- &buildsource;
-<!-- end boilerplate -->
-</sect2>
-
 </sect1>
 
 <!--  ~  End section  ~  -->
 
-
 <!--   ~~~~~       New section      ~~~~~     -->
-
-<sect1 id="quickstart"><title>Quickstart to Using <application>Privoxy</application></title>
-
-
-<!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="upgradersnote">
+<sect1 id="upgradersnote">
 <title>Note to Upgraders</title>
 <para>
  There are very significant changes from older versions of 
 
  </itemizedlist>
 </para>
+</sect1>
 
-</sect2>
+<!--   ~~~~~       New section      ~~~~~     -->
+<sect1 id="quickstart"><title>Quickstart to Using <application>Privoxy</application></title>
+<para>
+ <itemizedlist>
+
+ <listitem>
+  <para>
+  Install <application>Privoxy</application>. See the section <link linkend="installation">Installing</link>.
+  </para>
+ </listitem>  
+
+ <listitem>
+  <para>
+  Start <application>Privoxy</application>. See the section <link linkend="startup">Starting <application>Privoxy</application></link>.
+  </para>
+ </listitem>  
+
+ <listitem>
+  <para>
+  Change your browser's configuration to use the proxy <literal>localhost</literal> on port
+  <literal>8118</literal>. See the section <link linkend="startup">Starting <application>Privoxy</application></link>.
+  </para>
+ </listitem>  
+
+ <listitem>
+  <para>
+  Enjoy surfing with enhanced comfort and privacy. Please see the section
+  <link linkend="contact">Contacting the Developers</link> on how to report
+  bugs or problems with websites or to get help. You may want to change the
+  file <filename>user.action</filename> to further tweak your new browsing
+  experience.
+  </para>
+ </listitem>  
+
+ </itemizedlist>
+</para>
+
+</sect1>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="startup">
+<sect1 id="startup">
 <title>Starting <application>Privoxy</application></title>
 <para>
  Before launching <application>Privoxy</application> for the first time, you 
 
 <para>
  <screen>
  # /usr/sbin/privoxy /etc/privoxy/config
- </screen>
+</screen>
 </para>
 
 <para>
  Developers</quote></ulink> below. 
 </para>
 
-</sect2>
-
-
 <!--   ~~~~~       New section      ~~~~~     -->
 <sect2 id="cmdoptions">
 <title>Command Line Options</title>
 
 <para>
  All files use the <quote><literal>#</literal></quote> character to denote a
- comment (the rest of the line will be ignored) and understand line continuation
+ comment (the rest of the line will be ignored) angd understand line continuation
  through placing a backslash ("<literal>\</literal>") as the very last character
  in a line. If the <literal>#</literal> is preceded by a backslash, it looses
  its special function. Placing a <literal>#</literal> in front of an otherwise
 </sect4>
 
 <sect4 id="actionsfile"><title>
+actionsfile
+</title>
 <anchor id="default.action">
 <anchor id="standard.action">
 <anchor id="user.action">
-actionsfile
-</title>
 
 <variablelist>
  <varlistentry>
@@ -1018,7 +1032,7 @@ actionsfile
     The default values include standard.action, which is used for internal
     purposes and should be loaded, default.action, which is the
     <quote>main</quote> actions file maintained by the developers, and
-    user.action, where you can make your personal additions.
+    <filename>user.action</filename>, where you can make your personal additions.
    </para>
    <para> 
     There is no point in using <application>Privoxy</application> without an actions file.
@@ -1028,7 +1042,8 @@ actionsfile
 </variablelist>
 </sect4>
 
-<sect4 id="filterfile"><title><anchor id="default.filter">filterfile</title>
+<sect4 id="filterfile"><title>filterfile</title>
+<anchor id="default.filter">
 <variablelist>
  <varlistentry>
   <term>Specifies:</term>
@@ -1462,7 +1477,7 @@ actionsfile
   debug      1024 # debug kill pop-ups
   debug      4096 # Startup banner and warnings.
   debug      8192 # Non-fatal errors
-    </programlisting>
+</programlisting>
    </para>
    <para>
     To select multiple debug levels, you can either add them or use
@@ -1610,7 +1625,7 @@ actionsfile
    <para>
     <programlisting>
   listen-address  192.168.0.1:8118
-    </programlisting>
+</programlisting>
    </para>
   </listitem>
  </varlistentry>
@@ -1778,9 +1793,9 @@ actionsfile
 </sect4>
 
 <sect4 id="acls"><title>
+ACLs: permit-access and deny-access</title>
 <anchor id="permit-acces">
 <anchor id="deny-acces">
-ACLs: permit-access and deny-access</title>
 
 <variablelist>
  <varlistentry>
@@ -1876,7 +1891,7 @@ ACLs: permit-access and deny-access</title>
    <para>
     <screen>
   permit-access  localhost
-    </screen>
+</screen>
    </para>
    <para>
     Allow any host on the same class C subnet as www.privoxy.org access to
@@ -1885,7 +1900,7 @@ ACLs: permit-access and deny-access</title>
    <para>
     <screen>
   permit-access  www.privoxy.org/24 www.example.com/32
-    </screen>
+</screen>
    </para>
    <para>
     Allow access from any host on the 26-bit subnet 192.168.45.64 to anywhere,
@@ -1895,7 +1910,7 @@ ACLs: permit-access and deny-access</title>
     <screen>
   permit-access  192.168.45.64/26
   deny-access    192.168.45.73    www.dirty-stuff.example.com
-    </screen>
+</screen>
    </para>
   </listitem>
  </varlistentry>
@@ -2048,7 +2063,7 @@ ACLs: permit-access and deny-access</title>
     <screen>
   forward   .*     anon-proxy.example.org:8080
   forward   :443   .
-    </screen>
+</screen>
    </para>
    <para>
     Everything goes to our example ISP's caching proxy, except for requests
@@ -2058,7 +2073,7 @@ ACLs: permit-access and deny-access</title>
     <screen>
   forward   .*.                caching-proxy.example-isp.net:8000
   forward   .example-isp.net   .
-    </screen>
+</screen>
    </para>
   </listitem>
  </varlistentry>
@@ -2066,9 +2081,9 @@ ACLs: permit-access and deny-access</title>
 </sect4>
 
 <sect4 id="socks"><title>
+forward-socks4 and forward-socks4a</title>
 <anchor id="forward-socks4">
 <anchor id="forward-socks4a">
-forward-socks4 and forward-socks4a</title>
 
 <variablelist>
  <varlistentry>
@@ -2142,7 +2157,7 @@ forward-socks4 and forward-socks4a</title>
     <screen>
   forward-socks4a   .*.            socks-gw.example.com:1080  www-cache.example-isp.net:8080
   forward           .example.com   .
-    </screen>
+</screen>
    </para>
    <para>
     A rule that uses a SOCKS 4 gateway for all destinations but no HTTP parent looks like this:
@@ -2150,7 +2165,7 @@ forward-socks4 and forward-socks4a</title>
    <para>
     <screen>
   forward-socks4   .*.            socks-gw.example.com:1080  .
-    </screen>
+</screen>
    </para>
   </listitem>
  </varlistentry>
@@ -2180,7 +2195,7 @@ forward-socks4 and forward-socks4a</title>
  <screen>
   forward    .*.         .
   forward    .isp-b.net  host-b:8118
- </screen>
+</screen>
 </para>
 
 <para>
@@ -2191,7 +2206,7 @@ forward-socks4 and forward-socks4a</title>
  <screen>
   forward    .*.         .
   forward    .isp-a.net  host-a:8118
- </screen>
+</screen>
 </para>
 
 <para>
@@ -2223,8 +2238,7 @@ forward-socks4 and forward-socks4a</title>
   always_direct allow ftp 
 
   # Forward all the rest to Privoxy
-  never_direct allow all 
- </screen>
+  never_direct allow all</screen>
 </para>
 
 <para>
@@ -2426,8 +2440,7 @@ forward-socks4 and forward-socks4a</title>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="actions-file">
-<title>Actions Files</title>
+<sect2 id="actions-file"><title>Actions Files</title>
 
 <para>
  The actions files are used to define what actions
@@ -2445,7 +2458,7 @@ forward-socks4 and forward-socks4a</title>
  </para>
 
 <para> 
- Anything you want can blocked, including ads, banners, or just some obnoxious
+ Anything you want can be blocked, including ads, banners, or just some obnoxious
  URL that you would rather not see is done here. Cookies can be accepted or rejected, or
  accepted only during the current browser session (i.e. not written to disk),
  content can be modified, JavaScripts tamed, user-tracking fooled, and much more.
@@ -2809,12 +2822,13 @@ forward-socks4 and forward-socks4a</title>
 
 <para>
  Later defined actions always over-ride earlier ones.  So exceptions 
- to any rules you make, should come in the latter part of the file. For
- multi-valued actions, the actions are applied in the order they are
- specified. Actions files are processed in the order they are defined 
- in <filename>config</filename> (the default installation has three 
- actions files). It also quite possible for any given URL pattern to 
- match more than one action!
+ to any rules you make, should come in the latter part of the file (or 
+ in a file that is processed later when using multiple actions files). For
+ multi-valued actions, the actions are applied in the order they are specified.
+ Actions files are processed in the order they are defined in
+ <filename>config</filename> (the default installation has three actions
+ files). It also quite possible for any given URL pattern to match more than
+ one action!
 </para>
 
 <!-- start actions listing -->
@@ -2833,7 +2847,7 @@ forward-socks4 and forward-socks4a</title>
 <!--   ~~~~~       New section      ~~~~~     -->
 
 <sect4 id="add-header">
-<title><emphasis>+add-header{Name: value}</emphasis></title>
+<title><emphasis>+add-header</emphasis></title>
 
 <variablelist>
  <varlistentry>
@@ -2937,8 +2951,8 @@ forward-socks4 and forward-socks4a</title>
     will intercept the URL and display its special <quote>BLOCKED</quote> page
     instead. If there is sufficient space, a large red banner will appear with
     a friendly message about why the page was blocked, and a way to go there
-    anyway. If there is insufficient space a smaller blocked page will appear
-    without the red banner. 
+    anyway. If there is insufficient space a smaller <quote>BLOCKED</quote>
+    page will appear without the red banner. 
     <ulink url="http://ads.bannerserver.example.com/nasty-ads/sponsor.html">Click here</ulink>
     to view the default blocked HTML page (<application>Privoxy</application> must be running 
     for this to work as intended!).
@@ -3405,9 +3419,8 @@ forward-socks4 and forward-socks4a</title>
 
 <!--   ~~~~~       New section      ~~~~~     -->
 <sect4 id="hide-referer">
-<title><emphasis><anchor id="hide-referrer">+hide-referer</emphasis></title>
-
-
+<title><emphasis>+hide-referer</emphasis></title>
+<anchor id="hide-referrer">
 <variablelist>
  <varlistentry>
   <term>Type:</term>
@@ -4169,12 +4182,215 @@ forward-socks4 and forward-socks4a</title>
  that some actions are turned on in the default section of the actions file, 
  and require little to no additional configuration. These are just <quote>on</quote>.
  But, other actions that are turned on the default section <emphasis>do
- typically require</emphasis> exceptions to be listed in the lower sections of
- actions file. E.g. by default no URLs are <quote>blocked</quote> (i.e. in 
- the default definitions of <filename>default.action</filename>). We need 
- exceptions to this in order to enable ad blocking.
+ typically require</emphasis> exceptions to be listed in the latter sections of 
+ one of our actions file. For instance, by default no URLs are
+ <quote>blocked</quote> (i.e. in the default definitions of
+ <filename>default.action</filename>). We need exceptions to this in order to
+ enable ad blocking in the lower sections. But we need to be very selective
+ about what we do block.
+</para>
+
+<para>
+ Below is a liberally commented <filename>default.action</filename> file  to 
+ demonstrate how all the pieces come together. And to show how exceptions to
+ the default policies can be handled. This is followed by a
+ <filename>user.action</filename> with similar examples.
 </para>
 
+<para>
+ <literal>
+  <msgtext> 
+   <literallayout>
+
+# Settings -- Don't change! For internal Privoxy use ONLY.
+{{settings}}
+for-privoxy-version=3.0
+
+
+##########################################################################
+# <ulink url="configuration.html#ALIASES">Aliases</ulink> must be defined *before* they are used. These are
+# easier to remember, and combine several actions into one. Once defined
+# they can be used just like any built-in action.
+##########################################################################
+
+# Some useful aliases.
+ -prevent-cookies = -prevent-setting-cookies -prevent-reading-cookies
+ +imageblock      = +block +handle-as-image
+
+# Fragile sites should have the minimum changes:
+ fragile     = -block -deanimate-gifs -fast-redirects -filter -hide-referer \
+               -prevent-cookies -kill-popups
+
+# Shops should be allowed to set persistent cookies
+ shop        = -filter -prevent-cookies -session-cookies-only
+
+
+##########################################################################
+# Begin default action settings. Anything in this section will match 
+# all URLs -- UNLESS we have exceptions that match defined below this 
+# section. We will show all potential actions here whether they are on 
+# or off. We could omit any disabled action if we wanted, since all 
+# actions are 'off' by default anyway. Shown for completeness only.
+# Actions are enabled if preceded by a '+', otherwise they are disabled.
+##########################################################################
+ { \
+ <ulink url="configuration.html#ADD-HEADER">-add-header</ulink> \
+ <ulink url="configuration.html#BLOCK">-block</ulink> \
+ <ulink url="configuration.html#DEANIMATE-GIFS">-deanimate-gifs</ulink> \
+ <ulink url="configuration.html#DOWNGRADE-HTTP-VERSION">-downgrade-http-version</ulink> \
+ <ulink url="configuration.html#FAST-REDIRECTS">+fast-redirects</ulink> \
+ <ulink url="configuration.html#FILTER">+filter{html-annoyances}</ulink> \
+ <ulink url="configuration.html#FILTER">+filter{js-annoyances}</ulink> \
+ <ulink url="configuration.html#FILTER">-filter{content-cookies}</ulink> \
+ <ulink url="configuration.html#FILTER">-filter{popups}</ulink> \
+ <ulink url="configuration.html#FILTER">+filter{webbugs}</ulink> \
+ <ulink url="configuration.html#FILTER">-filter{refresh-tags}</ulink> \
+ <ulink url="configuration.html#FILTER">-filter{fun}</ulink> \
+ <ulink url="configuration.html#FILTER">+filter{nimda}</ulink> \
+ <ulink url="configuration.html#FILTER">+filter{banners-by-size}</ulink> \
+ <ulink url="configuration.html#FILTER">-filter{shockwave-flash}</ulink> \
+ <ulink url="configuration.html#FILTER">-filter{crude-prental}</ulink> \
+ <ulink url="configuration.html#HIDE-FORWARDED-FOR-HEADERS">+hide-forwarded-for-headers</ulink> \
+ <ulink url="configuration.html#HIDE-FROM-HEADER">+hide-from-header{block}</ulink> \
+ <ulink url="configuration.html#HIDE-REFERER">-hide-referrer</ulink> \
+ <ulink url="configuration.html#HIDE-USER-AGENT">-hide-user-agent</ulink> \
+ <ulink url="configuration.html#HANDLE-AS-IMAGE">-handle-as-image</ulink> \
+ <ulink url="configuration.html#SET-IMAGE-BLOCKER">+set-image-blocker{pattern}</ulink> \
+ <ulink url="configuration.html#LIMIT-CONNECT">-limit-connect</ulink> \
+ <ulink url="configuration.html#PREVENT-COMPRESSION">+prevent-compression</ulink> \
+ <ulink url="configuration.html#SESSION-COOKIES-ONLY">-session-cookies-only</ulink> \
+ <ulink url="configuration.html#PREVENT-READING-COOKIES">-prevent-reading-cookies</ulink> \
+ <ulink url="configuration.html#PREVENT-SETTING-COOKIES">-prevent-setting-cookies</ulink> \
+ <ulink url="configuration.html#KILL-POPUPS">-kill-popups</ulink> \
+ <ulink url="configuration.html#SEND-VANILLA-WAFER">-send-vanilla-wafer</ulink> \
+ <ulink url="configuration.html#SEND-WAFER">-send-wafer</ulink> \
+ }
+ / # forward slash will match *all* potential URL patterns. 
+
+##########################################################################
+# Default behavior is now set. Time for some exceptions to our 
+# default actions.
+##########################################################################
+
+# These sites are very complex and require very minimal interference.
+# We'll disable most actions with our 'fragile' alias.
+ {fragile}
+ .office.microsoft.com           # surprise, surprise!
+ .windowsupdate.microsoft.com
+
+
+# Shopping sites - not as fragile but require some special 
+# handling. We still want to block ads, and we will allow 
+# persistant cookies via the 'shop' alias.
+ {shop}
+ .quietpc.com 
+ .worldpay.com   # for quietpc.com
+ .jungle.com
+ .scan.co.uk
+
+
+# These sites require pop-ups too :(  We'll combine our 'shop' 
+# alias with two other actions into one rule to allow all popups.
+ {shop -no-popups -filter{popups}}
+ .dabs.com
+ .overclockers.co.uk
+
+
+# The 'Fast-redirects' action breaks some sites. Disable this action
+# for these known sensitive sites.
+ {-fast-redirects}
+ www.ukc.ac.uk/cgi-bin/wac\.cgi\?
+ login.yahoo.com
+ edit.europe.yahoo.com
+ .google.com
+ .altavista.com/.*(like|url|link):http
+ .altavista.com/trans.*urltext=http
+ .nytimes.com
+
+
+# Define which file types will be treated as images. Important
+# for ad blocking.
+ {+handle-as-image}
+ /.*\.(gif|jpe?g|png|bmp|ico)
+
+
+# Now lets list some domains that are known ad generators. And
+# our alias here will block these as well as force them to be 
+# treated as images. This combination of actions is important 
+# for ad blocking. What the browser will show instead is 
+# determined by the setting of <ulink url="configuration.html#SET-IMAGE-BLOCKER"><quote>+set-image-blocker</quote></ulink>
+ {+imageblock}
+ ar.atwola.com 
+ .ad.doubleclick.net
+ .a.yimg.com/(?:(?!/i/).)*$
+ .a[0-9].yimg.com/(?:(?!/i/).)*$
+ bs*.gsanet.com
+ bs*.einets.com
+ .qkimg.net
+ ad.*.doubleclick.net
+
+
+# These will just simply be blocked. They will generate the BLOCKED
+# banner page, if matched. Heavy use of wildcards and regular 
+# expressions in this example.
+ {+block}
+ ad*.
+ .*ads.
+ banner?.
+ count*.
+ /.*count(er)?\.(pl|cgi|exe|dll|asp|php[34]?)
+ /(?:.*/)?(publicite|werbung|rekla(ma|me|am)|annonse|maino(kset|nta|s)?)/
+ .hitbox.com 
+
+
+# The above block section will catch some sites we DO NOT want 
+# blocked via the wildcards and regular expressions. Now let's set 
+# exceptions to the exceptions so the good guys get better treatment.
+ {-block}
+ advogato.org
+ adsl.
+ ad[ud]*.
+ advice.
+# Let's just trust all .edu top level domains.
+ .edu
+ www.ugu.com/sui/ugu/adv
+# We'll need to access to path names containing 'download' 
+ .*downloads.
+ /downloads/
+# 'adv' is for globalintersec and means advanced, not advertisement
+ www.globalintersec.com/adv
+
+
+# Don't filter *anything* from our friends at sourceforge.
+# Notice we don't have to name the individual filter 
+# identifiers -- we just turn them all off in one fell swoop.
+ {-filter}
+ .sourceforge.net
+
+   </literallayout>
+  </msgtext> 
+ </literal>
+</para>
+
+<para>
+ So far we are painting with a broad brush by setting general policies. 
+ The above would be a reasonable starting point for many situations. Now, 
+ we want to be more specific and have customized rules that are more suitable
+ to our personal habits and preferences. These should be placed in 
+ <filename>user.action</filename>, which is parsed after all other 
+ actions files. So any settings here, will have the last word.
+</para>
+
+<para>
+ Now an example of a few things that one might do with a <filename>user.action</filename>
+ file. This is where user preferences are defined.
+</para>
+
+<!-- brief sample user.action here -->
+
+
+<!-- This is the old stuff. Left in temporarily for reference -->
+<!-- To be deleted when above is finished -->
 <para>
  Some examples:
 </para>
@@ -4500,6 +4716,32 @@ forward-socks4 and forward-socks4a</title>
  </literal>
 </para>
 
+
+<!--   ~~~~~       New section      ~~~~~     -->
+<sect3>
+<title>The +filter Action</title>
+<para>
+ Filters are enabled with the <ulink
+ url="configuration.html#FILTER"><quote>+filter</quote></ulink> action from within 
+ one of the actions files. <quote>+filter</quote> requires one parameter, which 
+ should match one of the section identifiers in the filter file itself. Example:
+</para>
+
+<para>
+ <screen>
+  +filter{html-annoyances}
+ </screen>
+</para>
+
+<para>
+ This would activate that particular filter. Similarly, <quote>+filter</quote>
+ can be turned off for selected sites as:
+ <quote>-filter{html-annoyances}</quote>. Remember, all actions are off by
+ default, unless they are explicity enabled in one of the actions files.
+</para>
+
+</sect3>
+
 </sect2>
 
 <!--  ~  End section  ~  -->
@@ -4541,35 +4783,6 @@ Requests</title>
  &contacting;
 <!-- end boilerplate -->
 
-
-<!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="submitactions">
-<title>Submitting Ads and <quote>Action</quote> Problems</title>
-<para>
- Ads and banners that are not stopped by <application>Privoxy</application> 
- can be submitted to the developers by accessing a special page and filling 
- out the brief, required form. Conversely, you can also report pages, images,
- etc. that <application>Privoxy</application> is blocking, but should not.
- The form itself does require Internet access.
-</para>
-<para>
- To do this, point your browser to <application>Privoxy</application> 
- at <ulink url="http://config.privoxy.org/">http://config.privoxy.org/</ulink>
- (shortcut: <ulink url="http://p.p/">http://p.p/</ulink>), and then select 
- <ulink url="javascript:w=Math.floor(screen.width/2);h=Math.floor(screen.height*0.9);void(window.open('http://www.privoxy.org/actions','Feedback','screenx='+w+',width='+w+',height='+h+',scrollbars=yes,toolbar=no,location=no,directories=no,status=no,menubar=no,copyhistory=no').focus());">Actions file feedback system</ulink>, 
- near the bottom of the page. Paste in the URL that is the cause of the 
- unwanted behavior, and follow the prompts. The developers will 
- try to incorporate a fix for the problem you reported into future versions.
-</para>
-
-<para>
- New, improved <filename>default.action</filename> files will occasionally be made
- available based on your feedback. These will be announced on the <ulink
- url="http://lists.sourceforge.net/lists/listinfo/ijbswa-announce">ijbswa-announce</ulink>
- list.
-</para>
-</sect2>
-
 </sect1>
 
 
@@ -4992,31 +5205,35 @@ Requests</title>
 
   <listitem>
    <para>
-    <ulink url="javascript:void(window.open('http://config.privoxy.org/toggle?mini=y&#38;set=enabled','ijbstatus','width=250,height=100,resizable=yes,scrollbars=no,toolbar=no,location=no,directories=no,status=no,menubar=no,copyhistory=no').focus());">Enable Privoxy</ulink>
+    <ulink
+    url="javascript:void(window.open('http://config.privoxy.org/toggle?mini=y&#38;set=enabled','ijbstatus','width=250,height=100,resizable=yes,scrollbars=no,toolbar=no,location=no,directories=no,status=no,menubar=no,copyhistory=no').focus());">Privoxy - Enable</ulink>
    </para>
   </listitem> 
 
   <listitem>
    <para>
-    <ulink url="javascript:void(window.open('http://config.privoxy.org/toggle?mini=y&#38;set=disabled','ijbstatus','width=250,height=100,resizable=yes,scrollbars=no,toolbar=no,location=no,directories=no,status=no,menubar=no,copyhistory=no').focus());">Disable Privoxy</ulink>
+    <ulink
+    url="javascript:void(window.open('http://config.privoxy.org/toggle?mini=y&#38;set=disabled','ijbstatus','width=250,height=100,resizable=yes,scrollbars=no,toolbar=no,location=no,directories=no,status=no,menubar=no,copyhistory=no').focus());">Privoxy - Disable</ulink>
    </para>
   </listitem> 
 
   <listitem>
    <para>
-    <ulink url="javascript:void(window.open('http://config.privoxy.org/toggle?mini=y&#38;set=toggle','ijbstatus','width=250,height=100,resizable=yes,scrollbars=no,toolbar=no,location=no,directories=no,status=no,menubar=no,copyhistory=no').focus());">Toggle Privoxy</ulink> (Toggles between enabled and disabled)
+    <ulink
+    url="javascript:void(window.open('http://config.privoxy.org/toggle?mini=y&#38;set=toggle','ijbstatus','width=250,height=100,resizable=yes,scrollbars=no,toolbar=no,location=no,directories=no,status=no,menubar=no,copyhistory=no').focus());">Privoxy - Toggle Privoxy</ulink> (Toggles between enabled and disabled)
    </para>
   </listitem> 
 
   <listitem>
    <para>
-    <ulink url="javascript:void(window.open('http://config.privoxy.org/toggle?mini=y','ijbstatus','width=250,height=2,resizable=yes,scrollbars=no,toolbar=no,location=no,directories=no,status=no,menubar=no,copyhistory=no').focus());">View Privoxy Status</ulink>
+    <ulink
+    url="javascript:void(window.open('http://config.privoxy.org/toggle?mini=y','ijbstatus','width=250,height=2,resizable=yes,scrollbars=no,toolbar=no,location=no,directories=no,status=no,menubar=no,copyhistory=no').focus());">Privoxy- View Status</ulink>
    </para>
   </listitem> 
 
   <listitem>
    <para>
-    <ulink url="javascript:w=Math.floor(screen.width/2);h=Math.floor(screen.height*0.9);void(window.open('http://www.privoxy.org/actions','Feedback','screenx='+w+',width='+w+',height='+h+',scrollbars=yes,toolbar=no,location=no,directories=no,status=no,menubar=no,copyhistory=no').focus());">Actions file feedback system</ulink>
+    <ulink url="javascript:w=Math.floor(screen.width/2);h=Math.floor(screen.height*0.9);void(window.open('http://www.privoxy.org/actions','Feedback','screenx='+w+',width='+w+',height='+h+',scrollbars=yes,toolbar=no,location=no,directories=no,status=no,menubar=no,copyhistory=no').focus());">Privoxy - Submit Filter Feedback</ulink>
    </para>
   </listitem> 
 
@@ -5050,15 +5267,15 @@ Requests</title>
  <listitem>
   <para>
    First, your web browser requests a web page. The browser knows to send 
-   the request to <application>Privoxy</application>, who in turn, 
-   will relay the request to the remote web server after passing the following 
+   the request to <application>Privoxy</application>, which will in turn, 
+   relay the request to the remote web server after passing the following 
    tests: 
   </para>
  </listitem> 
  <listitem>
   <para>
    <application>Privoxy</application> traps any request for its own internal CGI 
-  pages (e.g http://p.p/) and sends these back to the browser.
+   pages (e.g http://p.p/) and sends the CGI page back to the browser.
   </para>
  </listitem> 
  <listitem>
@@ -5066,13 +5283,13 @@ Requests</title>
    Next, <application>Privoxy</application> checks to see if the URL 
    matches any <ulink
    url="configuration.html#BLOCK"><quote>+block</quote></ulink> patterns. If
-   so, the remote web server is not contacted, and the URL is then further
-   checked against <quote>+handle-as-image</quote>. If both match, then the
-   setting of <ulink url="configuration.html#SET-IMAGE-BLOCKER">
-   <quote>+set-image-blocker</quote></ulink> is used to display whichever
-   option is appropriate. If <ulink
-   url="configuration.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink>
-   does not match, then the <quote>BLOCKED</quote> banner page is displayed.
+   so, the URL is then blocked, and the remote web server will not be contacted.
+   <ulink url="configuration.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink> 
+   is then checked and if it does not match, an 
+   HTML <quote>BLOCKED</quote> page is sent back. Otherwise, if it does match,
+   an image is returned. The type of image depends on the setting of <ulink
+   url="configuration.html#SET-IMAGE-BLOCKER"><quote>+set-image-blocker</quote></ulink>
+   (blank, checkerboard pattern, or an HTTP redirect to an image elsewhere).
   </para>
  </listitem> 
  <listitem>
@@ -5083,44 +5300,74 @@ Requests</title>
  </listitem> 
  <listitem>
   <para>
-   <ulink
-   url="configuration.html#FAST-REDIRECTS"><quote>+fast-redirects</quote></ulink>
-   is processed, stripping unwanted parts of the requested web page URL.
+   If the URL pattern matches the <ulink
+   url="configuration.html#FAST-REDIRECTS"><quote>+fast-redirects</quote></ulink> action,
+   it is then processed. Unwanted parts of the requested URL are stripped.
+  </para>
+ </listitem> 
+ <listitem>
+  <para>
+   Now the rest of the client browser's request headers are processed. If any
+   of these match any of the relevant actions (e.g. <ulink
+   url="configuration.html#HIDE-USER-AGENT"><quote>+hide-user-agent</quote></ulink>,
+   etc.), headers are suppressed or forged as determined by these actions and
+   their parameters.
   </para>
  </listitem> 
  <listitem>
   <para>
-   At this point, <application>Privoxy</application> now relays the URL to the
-   web server, requesting the page (assuming nothing up to this point has
-   prevented getting us from this far).
+   Now the web server starts sending its response back (i.e. typically a web page and related 
+   data).
   </para>
  </listitem> 
  <listitem>
   <para>
-   The first few hundred bytes are read from the web server and 
-   <ulink url="configuration.html#KILL-POPUPS"><quote>+kill-popups</quote></ulink>
-   is processed, if enabled.
+   First, the server headers are read and processed to determine, among other
+   things, the MIME type (document type) and encoding. The headers are then
+   filtered as deterimed by the 
+   <ulink url="configuration.html#PREVENT-SETTING-COOKIES"><quote>+prevent-setting-cookies</quote></ulink>,
+   <ulink url="configuration.html#SESSION-COOKIES-ONLY"><quote>+session-cookies-only</quote></ulink>,
+   and <ulink url="configuration.html#DOWNGRADE-HTTP-VERSION"><quote>+downgrade-http-version</quote></ulink>
+   actions.
   </para>
  </listitem> 
  <listitem>
   <para>
-   If <ulink url="configuration.html#FILTER"><quote>+filter</quote></ulink>
-   applies, the rest of the page is read into memory and then the filter rules
-   (from <filename>default.filter</filename>) are processed. Filters are
-   applied in the order they are specified in the
-   <filename>default.filter</filename> file.  The entire page, which is now
-   filtered, is then sent by <application>Privoxy</application> back to your
-   browser.
+   If the <ulink url="configuration.html#KILL-POPUPS"><quote>+kill-popups</quote></ulink>
+   action applies, and it is an HTML or JavaScript document, the popup-code in the
+   response is filtered on-the-fly as it is received.
+  </para>
+ </listitem> 
+ <listitem>
+  <para>
+   If a <ulink url="configuration.html#FILTER"><quote>+filter</quote></ulink>
+   or <ulink
+   url="configuration.html#DEANIMATE-GIFS"><quote>+deanimate-gifs</quote></ulink>
+   action applies (and the document type fits the action), the rest of the page is
+   read into memory (up to a configurable limit). Then the filter rules (from
+   <filename>default.filter</filename>) are processed against the buffered
+   content. Filters are applied in the order they are specified in the
+   <filename>default.filter</filename> file. Animated GIFs, if present, are
+   reduced to either the first or last frame, depending on the action
+   setting.The entire page, which is now filtered, is then sent by
+   <application>Privoxy</application> back to your browser. 
+  </para>
+  <para>
+   If neither <ulink url="configuration.html#FILTER"><quote>+filter</quote></ulink>
+   or <ulink
+   url="configuration.html#DEANIMATE-GIFS"><quote>+deanimate-gifs</quote></ulink>
+   matches, then <application>Privoxy</application> passes the raw data through 
+   to the client browser as it becomes available.
   </para>
  </listitem> 
  <listitem>
   <para>
-   As the browser receives the now filtered page content, it will read and request any
-   embedded URLs on the page, e.g. ad images. As the browser requests these
-   secondary URLs from whatever server they may be on,
-   <application>Privoxy</application> handles these same as above, and the process
-   is repeated all over again for each such URL. Note that a fancy web page may
-   have many, many such embedded URLs for graphics, frames, etc.
+   As the browser receives the now (probably filtered) page content, it 
+   reads and then requests any URLs that may be embedded within the page
+   source, e.g. ad images, stylesheets, JavaScript, other HTML documents (e.g.
+   frames), sounds, etc. For each of these objects, the browser issues a new
+   request. And each such request is in turn processed as above. Note that a
+   complex web page may have many such embedded URLs.
   </para>
  </listitem> 
  
@@ -5166,16 +5413,17 @@ Requests</title>
  First, enter one URL (or partial URL) at the prompt, and then
  <application>Privoxy</application> will tell us 
  how the current configuration will handle it. This will not
- help with filtering effects (i.e. the <quote>+filter</quote> action) from the
- <filename>default.filter</filename> file since this is handled very differently 
- and not so easy to trap! It also will not tell you about any other URLs that
- may be embedded within the URL you are testing (i.e. a web page). For
- instance, images such as ads are expressed as URLs within the raw page source
- of HTML pages. So you will only get info for the actual URL that is pasted
- into the prompt area -- not any sub-URLs. If you want to know about embedded
- URLs like ads, you will have to dig those out of the HTML source. Use your
- browser's <quote>View Page Source</quote> option for this. Or right click on
- the ad, and grab the URL.
+ help with filtering effects (i.e. the <ulink
+ url="configuration.html#FILTER"><quote>+filter</quote></ulink> action) from
+ the <filename>default.filter</filename> file since this is handled very
+ differently and not so easy to trap! It also will not tell you about any other
+ URLs that may be embedded within the URL you are testing. For instance, images
+ such as ads are expressed as URLs within the raw page source of HTML pages. So
+ you will only get info for the actual URL that is pasted into the prompt area
+ -- not any sub-URLs. If you want to know about embedded URLs like ads, you
+ will have to dig those out of the HTML source. Use your browser's <quote>View
+ Page Source</quote> option for this. Or right click on the ad, and grab the
+ URL.
 </para>
 
 <para>
@@ -5198,11 +5446,11 @@ Requests</title>
  +filter{webbugs} +filter{refresh-tags} +filter{nimda} +filter{banners-by-size} 
  +hide-forwarded-for-headers +hide-from-header{block} +hide-referer{forge} 
  -hide-user-agent -handle-as-image +set-image-blocker{pattern} -limit-connect 
- +prevent-compression +session-cookies-only +prevent-reading-cookies 
+prevent-setting-cookies -kill-popups -send-vanilla-wafer -send-wafer }
+ +prevent-compression +session-cookies-only -prevent-reading-cookies 
-prevent-setting-cookies -kill-popups -send-vanilla-wafer -send-wafer }
 /
 
- { -prevent-setting-cookies -prevent-reading-cookies }
+ { -session-cookies-only }
  .google.com
 
  { -fast-redirects }
@@ -5210,45 +5458,49 @@ Requests</title>
 
 --- File user ---
 (no matches in this file)  
-
 </screen>
 </para>
 
 <para>
- This tells us how we have defined our <quote>actions</quote>, and which ones
- match for our example, <quote>google.com</quote>. The first listing is 
- for the <filename>standard.action</filename>. No hits at all here on
- <quote>standard</quote>. Then next is <quote>default</quote>, or our
- <filename>default.action</filename> file. The large, multi-line listing, is
- how the actions are set to match for all URLs, i.e. our default settings. If
- you look at your <quote>actions</quote> file, this would be the section just
- below the <quote>aliases</quote> section near the top. This will apply to all
- URLs as signified by the single forward slash at the end of the listing --
- <quote>/</quote>.
+ This tells us how we have defined our 
+ <ulink url="configuration.html#ACTIONS"><quote>actions</quote></ulink>, and
+ which ones match for our example, <quote>google.com</quote>. The first listing
+ is any matches for the <filename>standard.action</filename> file. No hits at
+ all here on <quote>standard</quote>. Then next is <quote>default</quote>, or
+ our <filename>default.action</filename> file. The large, multi-line listing,
+ is how the actions are set to match for all URLs, i.e. our default settings.
+ If you look at your <quote>actions</quote> file, this would be the section
+ just below the <quote>aliases</quote> section near the top. This will apply to
+ all URLs as signified by the single forward slash at the end of the listing
+ -- <quote>/</quote>.
 </para>
 
 <para>
  But we can define additional actions that would be exceptions to these general
  rules, and then list specific URLs (or patterns) that these exceptions would
  apply to. Last match wins. Just below this then are two explicit matches for
- <quote>.google.com</quote>. The first is negating our various cookie blocking
- actions (i.e. we will allow cookies here). The second is allowing
- <quote>fast-redirects</quote> to take place. Note that there is a leading dot
- here -- <quote>.google.com</quote>. This will match any hosts and sub-domains,
- in the google.com domain also, such as <quote>www.google.com</quote>. So,
- apparently, we have these two actions defined somewhere in the lower part of our
- actions file, and <quote>google.com</quote> is referenced somewhere in these
- latter sections.
+ <quote>.google.com</quote>. The first is negating our previous cookie setting, 
+ which was for <ulink
+ url="configuration.html#SESSION-COOKIES-ONLY"><quote>+session-cookies-only</quote></ulink>
+ (i.e. not persistent). So we will allow persistent cookies for google. The
+ second turns <emphasis>off</emphasis> any 
+ <ulink
+ url="configuration.html#FAST-REDIRECTS"><quote>+fast-redirects</quote></ulink>
+ action, allowing this to take place unmolested. Note that there is a leading
+ dot here -- <quote>.google.com</quote>. This will match any hosts and
+ sub-domains, in the google.com domain also, such as
+ <quote>www.google.com</quote>. So, apparently, we have these two actions
+ defined somewhere in the lower part of our <filename>default.action</filename>
+ file, and <quote>google.com</quote> is referenced somewhere in these latter
+ sections.
 </para>
 
 <para>
- Then, for our <filename>user.action</filename> file, we again have no hits, as 
- signified by <quote>File user</quote>.
+ Then, for our <filename>user.action</filename> file, we again have no hits.
 </para>
 
 <para>
- And finally we pull it altogether in the bottom section and summarize how
+ And finally we pull it altogether in the bottom section and summarize how
  <application>Privoxy</application> is applying all its <quote>actions</quote> 
  to <quote>google.com</quote>:
 
@@ -5264,15 +5516,14 @@ Requests</title>
  +filter{webbugs} +filter{refresh-tags} +filter{nimda} +filter{banners-by-size} 
  +hide-forwarded-for-headers +hide-from-header{block} +hide-referer{forge} 
  -hide-user-agent -handle-as-image +set-image-blocker{pattern} -limit-connect 
- +prevent-compression +session-cookies-only -prevent-reading-cookies 
- -prevent-setting-cookies -kill-popups -send-vanilla-wafer -send-wafer 
- </screen>
+ +prevent-compression -session-cookies-only -prevent-reading-cookies 
+ -prevent-setting-cookies -kill-popups -send-vanilla-wafer -send-wafer
+</screen>
 </para>
 
 <para>
  Notice the only difference here to the previous listing, is to 
- <quote>fast-redirects</quote> and the two cookie settings.
+ <quote>fast-redirects</quote> and <quote>session-cookies-only</quote>.
 </para>
 
 <para>
@@ -5290,16 +5541,16 @@ Requests</title>
 
  { +block +handle-as-image }
   .doubleclick.net
-
- </screen>
+</screen>
 </para>
 
 <para>
  We'll just show the interesting part here, the explicit matches. It is 
  matched three different times. Each as an <quote>+block +handle-as-image</quote>,
  which is the expanded form of one of our aliases that had been defined as: 
- <quote>+imageblock</quote>. (<quote>Aliases</quote> are defined in the 
- first section of the actions file and typically used to combine more 
+ <quote>+imageblock</quote>. (<ulink
+ url="configuration.html#ALIASES"><quote>Aliases</quote></ulink> are defined in
+ the first section of the actions file and typically used to combine more 
  than one action.)
 </para>
 
@@ -5309,9 +5560,13 @@ Requests</title>
  would also cover the first. No point in taking chances with these guys 
  though ;-) Note that if you want an ad or obnoxious 
  URL to be invisible, it should be defined as <quote>ad.doubleclick.net</quote>
- is done here -- as both a <quote>+block</quote> <emphasis>and</emphasis> an
- <quote>+handle-as-image</quote>. The custom alias <quote>+imageblock</quote> does this
- for us.
+ is done here -- as both a <ulink
+ url="configuration.html#BLOCK"><quote>+block</quote></ulink>
+ <emphasis>and</emphasis> an 
+ <ulink
+ url="configuration.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink>.
+ The custom alias <quote>+imageblock</quote> just simplifies the process and make 
+ it more readable.
 </para>
 
 <para>
@@ -5329,22 +5584,21 @@ Requests</title>
    +filter{webbugs} +filter{nimda} +filter{banners-by-size} +filter{hal} 
    +filter{fun} +hide-forwarded-for-headers +hide-from-header{block} 
    +hide-referer{forge} -hide-user-agent -handle-as-image +set-image-blocker{blank} 
-   +prevent-compression +session-cookies-only +prevent-setting-cookies 
-   +prevent-reading-cookies +kill-popups -send-vanilla-wafer -send-wafer }
+   +prevent-compression +session-cookies-only -prevent-setting-cookies 
+   -prevent-reading-cookies +kill-popups -send-vanilla-wafer -send-wafer }
    /
 
  { +block +handle-as-image }
   /ads
-
- </screen>
+</screen>
 </para>
 
 <para>
  Ooops, the <quote>/adsl/</quote> is matching <quote>/ads</quote>! But 
  we did not want this at all! Now we see why we get the blank page. We could
  now add a new action below this that explicitly does <emphasis>not</emphasis>
- block (-block) pages with <quote>adsl</quote>. There are various ways to
- handle such exceptions. Example:
+ block (<quote>{-block}</quote>) paths with <quote>adsl</quote>. There are
various ways to handle such exceptions. Example:
 </para>
 
 <para>
@@ -5352,8 +5606,7 @@ Requests</title>
 
  { -block }
   /adsl
- </screen>
+</screen>
 </para>
 
 <para>
@@ -5369,10 +5622,9 @@ Requests</title>
 <para>
  <screen>
 
- { -block }
-  /adsl
- </screen>
+ { +block +handle-as-image }
+ /ads
+</screen>
 </para>
 
 <para>
@@ -5393,13 +5645,12 @@ Requests</title>
  .jungle.com
  .scan.co.uk
  .forbes.com
- </screen>
+</screen>
 </para>
 
 <para>
  <quote>{shop}</quote> is an <quote>alias</quote> that expands to 
- <quote>{ -filter -prevent-setting-cookies -prevent-reading-cookies }</quote>.
+ <quote>{ -filter -session-cookies-only }</quote>.
  Or you could do your own exception to negate filtering:
 
 </para>
@@ -5409,13 +5660,12 @@ Requests</title>
 
  {-filter}
  .forbes.com
- </screen>
+</screen>
 </para>
 
 <para>
  This would probably be most appropriately put in <filename>user.action</filename>, 
- for personal user exceptions.
+ for local site exceptions.
 </para>
 
 <para>
@@ -5450,6 +5700,13 @@ Requests</title>
  Temple Place - Suite 330, Boston, MA  02111-1307, USA.
 
  $Log: user-manual.sgml,v $
+ Revision 1.95  2002/04/26 17:23:29  swa
+ bookmarks cleaned, changed structure of user manual, screen and programlisting cleanups, and numerous other changes that I forgot
+
+ Revision 1.94  2002/04/26 05:24:36  hal9
+ -Add most of Andreas suggestions to Chain of Events section.
+ -A few other minor corrections and touch up.
+
  Revision 1.92  2002/04/25 18:55:13  hal9
  More catchups on new actions files, and new actions names.
  Other assorted cleanups, and minor modifications.