* let ftpd generate more useful output on error conditions

* include format-net package in ftpd package
This commit is contained in:
interp 2001-11-13 13:50:24 +00:00
parent 70306ad10e
commit a76848a6c6
3 changed files with 34 additions and 51 deletions

View File

@ -9,15 +9,15 @@
(define (format-internet-host-address address . maybe-separator) (define (format-internet-host-address address . maybe-separator)
(define (extract shift) (let ((extract (lambda (shift)
(number->string (number->string
(bitwise-and (arithmetic-shift address (- shift)) (bitwise-and (arithmetic-shift address (- shift))
255))) 255)))))
(let-optionals maybe-separator ((separator ".")) (let-optionals maybe-separator ((separator "."))
(string-append (string-append
(extract 24) separator (extract 16) separator (extract 24) separator (extract 16) separator
(extract 8) separator (extract 0)))) (extract 8) separator (extract 0)))))
;; does pretty-print of ports ;; does pretty-print of ports
;; Example: ;; Example:

View File

@ -228,8 +228,9 @@
(with-handler (with-handler
(lambda (condition more) (lambda (condition more)
(log (syslog-level debug) (log (syslog-level debug)
"hit error condition ~A -- exiting" "hit error condition ~A (maybe reason (maybe Netscape?): ~S) -- exiting"
(condition-type condition)) (condition-type condition)
(condition-stuff condition))
(display condition (current-error-port)) (display condition (current-error-port))
(escape 'fick-dich-ins-knie)) (escape 'fick-dich-ins-knie))
(lambda () (lambda ()
@ -317,18 +318,18 @@
(lambda (condition more) (lambda (condition more)
(cond (cond
((error? condition) ((error? condition)
(let ((reason (condition-stuff condition)))
(log (syslog-level notice) (log (syslog-level notice)
"internal error occured: ~S -- replying and escaping (451)" "internal error occured: ~S (maybe reason: ~S) -- replying and escaping (451)"
condition) condition reason)
(register-reply! 451 (register-reply! 451
(format #f "Internal error: ~S" (format #f "Internal error: ~S" reason))
(condition-stuff condition))) (escape 'fick-dich-ins-knie)))
(escape 'fick-dich-ins-knie))
((ftpd-error? condition) ((ftpd-error? condition)
; debug level because nearly every unsuccessful command ends ; debug level because nearly every unsuccessful command ends
; here (no args, can't change dir, etc.) ; here (no args, can't change dir, etc.)
(log (syslog-level debug) (log (syslog-level debug)
"ftpd error occured -- escaping") "ftpd error occured (maybe reason: ~S)-- escaping" (condition-stuff condition))
(escape 'fick-dich-ins-knie)) (escape 'fick-dich-ins-knie))
(else (else
(more)))) (more))))
@ -781,24 +782,6 @@
(lambda (host-address control-port) (lambda (host-address control-port)
host-address))) host-address)))
(define (format-internet-host-address address . maybe-separator)
(define (extract shift)
(number->string
(bitwise-and (arithmetic-shift address (- shift))
255)))
(let ((separator (optional maybe-separator ".")))
(string-append
(extract 24) separator (extract 16) separator
(extract 8) separator (extract 0))))
(define (format-port port)
(string-append
(number->string (bitwise-and (arithmetic-shift port -8) 255))
","
(number->string (bitwise-and port 255))))
(define (handle-nlst arg) (define (handle-nlst arg)
(log-command (syslog-level info) "NLST" arg) (log-command (syslog-level info) "NLST" arg)
(handle-listing arg '())) (handle-listing arg '()))
@ -887,11 +870,12 @@
path)))) path))))
(with-fatal-error-handler* ; CALL-WITH-INPUT-FILE doesn't go through ERRNO (with-fatal-error-handler* ; CALL-WITH-INPUT-FILE doesn't go through ERRNO
(lambda (condition more) (lambda (condition more)
(log (syslog-level info) "failed to open ~S for reading (550)" full-path) (let ((reason (condition-stuff condition)))
(log (syslog-level debug) "reporting about ~S" path) (log (syslog-level info) "failed to open ~S for reading (maybe reason: ~S) (550)" full-path reason)
(log (syslog-level debug) "replying error for file ~S (maybe reason: ~S)" path reason)
(signal-error! 550 (signal-error! 550
(format #f "Can't open \"~A\" for reading." (format #f "Can't open \"~A\" for reading."
path))) path))))
(lambda () (lambda ()
(let ((info (file-info full-path))) (let ((info (file-info full-path)))
(if (not (eq? 'regular (file-info:type info))) (if (not (eq? 'regular (file-info:type info)))
@ -931,11 +915,10 @@
path)))) path))))
(with-fatal-error-handler* (with-fatal-error-handler*
(lambda (condition more) (lambda (condition more)
(log (syslog-level info) "can't open ~S for writing (550)" full-path) (let ((reason (condition-stuff condition)))
(log (syslog-level debug) "replying error for file ~S" path) (log (syslog-level info) "can't open ~S for writing (maybe reason: ~S) (550)" full-path reason)
(signal-error! 550 (log (syslog-level debug) "replying error for file ~S (maybe reason: ~S)" path reason)
(format #f "Can't open \"~A\" for writing." (signal-error! 550 (format #f "Can't open \"~A\" for writing." path))))
path)))
(lambda () (lambda ()
(call-with-output-file full-path (call-with-output-file full-path
(lambda (file-port) (lambda (file-port)
@ -1144,7 +1127,7 @@
; Version ; Version
(define *ftpd-version* "$Revision: 1.25 $") (define *ftpd-version* "$Revision: 1.26 $")
(define (copy-port->port-binary input-port output-port) (define (copy-port->port-binary input-port output-port)
(let ((buffer (make-string *window-size*))) (let ((buffer (make-string *window-size*)))

View File

@ -479,7 +479,6 @@
scsh) scsh)
(files ls)) (files ls))
(define-interface ftpd-interface (define-interface ftpd-interface
(export ftpd (export ftpd
ftpd-inetd)) ftpd-inetd))
@ -495,7 +494,8 @@
string-lib string-lib
big-util big-util
defrec-package defrec-package
crlf-io strings ls) crlf-io strings ls
format-net) ; pretty print of internet-addresses
(access big-scheme) (access big-scheme)
(files ftpd)) (files ftpd))