#include CSS to be prepared for the send-stylesheet
[privoxy.git] / templates / blocked
1 ##########################################################
2 #
3 # "Blocked" Error Output template for Privoxy.
4 #
5 #  NOTE: UNLIKE THE OTHER TEMPLATES, THIS ONE USES
6 #  JavaScript write() TO GENERATE THE PAGE IN JS_AWARE
7 #  BROWSERS. SYMBOL SUBSTITUTIONS THAT RESULT IN MULTILINE
8 #  STRINGS WILL BREAK THE JavaScript SYNTAX.
9 #  USE WITH CAUTION.
10 #
11 # USING HTML TEMPLATES:
12 # ---------------------
13 #
14 # Template files are written in plain HTML, with a few
15 # additions:
16
17 # - Lines that start with a '#' character like this one
18 #   are ignored
19 #
20 # - Each item in the below list of exported symbols will
21 #   be replaced by dynamically generated text, if they
22 #   are enclosed in '@'-characters. E.g. The string @version@
23 #   will be replaced by the version number of Privoxy.
24 #
25 # - One special application of this is to make whole blocks
26 #   of the HTML template disappear if the condition <name>
27 #   is not given. Simply enclose the block between the two
28 #   strings @if-<name>start and if-<name>-end@. The strings
29 #   should be placed in HTML comments (<!-- -->), so the
30 #   html structure won't be messed when the magic happens.
31 #   
32 # USABLE SYMBOLS IN THIS TEMPLATE:
33 # --------------------------------
34 #
35 #  my-ip-addr:
36 #    The IP-address that the client used to reach this proxy
37 #  my-hostname:
38 #    The hostname associated with my-ip-addr
39 #  admin-address:
40 #    The email address of the pxoxy's administrator, as configured
41 #    in the config file
42 #  default-cgi:
43 #    The URL for the "main menu" builtin CGI of this proxy
44 #  menu:
45 #    List of <li> elements linking to the other available CGIs
46 #  version:
47 #    The version number of the proxy software
48 #  code-status:
49 #    The development status of the proxy software: "alpha", "beta",
50 #    or "stable".
51 #  homepage:
52 #    The URL of the SourceForge ijbswa project, who maintains this
53 #    software.
54 #
55 #  protocol:
56 #    The request's protocol: http:// or https://
57 #  hostport:
58 #    The host and port part of the blocked request's URL.
59 #  path:
60 #    The path part of the blocked request's URL.
61 #  path-ue:
62 #    The path part of the blocked request's URL, url-encoded.
63 #
64 #
65 # CONDITIONAL SYMBOLS FOR THIS TEMPLATE AND THEIR DEPANDANT SYMBOLS:
66 # ------------------------------------------------------------------
67 #
68 #  unstable:
69 #    This is an alpha or beta release of the proxy software
70 #  have-adminaddr-info:
71 #    An e-mail address for the local Privoxy adminstrator has
72 #    been specified and is available through the "admin-address"
73 #    symbol
74 #  have-proxy-info:
75 #    A URL for online documentation about this proxy has been
76 #    specified and is available through the "proxy-info-url"
77 #    symbol
78 #  have-help-info:
79 #    If either have-proxy-info is true or have-adminaddr-info is
80 #    true, have-help-info is true.  Used to conditionally include
81 #    a grey box for any and all help info.
82 #  force-support:
83 #    Privoxy has been compiled with support for forced loading
84 #    of blocked content. In that case, the symbol "force-prefix" is
85 #    avaiable, which translates to the FORCE_PREFIX  
86 #
87 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
88 <html>
89  <head>
90   <title>Request blocked (Privoxy@@my-hostname@)</title>
91   <meta http-equiv="Content-Style-Type" content="text/css">
92   <meta http-equiv="Content-Script-Type" content="text/javascript">
93   <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
94   <meta name="robots" content="noindex,nofollow">
95   <style type="text/css">
96 #include cgi-style.css
97   </style>
98   <script type="text/javascript" language="javascript">
99   <!--
100     /*
101      * Is this window or frame too small
102      * for the full-blown "blocked" page?
103      */
104     function isSmallFrame()
105     {
106        minWidth  = 650;
107        minHeight = 330;
108
109        /* 
110         * Navigator, Mozilla, Opera
111         */
112        if (window.innerWidth 
113            && (window.innerWidth >= minWidth) 
114            && (window.innerHeight >= minHeight))
115        {
116           return false;
117        }
118  
119        /* 
120         * MSIE
121         */
122        else if (document.body && document.body.clientWidth 
123                 && (document.body.clientWidth >= minWidth)
124                 && (document.body.clientHeight >= minHeight))
125        {
126           return false;
127        }
128
129        /*
130         * Small window or unsupported browser
131         */
132        return true;
133    }
134   //-->
135   </script>
136  </head>
137  <body>
138   <script type="text/javascript" language="javascript">
139   <!--
140 #   Note: The same small version is used at the bottom
141 #         of this file in the <noscript> context. If you
142 #         make changes here, keep the other version in sync!
143
144   if (isSmallFrame())
145   {
146      document.write('\
147    <p class="small" align="center"> \
148     <a href="@default-cgi@" target="_blank">Privoxy</a> blocked <b>@protocol@@hostport@@path@</b>. \
149     <br><a href="@default-cgi@show-url-info?url=@hostport@@path-ue@" target="_blank">See why</a> \
150     <!-- @if-force-support-start --> \
151     or <a href="http://@hostport@@force-prefix@@path@">go there anyway</a>. \
152     <!-- if-force-support-end@ --> \
153    </p> \
154    ');
155
156   }
157   else
158   {
159      document.write('\
160   <table cellpadding="20" cellspacing="10" border="0" width="100%">\
161     <tr> \
162       <td class="status"> \
163         BLOCKED \
164       </td> \
165       <td class="title" width=100%> \
166          <h1> \
167           This is <a href="@homepage@">Privoxy</a> @version@ on @my-hostname@ (@my-ip-address@), port @my-port@, \
168           @if-enabled-display-then@enabled@else-not-enabled-display@disabled@endif-enabled-display@ \
169         </h1> \
170       </td> \
171     </tr> \
172  \
173 <!-- @if-unstable-start --> \
174 # This will only appear if CODE_STATUS is "alpha" or "beta". See configure.in \
175     <tr> \
176       <td class="warning" colspan="2"> \
177         <h2>Warning:</h2> \
178         <p> \
179           <b>Please note that this <font color=red>@code-status@</font> release \
180           of the proxy software is not intended for production systems! \
181           <br>Use at your own risk. See the <a href="http://www.gnu.org/copyleft/gpl.html">license</a> for details.</b> \
182         </p> \
183       </td> \
184     </tr> \
185 <!-- if-unstable-end@ --> \
186  \
187     <tr> \
188       <td class="box" colspan="2"> \
189         <h2>Request for blocked URL</h2> \
190         <p>Your request for <b>@protocol@@hostport@@path@</b> was blocked. \
191           <br><a href="@default-cgi@show-url-info?url=@hostport@@path-ue@">See why</a> \
192     <!-- @if-force-support-start --> \
193           or <a href="http://@hostport@@force-prefix@@path@">go there anyway</a>. \
194 <!-- if-force-support-end@ --> \
195         </p> \
196       </td> \
197     </tr> \
198  \
199     <tr> \
200       <td class="box" colspan="2"> \
201         <h2>More Privoxy:</h2> \
202         <ul>@menu@<li><a href="@user-manual@">Documentation</a></li></ul> \
203       </td> \
204     </tr> \
205  \
206     <tr> \
207       <td class="info" colspan="2"> \
208         <big><b>Support and Service via Sourceforge:</b></big> \
209         <p> \
210           We value your feedback. To provide you with the best support, \
211           we ask that you: \
212         </p> \
213         <ul> \
214           <li> \
215             use the <a href="http://sourceforge.net/tracker/?group_id=11118&amp;atid=211118">support forum</a> or (better) the \
216             <a href="http://sourceforge.net/mail/?group_id=11118">mailing lists</a> to get help. \
217           </li> \
218           <li> \
219             submit banners and all problems with the actions file only through the \
220             <a href="javascript:void(window.open(\'http://www.privoxy.org/actions\',\'Feedback\',\'width=600,scrollbars=yes,toolbar=no,location=no,directories=no,status=no,menubar=no,copyhistory=no\').focus());">actions \
221             file feedback system</a>. \
222           </li> \
223           <li> \
224             submit bugs only through our <a href="http://sourceforge.net/tracker/?group_id=11118&amp;atid=111118">bug tracker</a>. \
225             Make sure that the bug has not yet been submitted. \
226           </li> \
227           <li> \
228             submit feature requests only through our <a href="http://sourceforge.net/tracker/?atid=361118&amp;group_id=11118&amp;func=browse">feature \
229             request tracker</a>. \
230           </li> \
231         </ul> \
232       </td> \
233     </tr> \
234  \
235 <!-- @if-have-help-info-start --> \
236     <tr> \
237       <td class="info" colspan="2"> \
238         <h2>Local Privoxy support:</h2> \
239  \
240 <!-- @if-have-proxy-info-start --> \
241         <p>You can consult the <a href="@proxy-info-url@">online documentation</a> for more information about this Privoxy installation.</p> \
242 <!-- if-have-proxy-info-end@ --> \
243  \
244 <!-- @if-have-adminaddr-info-start --> \
245         <p>Address e-mail questions about this service to \
246           <a href="mailto:@admin-address@"><code>@admin-address@</code></a>, \
247           who will be glad to help you. \
248         </p> \
249 <!-- if-have-adminaddr-info-end@ --> \
250       </td> \
251     </tr> \
252 <!-- if-have-help-info-end@ --> \
253  \
254   </table> \
255      ');
256   }
257   //-->
258   </script>
259
260 #   Note: The same small version is used above via JavaScript
261 #         If you make changes here, keep the other version in sync!
262
263   <noscript>
264    <p class="small" align="center">
265     <a href="@default-cgi@" target="_blank">Privoxy</a> blocked <b>@protocol@@hostport@@path@</b>.
266     <br><a href="@default-cgi@show-url-info?url=@hostport@@path-ue@" target="_blank">See why</a>
267     <!-- @if-force-support-start -->
268     or <a href="http://@hostport@@force-prefix@@path@">go there anyway</a>.
269     <!-- if-force-support-end@ -->
270    </p>
271   </noscript>
272
273  </body>
274 </html>