forked from cadence/breezewiki
		
	More powerful static file handling
This commit is contained in:
		
							parent
							
								
									50d944fb11
								
							
						
					
					
						commit
						fb00a2e443
					
				
					 5 changed files with 78 additions and 53 deletions
				
			
		| 
						 | 
					@ -1,17 +1,11 @@
 | 
				
			||||||
#lang racket/base
 | 
					#lang racket/base
 | 
				
			||||||
(require racket/path
 | 
					(require web-server/servlet-dispatch
 | 
				
			||||||
         racket/runtime-path
 | 
					 | 
				
			||||||
         net/url
 | 
					 | 
				
			||||||
         web-server/servlet-dispatch
 | 
					 | 
				
			||||||
         web-server/dispatchers/filesystem-map
 | 
					 | 
				
			||||||
         (prefix-in pathprocedure: web-server/dispatchers/dispatch-pathprocedure)
 | 
					         (prefix-in pathprocedure: web-server/dispatchers/dispatch-pathprocedure)
 | 
				
			||||||
         (prefix-in sequencer: web-server/dispatchers/dispatch-sequencer)
 | 
					         (prefix-in sequencer: web-server/dispatchers/dispatch-sequencer)
 | 
				
			||||||
         (prefix-in lift: web-server/dispatchers/dispatch-lift)
 | 
					         (prefix-in lift: web-server/dispatchers/dispatch-lift)
 | 
				
			||||||
         (prefix-in filter: web-server/dispatchers/dispatch-filter)
 | 
					         (prefix-in filter: web-server/dispatchers/dispatch-filter)
 | 
				
			||||||
         (prefix-in files: web-server/dispatchers/dispatch-files)
 | 
					 | 
				
			||||||
         "src/config.rkt"
 | 
					         "src/config.rkt"
 | 
				
			||||||
         "src/reloadable.rkt"
 | 
					         "src/reloadable.rkt")
 | 
				
			||||||
         "src/server-utils.rkt")
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
(define-syntax-rule (require-reloadable filename varname)
 | 
					(define-syntax-rule (require-reloadable filename varname)
 | 
				
			||||||
  (define varname
 | 
					  (define varname
 | 
				
			||||||
| 
						 | 
					@ -23,14 +17,13 @@
 | 
				
			||||||
(require-reloadable "src/page-not-found.rkt" page-not-found)
 | 
					(require-reloadable "src/page-not-found.rkt" page-not-found)
 | 
				
			||||||
(require-reloadable "src/page-proxy.rkt" page-proxy)
 | 
					(require-reloadable "src/page-proxy.rkt" page-proxy)
 | 
				
			||||||
(require-reloadable "src/page-search.rkt" page-search)
 | 
					(require-reloadable "src/page-search.rkt" page-search)
 | 
				
			||||||
 | 
					(require-reloadable "src/page-static.rkt" static-dispatcher)
 | 
				
			||||||
(require-reloadable "src/page-wiki.rkt" page-wiki)
 | 
					(require-reloadable "src/page-wiki.rkt" page-wiki)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
(when (not (config-true? 'debug))
 | 
					(when (not (config-true? 'debug))
 | 
				
			||||||
  (set-reload-poll-interval! #f))
 | 
					  (set-reload-poll-interval! #f))
 | 
				
			||||||
(reload!)
 | 
					(reload!)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
(define-runtime-path path-static "static")
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
(serve/launch/wait
 | 
					(serve/launch/wait
 | 
				
			||||||
 #:listen-ip (if (config-true? 'debug) "127.0.0.1" #f)
 | 
					 #:listen-ip (if (config-true? 'debug) "127.0.0.1" #f)
 | 
				
			||||||
 #:port (string->number (config-get 'port))
 | 
					 #:port (string->number (config-get 'port))
 | 
				
			||||||
| 
						 | 
					@ -41,13 +34,5 @@
 | 
				
			||||||
    (filter:make #rx"^/[a-z-]+/wiki/Category:.+$" (lift:make page-category))
 | 
					    (filter:make #rx"^/[a-z-]+/wiki/Category:.+$" (lift:make page-category))
 | 
				
			||||||
    (filter:make #rx"^/[a-z-]+/wiki/.+$" (lift:make page-wiki))
 | 
					    (filter:make #rx"^/[a-z-]+/wiki/.+$" (lift:make page-wiki))
 | 
				
			||||||
    (filter:make #rx"^/[a-z-]+/search$" (lift:make page-search))
 | 
					    (filter:make #rx"^/[a-z-]+/search$" (lift:make page-search))
 | 
				
			||||||
    (filter:make #rx"^/static/" (files:make
 | 
					    static-dispatcher
 | 
				
			||||||
                                 #:url->path
 | 
					 | 
				
			||||||
                                 (lambda (u)
 | 
					 | 
				
			||||||
                                   ((make-url->path path-static)
 | 
					 | 
				
			||||||
                                    (struct-copy url u [path (cdr (url-path u))])))
 | 
					 | 
				
			||||||
                                 #:path->mime-type
 | 
					 | 
				
			||||||
                                 (lambda (u)
 | 
					 | 
				
			||||||
                                   (ext->mime-type (path-get-extension u)))
 | 
					 | 
				
			||||||
                                 #:cache-no-cache (config-true? 'debug) #;"browser applies heuristics if unset"))
 | 
					 | 
				
			||||||
    (lift:make page-not-found))))
 | 
					    (lift:make page-not-found))))
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										22
									
								
								dist.rkt
									
										
									
									
									
								
							
							
						
						
									
										22
									
								
								dist.rkt
									
										
									
									
									
								
							| 
						 | 
					@ -1,26 +1,20 @@
 | 
				
			||||||
#lang racket/base
 | 
					#lang racket/base
 | 
				
			||||||
(require racket/path
 | 
					(require web-server/servlet-dispatch
 | 
				
			||||||
         racket/runtime-path
 | 
					 | 
				
			||||||
         net/url
 | 
					 | 
				
			||||||
         web-server/servlet-dispatch
 | 
					 | 
				
			||||||
         web-server/dispatchers/filesystem-map
 | 
					 | 
				
			||||||
         (prefix-in pathprocedure: web-server/dispatchers/dispatch-pathprocedure)
 | 
					         (prefix-in pathprocedure: web-server/dispatchers/dispatch-pathprocedure)
 | 
				
			||||||
         (prefix-in sequencer: web-server/dispatchers/dispatch-sequencer)
 | 
					         (prefix-in sequencer: web-server/dispatchers/dispatch-sequencer)
 | 
				
			||||||
         (prefix-in lift: web-server/dispatchers/dispatch-lift)
 | 
					         (prefix-in lift: web-server/dispatchers/dispatch-lift)
 | 
				
			||||||
         (prefix-in filter: web-server/dispatchers/dispatch-filter)
 | 
					         (prefix-in filter: web-server/dispatchers/dispatch-filter)
 | 
				
			||||||
         (prefix-in files: web-server/dispatchers/dispatch-files)
 | 
					 | 
				
			||||||
         "src/config.rkt"
 | 
					         "src/config.rkt"
 | 
				
			||||||
         "src/server-utils.rkt")
 | 
					         "src/reloadable.rkt")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
(require (only-in "src/page-category.rkt" page-category))
 | 
					(require (only-in "src/page-category.rkt" page-category))
 | 
				
			||||||
(require (only-in "src/page-home.rkt" page-home))
 | 
					(require (only-in "src/page-home.rkt" page-home))
 | 
				
			||||||
(require (only-in "src/page-not-found.rkt" page-not-found))
 | 
					(require (only-in "src/page-not-found.rkt" page-not-found))
 | 
				
			||||||
(require (only-in "src/page-proxy.rkt" page-proxy))
 | 
					(require (only-in "src/page-proxy.rkt" page-proxy))
 | 
				
			||||||
(require (only-in "src/page-search.rkt" page-search))
 | 
					(require (only-in "src/page-search.rkt" page-search))
 | 
				
			||||||
 | 
					(require (only-in "src/page-static.rkt" static-dispatcher))
 | 
				
			||||||
(require (only-in "src/page-wiki.rkt" page-wiki))
 | 
					(require (only-in "src/page-wiki.rkt" page-wiki))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
(define-runtime-path path-static "static")
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
(serve/launch/wait
 | 
					(serve/launch/wait
 | 
				
			||||||
 #:listen-ip (if (config-true? 'debug) "127.0.0.1" #f)
 | 
					 #:listen-ip (if (config-true? 'debug) "127.0.0.1" #f)
 | 
				
			||||||
 #:port (string->number (config-get 'port))
 | 
					 #:port (string->number (config-get 'port))
 | 
				
			||||||
| 
						 | 
					@ -31,13 +25,5 @@
 | 
				
			||||||
    (filter:make #rx"^/[a-z-]+/wiki/Category:.+$" (lift:make page-category))
 | 
					    (filter:make #rx"^/[a-z-]+/wiki/Category:.+$" (lift:make page-category))
 | 
				
			||||||
    (filter:make #rx"^/[a-z-]+/wiki/.+$" (lift:make page-wiki))
 | 
					    (filter:make #rx"^/[a-z-]+/wiki/.+$" (lift:make page-wiki))
 | 
				
			||||||
    (filter:make #rx"^/[a-z-]+/search$" (lift:make page-search))
 | 
					    (filter:make #rx"^/[a-z-]+/search$" (lift:make page-search))
 | 
				
			||||||
    (filter:make #rx"^/static/" (files:make
 | 
					    static-dispatcher
 | 
				
			||||||
                                 #:url->path
 | 
					 | 
				
			||||||
                                 (lambda (u)
 | 
					 | 
				
			||||||
                                   ((make-url->path path-static)
 | 
					 | 
				
			||||||
                                    (struct-copy url u [path (cdr (url-path u))])))
 | 
					 | 
				
			||||||
                                 #:path->mime-type
 | 
					 | 
				
			||||||
                                 (lambda (u)
 | 
					 | 
				
			||||||
                                   (ext->mime-type (path-get-extension u)))
 | 
					 | 
				
			||||||
                                 #:cache-no-cache (config-true? 'debug) #;"browser applies heuristics if unset"))
 | 
					 | 
				
			||||||
    (lift:make page-not-found))))
 | 
					    (lift:make page-not-found))))
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -49,6 +49,7 @@
 | 
				
			||||||
        (printf "note: ~a items loaded from config file~n" (length l)))))))
 | 
					        (printf "note: ~a items loaded from config file~n" (length l)))))))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
(when (config-true? 'debug)
 | 
					(when (config-true? 'debug)
 | 
				
			||||||
 | 
					  ; all values here are optimised for maximum prettiness
 | 
				
			||||||
  (parameterize ([pretty-print-columns 80])
 | 
					  (parameterize ([pretty-print-columns 80])
 | 
				
			||||||
    (display "config: ")
 | 
					    (display "config: ")
 | 
				
			||||||
    (pretty-write (hash->list config))))
 | 
					    (pretty-write (hash->list config))))
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										69
									
								
								src/page-static.rkt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								src/page-static.rkt
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,69 @@
 | 
				
			||||||
 | 
					#lang racket/base
 | 
				
			||||||
 | 
					(require racket/path
 | 
				
			||||||
 | 
					         racket/runtime-path
 | 
				
			||||||
 | 
					         net/url
 | 
				
			||||||
 | 
					         web-server/http/request-structs
 | 
				
			||||||
 | 
					         web-server/servlet-dispatch
 | 
				
			||||||
 | 
					         web-server/dispatchers/filesystem-map
 | 
				
			||||||
 | 
					         (only-in web-server/dispatchers/dispatch next-dispatcher)
 | 
				
			||||||
 | 
					         (prefix-in files: web-server/dispatchers/dispatch-files)
 | 
				
			||||||
 | 
					         "config.rkt")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(provide
 | 
				
			||||||
 | 
					 static-dispatcher)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(module+ test
 | 
				
			||||||
 | 
					  (require rackunit))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(define-runtime-path path-static "../static")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(define hash-ext-mime-type
 | 
				
			||||||
 | 
					  (hash #".css" #"text/css"
 | 
				
			||||||
 | 
					        #".png" #"image/png"
 | 
				
			||||||
 | 
					        #".svg" #"image/svg+xml"
 | 
				
			||||||
 | 
					        #".txt" #"text/plain"))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(define (ext->mime-type ext)
 | 
				
			||||||
 | 
					  (hash-ref hash-ext-mime-type ext))
 | 
				
			||||||
 | 
					(module+ test
 | 
				
			||||||
 | 
					  (check-equal? (ext->mime-type #".png") #"image/png"))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(define (make-path segments)
 | 
				
			||||||
 | 
					  (map (λ (seg) (path/param seg '())) segments))
 | 
				
			||||||
 | 
					(module+ test
 | 
				
			||||||
 | 
					  (check-equal? (make-path '("static" "main.css"))
 | 
				
			||||||
 | 
					                (list (path/param "static" '()) (path/param "main.css" '()))))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(define (path-rewriter p)
 | 
				
			||||||
 | 
					  (cond
 | 
				
			||||||
 | 
					    ; url is ^/static/... ?
 | 
				
			||||||
 | 
					    [(equal? (path/param-path (car p)) "static")
 | 
				
			||||||
 | 
					     ; rewrite to ^/... which will be treated as relative to static/ on the filesystem
 | 
				
			||||||
 | 
					     (cdr p)]
 | 
				
			||||||
 | 
					    ; url is literally ^/robots.txt
 | 
				
			||||||
 | 
					    [(equal? p (make-path '("robots.txt")))
 | 
				
			||||||
 | 
					     ; rewrite to ^/... -- it already is!
 | 
				
			||||||
 | 
					     p]
 | 
				
			||||||
 | 
					    ; not going to use the static file dispatcher
 | 
				
			||||||
 | 
					    [#t (next-dispatcher)]))
 | 
				
			||||||
 | 
					(module+ test
 | 
				
			||||||
 | 
					  (check-equal? (path-rewriter (make-path '("static" "main.css")))
 | 
				
			||||||
 | 
					                (make-path '("main.css")))
 | 
				
			||||||
 | 
					  (check-equal? (path-rewriter (make-path '("static" "robots.txt")))
 | 
				
			||||||
 | 
					                (make-path '("robots.txt")))
 | 
				
			||||||
 | 
					  (check-equal? (path-rewriter (make-path '("robots.txt")))
 | 
				
			||||||
 | 
					                (make-path '("robots.txt"))))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(define (static-dispatcher conn old-req)
 | 
				
			||||||
 | 
					  (define old-uri (request-uri old-req))
 | 
				
			||||||
 | 
					  (define old-path (url-path old-uri))
 | 
				
			||||||
 | 
					  (define new-path (path-rewriter old-path))
 | 
				
			||||||
 | 
					  (define new-uri (struct-copy url old-uri [path new-path]))
 | 
				
			||||||
 | 
					  (define new-req (struct-copy request old-req [uri new-uri]))
 | 
				
			||||||
 | 
					  ((files:make
 | 
				
			||||||
 | 
					    #:url->path (lambda (u)
 | 
				
			||||||
 | 
					                  (println u)
 | 
				
			||||||
 | 
					                  ((make-url->path path-static) u))
 | 
				
			||||||
 | 
					    #:path->mime-type (lambda (u) (ext->mime-type (path-get-extension u)))
 | 
				
			||||||
 | 
					    #:cache-no-cache (config-true? 'debug) #;"browser applies heuristics if unset")
 | 
				
			||||||
 | 
					   conn new-req))
 | 
				
			||||||
| 
						 | 
					@ -1,16 +0,0 @@
 | 
				
			||||||
#lang racket/base
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
(provide
 | 
					 | 
				
			||||||
 ext->mime-type)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
(module+ test
 | 
					 | 
				
			||||||
  (require rackunit))
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
(define hash-ext-mime-type
 | 
					 | 
				
			||||||
  (hash #".css" #"text/css"
 | 
					 | 
				
			||||||
        #".svg" #"image/svg+xml"
 | 
					 | 
				
			||||||
        #".png" #"image/png"))
 | 
					 | 
				
			||||||
(define (ext->mime-type ext)
 | 
					 | 
				
			||||||
  (hash-ref hash-ext-mime-type ext))
 | 
					 | 
				
			||||||
(module+ test
 | 
					 | 
				
			||||||
  (check-equal? (ext->mime-type #".png") #"image/png"))
 | 
					 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue