167 lines
		
	
	
		
			8.4 KiB
		
	
	
	
		
			Factor
		
	
	
			
		
		
	
	
			167 lines
		
	
	
		
			8.4 KiB
		
	
	
	
		
			Factor
		
	
	
| USING: assocs help.markup help.syntax io.streams.string sequences strings present math kernel byte-arrays urls
 | |
| calendar ;
 | |
| IN: http
 | |
| 
 | |
| HELP: <request>
 | |
| { $values { "request" request } }
 | |
| { $description "Creates an empty request." } ;
 | |
| 
 | |
| HELP: request
 | |
| { $description "An HTTP request."
 | |
| $nl
 | |
| "Instances contain the following slots:"
 | |
| { $table
 | |
|     { { $slot "method" } { "The HTTP method as a " { $link string } ". The most frequently-used HTTP methods are " { $snippet "GET" } ", " { $snippet "HEAD" } " and " { $snippet "POST" } "." } }
 | |
|     { { $slot "url" } { "The " { $link url } " being requested" } }
 | |
|     { { $slot "version" } { "The HTTP version. Default is " { $snippet "1.1" } " and should not be changed without good reason." } }
 | |
|     { { $slot "header" } { "An assoc of HTTP header values. See " { $link "http.headers" } } }
 | |
|     { { $slot "post-data" } { "See " { $link "http.post-data" } } }
 | |
|     { { $slot "cookies" } { "A sequence of HTTP cookies. See " { $link "http.cookies" } } }
 | |
| } } ;
 | |
| 
 | |
| HELP: <response>
 | |
| { $values { "response" response } }
 | |
| { $description "Creates an empty response." } ;
 | |
| 
 | |
| HELP: response
 | |
| { $class-description "An HTTP response."
 | |
| $nl
 | |
| "Instances contain the following slots:"
 | |
| { $table
 | |
|     { { $slot "version" } { "The HTTP version. Default is " { $snippet "1.1" } " and should not be changed without good reason." } }
 | |
|     { { $slot "code" } { "HTTP status code, an " { $link integer } ". Examples are 200 for success, 404 for file not found, and so on." } }
 | |
|     { { $slot "message" } { "HTTP status message, only displayed to the user. If the status code is 200, the status message might be ``Success'', for example." } }
 | |
|     { { $slot "header" } { "An assoc of HTTP header values. See " { $link "http.headers" } } }
 | |
|     { { $slot "cookies" } { "A sequence of HTTP cookies. See " { $link "http.cookies" } } }
 | |
|     { { $slot "content-type" } { "an HTTP content type" } }
 | |
|     { { $slot "content-charset" } { "an encoding descriptor. See " { $link "io.encodings" } } }
 | |
|     { { $slot "body" } { "an HTTP response body" } }
 | |
| } } ;
 | |
| 
 | |
| HELP: <raw-response>
 | |
| { $values { "response" raw-response } }
 | |
| { $description "Creates an empty raw response." } ;
 | |
| 
 | |
| HELP: raw-response
 | |
| { $class-description "A minimal HTTP response used by webapps which need full control over all output sent to the client. Most webapps can use " { $link response } " instead."
 | |
| $nl
 | |
| "Instances contain the following slots:"
 | |
| { $table
 | |
|     { { $slot "version" } { "The HTTP version. Default is " { $snippet "1.1" } " and should not be changed without good reason." } }
 | |
|     { { $slot "code" } { "HTTP status code, an " { $link integer } ". Examples are 200 for success, 404 for file not found, and so on." } }
 | |
|     { { $slot "message" } { "HTTP status message, only displayed to the user. If the status code is 200, the status message might be ``Success'', for example." } }
 | |
|     { { $slot "body" } { "an HTTP response body" } }
 | |
| } } ;
 | |
| 
 | |
| HELP: <cookie>
 | |
| { $values { "value" object } { "name" string } { "cookie" cookie } }
 | |
| { $description "Creates a cookie with the specified name and value. The value can be any object supported by the " { $link present } " word." } ;
 | |
| 
 | |
| HELP: cookie
 | |
| { $class-description
 | |
| "An HTTP cookie."
 | |
| $nl
 | |
| "Instances contain a number of slots which correspond exactly to the fields of a cookie in the cookie specification:"
 | |
| { $table
 | |
|     { { $slot "name" } { "The cookie name, a " { $link string } } }
 | |
|     { { $slot "value" } { "The cookie value, an object supported by " { $link present } } }
 | |
|     { { $slot "comment" } { "A " { $link string } } }
 | |
|     { { $slot "path" } { "The pathname prefix where the cookie is valid, a " { $link string } } }
 | |
|     { { $slot "domain" } { "The domain name where the cookie is valid, a " { $link string } } }
 | |
|     { { $slot "expires" } { "The expiry time, a " { $link timestamp } " or " { $link f } " for a session cookie" } }
 | |
|     { { $slot "max-age" } { "The expiry duration, a " { $link duration } " or " { $link f } " for a session cookie" } }
 | |
|     { { $slot "http-only" } { "If set to a true value, JavaScript code cannot see the cookie" } }
 | |
|     { { $slot "secure" } { "If set to a true value, the cookie is only sent for " { $snippet "https" } " protocol connections" } }
 | |
| }
 | |
| "Only one of " { $snippet "expires" } " and " { $snippet "max-age" } " can be set; the latter is preferred and is supported by all modern browsers." } ;
 | |
| 
 | |
| HELP: delete-cookie
 | |
| { $values { "request/response" "a " { $link request } " or a " { $link response } } { "name" string } }
 | |
| { $description "Deletes a cookie from a request or response." }
 | |
| { $side-effects "request/response" } ;
 | |
| 
 | |
| HELP: get-cookie
 | |
| { $values { "request/response" "a " { $link request } " or a " { $link response } } { "name" string } { "cookie/f" { $maybe cookie } } }
 | |
| { $description "Gets a named cookie from a request or response." } ;
 | |
| 
 | |
| HELP: put-cookie
 | |
| { $values { "request/response" "a " { $link request } " or a " { $link response } } { "cookie" cookie } }
 | |
| { $description "Stores a cookie in a request or response." }
 | |
| { $side-effects "request/response" } ;
 | |
| 
 | |
| HELP: <post-data>
 | |
| { $values { "raw" byte-array } { "content-type" "a MIME type string" } { "post-data" post-data } }
 | |
| { $description "Creates a new " { $link post-data } "." } ;
 | |
| 
 | |
| HELP: header
 | |
| { $values { "request/response" "a " { $link request } " or a " { $link response } } { "key" string } { "value" string } }
 | |
| { $description "Obtains an HTTP header value from a request or response." } ;
 | |
| 
 | |
| HELP: post-data
 | |
| { $class-description "HTTP POST data passed in a POST request."
 | |
| $nl
 | |
| "Instances contain the following slots:"
 | |
| { $table
 | |
|     { { $slot "raw" } { "The raw bytes of the POST data" } }
 | |
|     { { $slot "content" } { "The POST data. This can be in a higher-level form, such as an assoc of POST parameters, a string, or an XML document" } }
 | |
|     { { $slot "content-type" } "A MIME type" }
 | |
| } } ;
 | |
| 
 | |
| HELP: set-header
 | |
| { $values { "request/response" "a " { $link request } " or a " { $link response } } { "value" object } { "key" string } }
 | |
| { $description "Stores a value into the HTTP header of a request or response. The value can be any object supported by " { $link present } "." }
 | |
| { $notes "This word always returns the same object that was input. This allows for a ``pipeline'' coding style, where several header parameters are set in a row." }
 | |
| { $side-effects "request/response" } ;
 | |
| 
 | |
| ARTICLE: "http.cookies" "HTTP cookies"
 | |
| "Every " { $link request } " and " { $link response } " instance can contain cookies."
 | |
| $nl
 | |
| "The " { $vocab-link "furnace.sessions" } " vocabulary implements session management using cookies, thus the most common use case can be taken care of without working with cookies directly."
 | |
| $nl
 | |
| "The class of cookies:"
 | |
| { $subsection cookie }
 | |
| "Creating cookies:"
 | |
| { $subsection <cookie> }
 | |
| "Getting, adding, and deleting cookies in " { $link request } " and " { $link response } " objects:"
 | |
| { $subsection get-cookie }
 | |
| { $subsection put-cookie }
 | |
| { $subsection delete-cookie } ;
 | |
| 
 | |
| ARTICLE: "http.headers" "HTTP headers"
 | |
| "Every " { $link request } " and " { $link response } " has a set of HTTP headers stored in the " { $slot "header" } " slot. Header names are normalized to lower-case when a request or response is being parsed."
 | |
| { $subsection header }
 | |
| { $subsection set-header } ;
 | |
| 
 | |
| ARTICLE: "http.post-data" "HTTP post data"
 | |
| "Every " { $link request } " where the " { $slot "method" } " slot is " { $snippet "POST" } " can contain post data."
 | |
| { $subsection post-data }
 | |
| { $subsection <post-data> } ;
 | |
| 
 | |
| ARTICLE: "http.requests" "HTTP requests"
 | |
| "HTTP requests:"
 | |
| { $subsection request }
 | |
| { $subsection <request> }
 | |
| "Requests can contain form submissions:"
 | |
| { $subsection "http.post-data" } ;
 | |
| 
 | |
| ARTICLE: "http.responses" "HTTP responses"
 | |
| "HTTP responses:"
 | |
| { $subsection response }
 | |
| { $subsection <response> }
 | |
| "Raw responses only contain a status line, with no header. They are used by webapps which need full control over the HTTP response, for example " { $vocab-link "http.server.cgi" } ":"
 | |
| { $subsection raw-response }
 | |
| { $subsection <raw-response> } ;
 | |
| 
 | |
| ARTICLE: "http" "HTTP protocol objects"
 | |
| "The " { $vocab-link "http" } " vocabulary contains data types shared by " { $vocab-link "http.client" } " and " { $vocab-link "http.server" } "."
 | |
| $nl
 | |
| "The HTTP client sends an HTTP request to the server and receives an HTTP response back. The HTTP server receives HTTP requests from clients and sends HTTP responses back."
 | |
| { $subsection "http.requests" }
 | |
| { $subsection "http.responses" }
 | |
| "Both requests and responses support some common functionality:"
 | |
| { $subsection "http.headers" }
 | |
| { $subsection "http.cookies" }
 | |
| { $see-also "urls" } ;
 | |
| 
 | |
| ABOUT: "http"
 |