GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages


Manual Reference Pages  -  MOD_ESI (3)

NAME

mod_esi - Erlang Server Interface

CONTENTS

Description
Exports
Exports

DESCRIPTION

This module defines the Erlang Server Interface (ESI) API. It is a more efficient way of writing Erlang scripts for your Inets web server than writing them as common CGI scripts.

EXPORTS

deliver(SessionID, Data) -> ok | {error, Reason}

Types:

SessionID = term()
Data = string() | io_list() | binary()
Reason = term()

This function is only intended to be used from functions called by the Erl Scheme interface to deliver parts of the content to the user.

Sends data from an Erl Scheme script back to the client.

Note:
If any HTTP header fields are added by the script, they must be in the first call to deliver/2, and the data in the call must be a string. Calls after the headers are complete can contain binary data to reduce copying overhead. Do not assume anything about the data type of SessionID. SessionID must be the value given as input to the ESI callback function that you implemented.

ESI CALLBACK FUNCTIONS

EXPORTS

Module:Function(SessionID, Env, Input)-> _

Types:

SessionID = term()
Env = [EnvironmentDirectives] ++ ParsedHeader
EnvironmentDirectives = {Key,Value}
Key = query_string | content_length | server_software | gateway_interface | server_protocol | server_port | request_method | remote_addr | script_name
Input = string()

Module must be found in the code path and export Function with an arity of three. An erlScriptAlias must also be set up in the configuration file for the web server.

If the HTTP request is a ’post’ request and a body is sent, content_length is the length of the posted data. If ’get’ is used, query_string is the data after ? in the URL.

ParsedHeader is the HTTP request as a key-value tuple list. The keys in ParsedHeader are in lower case.

SessionID is an identifier the server uses when deliver/2 is called. Do not assume anything about the datatype.

Use this callback function to generate dynamic web content dynamically. When a part of the page is generated, send the data back to the client through deliver/2. Notice that the first chunk of data sent to the client must at least contain all HTTP header fields that the response will generate. If the first chunk does not contain the end of HTTP header, that is, "\r\n\r\n", the server assumes that no HTTP header fields will be generated.

Module:Function(Env, Input)-> Response

Types:

Env = [EnvironmentDirectives] ++ ParsedHeader
EnvironmentDirectives = {Key,Value}
Key = query_string | content_length | server_software | gateway_interface | server_protocol | server_port | request_method | remote_addr | script_name.
Input = string()
Response = string()

This callback format consumes much memory, as the whole response must be generated before it is sent to the user. This function is deprecated and is only kept for backwards compatibility. For new development, use Module:Function/3.

Search for    or go to Top of page |  Section 3 |  Main Index


Ericsson AB MOD_ESI (3) inets 6.2

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with manServer 1.07.