projects
/
rrq
/
hourglass.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
default installation values
[rrq/hourglass.git]
/
manager
/
basic_login.lsp
diff --git
a/manager/basic_login.lsp
b/manager/basic_login.lsp
index 14117d45eb3856dfa90346aa0d34a90cccd349ff..c4488d37936be306457b5baebc1e738728f16763 100644
(file)
--- a/
manager/basic_login.lsp
+++ b/
manager/basic_login.lsp
@@
-5,10
+5,11
@@
;;
;; Its (main-args 0) has a final path component X.cgi that links to
;; this file as a packnl embedding that will use that X part of its
;;
;; Its (main-args 0) has a final path component X.cgi that links to
;; this file as a packnl embedding that will use that X part of its
-;; name to determine th actual script. That lookup will also use the
-;; "role base" as declared in "roles.txt"
+;; name to determine th actual script.
+;(write-line 2 (string (date-value) " " (main-args)))
(unless (ends-with (main-args 0) ".cgi")
(unless (ends-with (main-args 0) ".cgi")
+ (load "siteconfig.lsp")
(if (exists file? (list (main-args 1)
(string (main-args 1) ".lsp")))
(load $it)
(if (exists file? (list (main-args 1)
(string (main-args 1) ".lsp")))
(load $it)
@@
-18,28
+19,36
@@
;; This script is executed in (protected) subdirectory www
(change-dir "..")
;; This script is executed in (protected) subdirectory www
(change-dir "..")
+(load "siteconfig.lsp")
+
;; Needs an HTTP_AUTHORIZATION environment variable
;; Needs an HTTP_AUTHORIZATION environment variable
-(unless (setf AUTH (env "HTTP_AUTHORIZATION"))
- (write-line 2 (read-file "tmpl/unauthorized.http"))
+(when (empty? (setf AUTH (env "HTTP_AUTHORIZATION")))
+ ;(write-line 2 "needs auth")
+ (write-line 1 (read-file "tmpl/unauthorized.http"))
(exit 0))
(exit 0))
-;; Must find that value in .htpasswd
-(unless (ref (6 AUTH) (parse (read-file ".htpasswd") "\n"))
+;; Must find that value in wui.passwd
+(constant 'PASSWD SITE:wui.passwd)
+(unless (ref (6 AUTH) (parse (read-file PASSWD) "\n"))
(write-line 1 (read-file "tmpl/unauthorized.http"))
(exit 0))
(write-line 1 (read-file "tmpl/unauthorized.http"))
(exit 0))
+;; Determine actual script name respecting given role, if any.
+(define (role-script (ROLE "."))
+ (let ((CMD (and (regex "([^/]*).cgi$" (main-args 0) 0) $1)))
+ (if (= "." ROLE) (string CMD ".lsp") (format "%s/%s.lsp" ROLE CMD))))
+
(setf
(setf
- ROLES (map (fn (x) (parse x ":")) (parse (read-file "roles.txt") "\n"))
REMOTE_USER (and (regex "([^:]+):" (base64-dec (6 AUTH)) 0) $1)
REMOTE_USER (and (regex "([^:]+):" (base64-dec (6 AUTH)) 0) $1)
- ROLE (or (lookup REMOTE_USER ROLSE) "child")
- SCRIPT (format "%s/%s" ROLE (main-args 1))
+ SCRIPT (role-script)
)
(env "REMOTE_USER" REMOTE_USER)
)
(env "REMOTE_USER" REMOTE_USER)
-(env "ROLE" ROLE)
+
;
(env "ROLE" ROLE)
(unless (file? SCRIPT)
(write 1 "\nBroken.\n")
(exit 0))
(unless (file? SCRIPT)
(write 1 "\nBroken.\n")
(exit 0))
+;(write-line 2 (string (list "script" SCRIPT)))
(load SCRIPT)
(exit 0)
(load SCRIPT)
(exit 0)