1 ;;;; -*- Mode: Lisp; Syntax: ANSI-Common-Lisp; Base: 10; Package: wol -*-
2 ;;;; *************************************************************************
3 ;;;; FILE IDENTIFICATION
5 ;;;; Name: classes.lisp
6 ;;;; Purpose: Classes for Wol library
7 ;;;; Programmer: Kevin M. Rosenberg
8 ;;;; Date Started: July 2003
10 ;;;; $Id: classes.lisp,v 1.8 2003/08/10 17:56:44 kevin Exp $
12 ;;;; This file and Wol are Copyright (c) 2001-2003 by Kevin M. Rosenberg
13 ;;;; *************************************************************************
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)))
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)))
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)))
50 ((project :initarg :project :accessor entity-project)
51 (aserve-entity :initarg :aserve-entity :initform nil
52 :accessor entity-aserve-entity)))
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)
87 (defvar *reap-interval* 300)
88 (defvar *reaper-process* nil)
90 (defvar *active-projects* (make-hash-table :test 'equal))
92 (defvar +asp-header+ "lsp")
93 (defvar +full-asp-header+ "/lsp")
95 (defvar +plist-header+ "/sdata"
96 "string that starts an encoded plist")
98 (defparameter *wol-version* '(0 1 0))
100 (defvar *wol-stream* nil
101 "The output stream for the current request")
103 (defconstant +length-session-id+ 24)
105 (defvar *req* nil "Current request")
106 (defvar *ent* nil "Current entity")