1 # static_agent.tcl --
2 #
3 # FIXME: This file needs a description here.
4 #
5 # Copyright (c) 1998-2002 The Regents of the University of California.
6 # All rights reserved.
7 #
8 # Redistribution and use in source and binary forms, with or without
9 # modification, are permitted provided that the following conditions are met:
10 #
11 # A. Redistributions of source code must retain the above copyright notice,
12 # this list of conditions and the following disclaimer.
13 # B. Redistributions in binary form must reproduce the above copyright notice,
14 # this list of conditions and the following disclaimer in the documentation
15 # and/or other materials provided with the distribution.
16 # C. Neither the names of the copyright holders nor the names of its
17 # contributors may be used to endorse or promote products derived from this
18 # software without specific prior written permission.
19 #
20 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS''
21 # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23 # ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR
24 # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25 # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
26 # SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
27 # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
28 # OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 #
31 # @(#) $Header: /usr/mash/src/repository/mash/mash-1/tcl/applications/pathfinder/static_agent.tcl,v 1.8 2002/02/03 04:22:06 lim Exp $
32
33
34 import HTTP_Agent
35
36 #
37 # The HTTP_Agent/Static class is an HTTP-aware agent that can be
38 # used to disseminate static pages
39 #
40 Class HTTP_Agent/Static -superclass HTTP_Agent
41
42 HTTP_Agent/Static public init { } {
43 $self next
44 $self instvar html_dir_ content_types_
45
46 # Initialize the html directory.
47 #set html_dir_ ~/mash/tcl/applications/mash_server/html/
48 set html_dir_ [$self get_option html_dir]
49
50 # setup the extension to content-type mappings
51 set content_types_(.html) text/html
52 set content_types_(.htm) text/html
53 set content_types_(.gif) image/gif
54 set content_types_(.jpg) image/jpeg
55 set content_types_(.jpeg) image/jpeg
56 set content_types_(.mash) x-mash/x-script
57 set content_types_(.tcl) application/x-tcl
58 }
59
60
61 #
62 # The handle_request method is called by the MASH_Server when an
63 # HTTP request is received. This method checks for the existence
64 # of URLs in the HTML directory and returns the corresponding page.
65 #
66 HTTP_Agent/Static public handle_request { url key source reply_var } {
67 upvar $reply_var reply
68 $self instvar html_dir_ content_types_
69 mtrace trcNet "-> HTTP_Agent/Static::handle_request called"
70
71 if { [string index $url 0] == "/" } {
72 set url [string range $url 1 end]
73 }
74 if {[string index $url 0] == "/" && [string range $url 0 1] != ".."} {
75 # check this to ensure that we do not inadvertently give
76 # access to our full filesystem thru this URL
77 return 0
78 }
79
80 set filename [file join $html_dir_ $url]
81 if [catch {set fd [open $filename]}] { return 0 }
82 if [catch {fconfigure $fd -translation binary}] { return 0 }
83 if [catch {set reply(data) [read $fd] }] {
84 catch {close $fd}
85 return 0
86 }
87 catch {close $fd}
88
89 set ext [string tolower [file extension $filename]]
90 if [info exists content_types_($ext)] {
91 set reply(headers) [list content-type $content_types_($ext)]
92 } else {
93 set reply(headers) [list content-type text/plain]
94 }
95
96 set reply(status) 200
97 return 1
98 }
99
100
This page was automatically generated by the
LXR engine.
Visit the LXR main site for more
information.