File: session1.lisp

package info (click to toggle)
kpax 20061019-2
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 848 kB
  • ctags: 1,007
  • sloc: lisp: 7,343; makefile: 93
file content (55 lines) | stat: -rw-r--r-- 2,162 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
;;;; -*- mode: lisp -*-
;;;;
;;;; $Id: session1.lisp,v 1.11 2004/09/17 08:08:48 sven Exp $
;;;;
;;;; A basic web application that tests session tracking
;;;;
;;;; Copyright (C) 2004 Sven Van Caekenberghe, Beta Nine BVBA. All Rights Reserved.
;;;;
;;;; You are granted the rights to distribute and use this software
;;;; as governed by the terms of the Lisp Lesser GNU Public License
;;;; (http://opensource.franz.com/preamble.html), also known as the LLGPL.
;;;;

(in-package :kpax-user)

(defwebapp :session1
  (:index 'session1-start)
  (:static-root "static/")
  (:unsecure t))

(defun session1-start (request-response)
  (html-page (out request-response)
    (:html 
     (:head 
      (:title "Session1!")
      (:link :rel "stylesheet" :type "text/css" :href (static-url request-response :server "nx.css")))
     (let ((session (get-session request-response)))
       (htm
        (:body 
         (:div :class "NX_panel"
          (:span :class "NX_title" "Session1!")
          (:div :class "NX_border"
           (:p 
            (fmt "Current session id is ~36R [~:*~d]" (get-session-id session)))
           (:p 
            "Session created " 
            (s-utils:format-universal-time (get-created-timestamp session) :stream out))
           (:p 
            "Session last modified " 
            (s-utils:format-universal-time (get-last-modified-timestamp session) :stream out))
           (let ((age (- (get-universal-time) (get-created-timestamp session))))
             (unless (zerop age)
               (htm
                (:p 
                 "Session has been alive for " 
                 (s-utils:format-duration (- (get-universal-time) (get-created-timestamp session)) :stream out)))))
           (let ((hit-counter-value (or (get-attribute session :counter) 0)))
             (incf hit-counter-value)
             (setf (get-attribute session :counter) hit-counter-value)
             (htm 
              (:p (fmt "This page has been hit ~d time~:p in this session" hit-counter-value))))
           (:div :class "NX_button_group"
            (:a :class "NX_button" :href (dynamic-url request-response nil) "Reload"))))))))))

;;;; eof