- (let ((dest (assoc (message-to msg) (get-to-addresses config))))
- (if dest
- (let ((dest-file (cdr dest)))
- (if (directory-exists? dest-file)
- (deliver-message-local msg dest-file))
- (print "Message DELIVERED:"))
- (print "Message REJECTED:"))
- (print " * From: " (message-from msg))
- (print " * To: " (message-to msg)))
+ (let* ((local-addresses (get-local-addresses config))
+ (dest (assoc (message-to msg) local-addresses))
+ (orig (assoc (message-from msg) local-addresses)))
+ (cond
+ (dest
+ (let ((dest-dir (cadr dest)))
+ (deliver-message-local msg dest-file))
+ (print "Message DELIVERED (local):"))
+ (orig
+ (let ((password (caddr orig)))
+ (if (and
+ (string=? (conc "<" (message-user msg) "@" (config-host config) ">")
+ (message-from msg))
+ password
+ (string=? (message-password msg) password))
+ (begin
+ (deliver-message-remote msg)
+ (print "Message DELIVERED (remote):"))
+ (print "Message DELIVERY REJECTED (auth failure):"))))
+ (else
+ (print "Message DELIVERY REJECTED (relay forbidden):"))))
+ (print " * From: " (message-from msg))
+ (print " * To: " (message-to msg))