* let ftpd generate more useful output on error conditions
* include format-net package in ftpd package
This commit is contained in:
parent
70306ad10e
commit
a76848a6c6
|
@ -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:
|
||||||
|
|
53
ftpd.scm
53
ftpd.scm
|
@ -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*)))
|
||||||
|
|
|
@ -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))
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue