Index: openacs-4/packages/acs-core-docs/www/rp-requirements.html =================================================================== RCS file: /usr/local/cvsroot/openacs-4/packages/acs-core-docs/www/rp-requirements.html,v diff -u -r1.2 -r1.3 --- openacs-4/packages/acs-core-docs/www/rp-requirements.html 17 Oct 2001 20:39:26 -0000 1.2 +++ openacs-4/packages/acs-core-docs/www/rp-requirements.html 2 Feb 2002 03:47:32 -0000 1.3 @@ -1,25 +1,131 @@ - -15. ACS 4 Request Processor Requirements

Home : Documentation : Part III. For ACS Developers : 7. Kernel Documentation : 15. ACS 4 Request Processor Requirements 

15. ACS 4 Request Processor Requirements

Table of Contents

15.1. Introduction
15.2. Vision Statement
15.3. System Overview
15.4. Related Links
15.5. Requirements

+ + + + +OpenACS 4 Request Processor Requirements + + + + + + + + +

+
+

+OpenACS 4 Request Processor Requirements

+

by Rafael H. Schloming -

15.1. Introduction

The following is a requirements document for the ACS 4.0 request +

+
+

+Introduction

+

The following is a requirements document for the OpenACS 4.0 request processor. The major enhancements in the 4.0 version include a more sophisticated directory mapping system that allows package pageroots to be mounted at arbitrary urls, and tighter integration with the database to allow -for flexible user controlled url structures, and subsites.

15.2. Vision Statement

Most web servers are designed to serve pages from exactly one static +for flexible user controlled url structures, and subsites.

+
+
+

+Vision Statement

+

Most web servers are designed to serve pages from exactly one static pageroot. This restriction can become cumbersome when trying to build a web -toolkit full of reusable and reconfigurable components.

15.3. System Overview

The request processor's functionality can be split into two main -pieces.

  1. Set up the environment in which a server side script expects to run. This -includes things like:

    • Initialize common variables associated with a request.

    • Authenticate the connecting party.

    • Check that the connecting party is authorized to proceed with the -request.

    • Invoke any filters associated with the request URI.

  2. Determine to which entity the request URI maps, and deliver the content +toolkit full of reusable and reconfigurable components.

    +
+
+

+System Overview

+

The request processor's functionality can be split into two main +pieces.

+
    +
  1. +

    Set up the environment in which a server side script expects to run. This +includes things like:

    +
      +
    • Initialize common variables associated with a request.

    • +
    • Authenticate the connecting party.

    • +
    • Check that the connecting party is authorized to proceed with the +request.

    • +
    • Invoke any filters associated with the request URI.

    • +
    +
  2. +
  3. Determine to which entity the request URI maps, and deliver the content provided by this entity. If this entity is a proc, then it is invoked. If this entitty is a file then this step involves determining the file type, and the manner in which the file must be processed to produce content appropriate for the connecting party. Eventually this may also require determining the capabilities of the connecting browser and choosing the most appropriate form -for the delivered content.

It is essential that any errors that occur during the above steps be -reported to developers in an easily decipherable manner.

15.5. Requirements

10.0 Multiple Pageroots

10.10 Pageroots may be combined into one URL space.

10.20 Pageroots may be mounted at more than one location in the URL -space.

20.0 Application Context

20.10 The request processor must be able to determine a primary context +for the delivered content.

+
+

It is essential that any errors that occur during the above steps be +reported to developers in an easily decipherable manner.

+
+ +
+

+Requirements

+

10.0 Multiple Pageroots

+
+

+10.10 Pageroots may be combined into one URL space.

+

+10.20 Pageroots may be mounted at more than one location in the URL +space.

+
+

20.0 Application Context

+

+20.10 The request processor must be able to determine a primary context or state associated with a pageroot based on it's location within the URL -space.

30.0 Authentication

30.10 The request processor must be able to verify that the connecting -browser actually represents the party it claims to represent.

40.0 Authorization

40.10 The request processor must be able to verify that the party the -connecting browser represents is allowed to make the request.

50.0 Scalability

+space.

+

30.0 Authentication

+

+30.10 The request processor must be able to verify that the connecting +browser actually represents the party it claims to represent.

+

40.0 Authorization

+

+40.10 The request processor must be able to verify that the party the +connecting browser represents is allowed to make the request.

+

50.0 Scalability

+
+
+ + +