Skip to content

Instantly share code, notes, and snippets.

@pmn pmn/gist:1164308
Created Aug 23, 2011

What would you like to do?
peeranoia source
(ns peeranoia.core
(:use [compojure.core :only [defroutes GET]]
[hiccup.core :only [escape-html html]]
[ :only [include-css include-js html5]]
[ring.adapter.jetty :only [run-jetty]]
[ring.middleware.cookies :only [wrap-cookies]])
(:require [compojure.route :as route]
[compojure.handler :as handler]))
(defn- render-page
[{:keys [visits referer ip user-agent headers]}]
[:title "peeranoia"]
(include-css "/css/site.css")]
[:h2 "peeranoia"]
[:div.infoblock "Your IP is: "
[:span ip]]
[:div.infoblock "Your User-Agent is: "
[:span user-agent]]
[:div.infoblock "Your cookies report that you have been here: "
[:span (str visits " times")]]
(when-not (nil? referer)
[:div.infoblock "You were referred here by: "
[:span referer]])
[:div.infoblock "Full headers: "
[:span (escape-html headers)]]]
(include-js "/js/g.js")]))
(defn- add-visit
(if-not (nil? visitcount)
(-> visitcount Integer/parseInt inc str)
(defn home-page
(let [header-info {:visits (add-visit (:value (get (:cookies r) "value")))
:referer (get (:headers r) "referer")
:ip (get (:headers r) "x-real-ip")
:user-agent (get (:headers r) "user-agent")
:headers (:headers r)}]
{:cookies {:value (:visits header-info),
:path "/",
:domain "" }
(render-page header-info)})))
(defroutes main-routes
(GET "/" [:as r] (home-page r))
(route/resources "/")
(route/not-found "404 - not found"))
(def app
(-> (handler/site main-routes)
(defn -main []
(let [port (Integer/parseInt (get (System/getenv) "PORT" "8080"))]
(run-jetty app {:port port})))
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
You can’t perform that action at this time.