r7061: initial property settings
[wol.git] / classes.lisp
1 ;;;; -*- Mode: Lisp; Syntax: ANSI-Common-Lisp; Base: 10; Package: wol -*-
2 ;;;; *************************************************************************
3 ;;;; FILE IDENTIFICATION
4 ;;;;
5 ;;;; Name:          classes.lisp
6 ;;;; Purpose:       Classes for Wol library
7 ;;;; Programmer:    Kevin M. Rosenberg
8 ;;;; Date Started:  July 2003
9 ;;;;
10 ;;;; $Id$
11 ;;;;
12 ;;;; This file and Wol are Copyright (c) 2001-2003 by Kevin M. Rosenberg
13 ;;;; *************************************************************************
14
15 (in-package #:wol)
16
17
18 (defclass session-master ()
19   ((lifetime :initarg lifetime :initform nil :accessor lifetime)
20    (cookie-name :initarg cookie-name :accessor cookie-name)
21    (counter :initform 0 :accessor counter)
22    (prefix :initform "/" :accessor prefix)
23    (sessions :initform nil :accessor sessions)))
24    
25
26 (defclass websession ()
27   ((key :initarg :key :accessor websession-key)
28    (lastref :initarg :lastref :accessor websession-lastref)
29    (lifetime :initarg :lifetime :initform nil
30              :accessor websession-lifetime)
31    (data :initform nil :accessor websession-data)
32    (method :initarg :method :accessor websession-method :initform nil)
33    (variables :initform (make-hash-table :test 'equal)
34               :accessor websession-variables)))
35    
36 (defclass wol-project ()
37   ((name :initarg :name :initform "" :type string :accessor project-name)
38    (project-prefix :initarg :project-prefix :type string
39                    :initform "/" :accessor project-prefix)
40    (map :initarg :map :initform nil :type list :accessor project-map)
41    (hash :initarg :hash :initform nil :accessor project-hash-map)
42    (index :initarg :index :initform "index" :type string 
43           :accessor project-index)
44    (server :initarg :server :initform nil :accessor project-server)
45    (session-master :initform (make-instance 'session-master)
46                    :accessor session-master)
47    (connector :initarg :connector :accessor project-connector)))
48
49 (defclass entity ()
50   ((project :initarg :project :accessor entity-project)
51    (aserve-entity :initarg :aserve-entity :initform nil
52                   :accessor entity-aserve-entity)))
53
54
55 (defclass http-request ()
56   ((method  :initarg :method :accessor request-method)
57    (uri  :initarg :uri :accessor request-uri)
58    (decoded-uri-path :initarg :decoded-uri-path
59                      :accessor request-decoded-uri-path)
60    (raw-request :initarg :raw-request :accessor request-raw-request)
61    (raw-uri :initarg :raw-uri :accessor request-raw-uri)
62    (protocol :initarg :protocol :reader request-protocol)
63    (protocol-string :initarg :protocol-string :reader request-protocol-string)
64    (socket :initarg :socket :reader request-socket)
65    (ml-server :initarg :ml-server :reader request-ml-server)
66    (aserve-server :initarg :aserve-server :reader request-aserve-server)
67    (host :initarg :host :accessor request-host)
68    (desired-query :initform nil :accessor request-desired-query
69                   :documentation "type of query alist requested")
70    (posted-content :initarg :posted-content :accessor request-posted-content)
71    (headers :initarg :headers :accessor request-headers)
72    (page :initarg :page :initform nil :accessor request-page)
73    (url-plist :initarg :url-plist :initform nil :accessor request-url-plist)
74    (plist :initarg :plist :initform nil :accessor request-plist)
75    (url-next-plists :initarg :url-next-plists :initform nil 
76                 :accessor request-url-next-plists)
77    (uri-query :initarg :uri-query :initform nil 
78                 :accessor request-uri-query)
79    (query-alist :initarg :query-alist :initform nil 
80                 :accessor request-query-alist)
81    (session :initarg :session :initform nil
82             :accessor websession-from-req)
83    (aserve-request :initarg :aserve-request :initform nil
84                    :accessor aserve-request)
85    ))
86
87 (defvar *reap-interval* 300)
88 (defvar *reaper-process* nil) 
89
90 (defvar *active-projects* (make-hash-table :test 'equal))
91
92 (eval-when (:compile-toplevel :load-toplevel :execute)
93   (defvar +plist-header+ "sdata"
94     "string that starts an encoded plist"))
95
96 (defconstant +plist-header-length+ (length +plist-header+))
97
98 (defparameter *wol-version* '(0 1 0))
99
100 (defvar *wol-stream* nil
101   "The output stream for the current request")
102
103 (defconstant +length-session-id+ 24)
104
105 (defvar *req* nil "Current request")
106 (defvar *ent* nil "Current entity")