~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~ [ freetext search ] ~ [ file search ] ~

Open Mash Cross Reference
mash/tcl/applications/pathfinder/static_agent.tcl

Component: ~ [ mash ] ~ [ apps ] ~ [ gsm ] ~ [ lib ] ~ [ otcl ] ~ [ srm ] ~ [ tcl8.3 ] ~ [ tclcl ] ~ [ tk8.3 ] ~ [ tutorials ] ~

  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 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~ [ freetext search ] ~ [ file search ] ~

This page was automatically generated by the LXR engine.
Visit the LXR main site for more information.