Home | Wiki | OI 1.x Docs | OI 2.x Docs OI logo

NAME

OpenInteract2::Manual::Install - Create an OpenInteract2 website in ten minutes!

SYNOPSIS

This part of the manual will walk you through setting up an OpenInteract2 website.

WHAT IS IT?

OpenInteract2 is an extensible application server that includes everything you need to quickly build robust applications. It includes:

CONCEPTS

For more information about these concepts see OpenInteract2::Manual::Architecture.

Context

Holds all application configuration information and provides a central lookup mechanism. This is a singleton (there's only one in the system at any time) and can be imported from the OpenInteract2::Context class since it's used fairly often.

Adapter

This is the tool that sits between your interface (e.g., Apache/mod_perl, CGI, etc.) and the OpenInteract server. The adapter translates parameters from the user, information about the request (hostname, URL, referer, cookies, etc.) and other data into the relevant OpenInteract2::Request subclass.

Once the OpenInteract cycle is complete it translates OpenInteract data (content, headers, etc.) into a response to send back to the user via the relevant OpenInteract2::Response subclass. For an example see Apache::OpenInteract2.

Controller

Once the adapter has created the request and response it hands off the processing to the OpenInteract2::Controller object. This reads the URL and creates the relevant action object that will generate the content. It knows which action object to create through a URL-to-action mapping created at server startup. The controller places the generated content in a larger scope so you can control common graphical elements (sidebars, menus, etc.) from one place.

Action

Actions are the core of OpenInteract2. Each action provides a discrete set of functionality. What "discrete set" means is up to the developer, but typically this is a set of SCRUD (Search - CReate - Update - Delete) operations on a class of objects.

Each action is represented by zero or more URLs, and each operation is specified by a task referenced in that URL. So if I created a 'news' action my URLs might look like:

  /news/search/
  /news/create/
  /news/update/
  /news/remove/

Every task returns some sort of content, generally by passing data to a Content Generator which marries it with a template. See OpenInteract2::Action for much more information.

Content Generator

As mentioned above tasks in an Action return content. They normally generate that content by assembling a set of data and passing that data off to a content generator. A content generator is a wrapper around some sort of templating system, such as the Template Toolkit|Template, HTML::Template or Text::Template or even your own homegrown system. (Admit it, you've written your own.)

Each action is associated with a content generator. And you can even associate an action with multiple content generators so you can settle a bet as to which templating system is easiest to use.

CONFIGURATION FILES

These are the major configuration files at the server level. Each package has its own configuration files -- see OpenInteract2::Manual::Packages for more information about packages.

server configuration - conf/server.ini

This is the main OpenInteract2 configuration file. No matter what interface you use you will need to modify this file. It holds the global debugging level, deployment URL, email addresses, directory layouts, database connection data, session information along with lots of other items. Much of it you don't need to edit, but it's useful to give it a once-over so you're familiar with it.

logging configuration - conf/log4perl.conf

This controls logging for the application server. Here you can determine the logging level for the whole server or discrete parts of it, which logfiles get written, when/if they're rolled over, etc. See OpenInteract2::Manual::Logging for a quick intro to logging and read up about Log::Log4perl for details.

interface configuration: Apache - conf/httpd_modperl_solo.conf

This describes a virtual host configuration for running the server inside Apache/mod_perl without a front-end proxy server. It's useful for development but in real life you'd probably want the proxy server (see conf/httpd_static.conf for a proxy configuration and conf/httpd_modperl.conf for the corresponding proxied backend configuration).

interface configuration: standalone - conf/oi2_daemon.ini

Just a few directives to tell the standalone web server what host and port to run on.

COPYRIGHT

Copyright (c) 2002-2003 Chris Winters. All rights reserved.

AUTHORS

Chris Winters <chris@cwinters.com>

Generated from the OpenInteract 1.99_04 source.


Home | Wiki | OI 1.x Docs | OI 2.x Docs
SourceForge Logo