1. Richo Healey
  2. ident.so


ident.so / main.scm

#!/usr/bin/env csi -ss

(use srfi-13)
(use srfi-18)
(use tcp)
; (require-extension intarweb)
(require "lib/response")
(require "lib/request")

(define ident-so-port
  (get-environment-variable "PORT"))

(define threaded?
  (if (get-environment-variable "IDENT_THREADED")

(define real-handle
  (lambda (in out)
    ; We're lazy- we can find out everything about the request that we care
    ; about from it's first line
    (let ((line (read-line in)))
      (if (not (equal? line #!eof))
        (let* ((request (make-request line))
               (response (make-response))
               (request-path (get-request-path request)))
        (cond ((string=? request-path "/")
             (set-response-header "Content-Type" "text/html"
             (set-response-body "<html><body><b>Got root?</b></body></html>" response)))
            ((string=? request-path "/rawr")
             (set-response-body "got rawr?" response))
             (set-response-body "No such page mang" response))
      (close-input-port in)
      (close-output-port out))))

(define handle
  (if threaded?
    (lambda (in out) (thread-start! (make-thread (lambda () (real-handle in out)))))))

(define main
  (lambda (argv)
    (letrec ((sock (tcp-listen (string->number (get-environment-variable "PORT"))))
      (mainloop (lambda ()
        (let-values (((s-in s-out) (tcp-accept sock)))
          (handle s-in s-out)