factor/contrib/httpd/file-responder.factor

64 lines
1.6 KiB
Factor
Raw Normal View History

! Copyright (C) 2004,2005 Slava Pestov.
! See http://factor.sf.net/license.txt for BSD license.
2004-07-16 02:26:21 -04:00
IN: file-responder
2006-05-25 00:06:50 -04:00
USING: cont-responder html httpd io kernel math namespaces
2006-01-31 22:43:29 -05:00
parser sequences strings ;
2004-07-16 02:26:21 -04:00
: serving-path ( filename -- filename )
[ "" ] unless* "doc-root" get swap append ;
2004-07-16 02:26:21 -04:00
: file-response ( mime-type length -- )
[
2006-01-17 10:47:15 -05:00
number>string "Content-Length" set
"Content-Type" set
] make-hash "200 OK" response terpri ;
: serve-static ( filename mime-type -- )
over file-length file-response "method" get "head" = [
drop
] [
<file-reader> stdio get stream-copy
2005-09-24 15:21:17 -04:00
] if ;
2004-07-16 02:26:21 -04:00
: serve-file ( filename -- )
dup mime-type dup "application/x-factor-server-page" = [
drop run-file
2004-07-16 02:26:21 -04:00
] [
serve-static
2005-09-24 15:21:17 -04:00
] if ;
2004-07-16 02:26:21 -04:00
2004-08-30 20:24:19 -04:00
: list-directory ( directory -- )
serving-html
"method" get "head" = [
drop
] [
"request" get [ dup log-message directory. ] simple-html-document
2005-09-24 15:21:17 -04:00
] if ;
2004-08-30 20:24:19 -04:00
: serve-directory ( filename -- )
dup "/" tail? [
dup "index.html" append dup exists? [
2005-06-18 21:15:07 -04:00
nip serve-file
] [
2004-08-30 20:24:19 -04:00
drop list-directory
2005-09-24 15:21:17 -04:00
] if
] [
2004-08-30 20:24:19 -04:00
drop directory-no/
2005-09-24 15:21:17 -04:00
] if ;
: serve-object ( filename -- )
2005-09-24 15:21:17 -04:00
dup directory? [ serve-directory ] [ serve-file ] if ;
2006-01-31 22:43:29 -05:00
: file-responder ( -- )
[
"doc-root" get [
"argument" get serving-path dup exists? [
serve-object
] [
drop "404 not found" httpd-error
] if
2004-07-16 02:26:21 -04:00
] [
2006-01-31 22:43:29 -05:00
"404 doc-root not set" httpd-error
2005-09-24 15:21:17 -04:00
] if
2006-01-31 22:43:29 -05:00
] (show-final) ;