Still work to do in the manual...
This commit is contained in:
parent
8e80e38f2c
commit
0a4c1534f3
@ -36,7 +36,7 @@
|
|||||||
<h2 id=dns>DNS</h2>
|
<h2 id=dns>DNS</h2>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
Name resolution function return <em>all</em> information returned by the
|
Name resolution functions return <em>all</em> information obtained from the
|
||||||
resolver in a table of the form:
|
resolver in a table of the form:
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
@ -59,14 +59,9 @@ socket.dns.<b>gethostname()</b>
|
|||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=description>
|
<p class=description>
|
||||||
Returns the standard host name for the machine.
|
Returns the standard host name for the machine as a string.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=return>
|
|
||||||
The function returns a string with the host name.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
|
|
||||||
<!-- tohostname +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
<!-- tohostname +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
||||||
|
|
||||||
<p class=name id=tohostname>
|
<p class=name id=tohostname>
|
||||||
|
59
doc/ftp.html
59
doc/ftp.html
@ -35,12 +35,33 @@
|
|||||||
|
|
||||||
<p>
|
<p>
|
||||||
FTP (File Transfer Protocol) is a protocol used to transfer files
|
FTP (File Transfer Protocol) is a protocol used to transfer files
|
||||||
between hosts. The module <tt>ftp.lua</tt> offers simple FTP support.
|
between hosts. The <tt>ftp</tt> namespace offers thorough support
|
||||||
Applications can easily download and upload files.
|
to FTP, under a simple interface. The implementation conforms to
|
||||||
The implementation conforms to
|
|
||||||
<a href="http://www.cs.princeton.edu/~diego/rfc/rfc0959.txt">RFC 959</a>.
|
<a href="http://www.cs.princeton.edu/~diego/rfc/rfc0959.txt">RFC 959</a>.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
High level functions are provided supporting the most common operations.
|
||||||
|
These high level functions are implemented on top of a lower level
|
||||||
|
interface. Using the low-level interface, users can easily create their
|
||||||
|
own functions to access <em>any</em> operation supported by the FTP
|
||||||
|
protocol. For that, check the implementation.
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
To really benefit from this module, a good understanding of
|
||||||
|
<a href="http://lua-users.org/wiki/FiltersSourcesAndSinks">
|
||||||
|
LTN012, Filters sources and sinks</a> is necessary.
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<p class=description> To obtain the <tt>ftp</tt> namespace, run:
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<pre class=example>
|
||||||
|
-- loads the FTP module and any libraries it requires
|
||||||
|
local ftp = require("ftp")
|
||||||
|
</pre>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
URLs MUST conform to
|
URLs MUST conform to
|
||||||
<a href="http://www.cs.princeton.edu/~diego/rfc/rfc1738.txt">RFC
|
<a href="http://www.cs.princeton.edu/~diego/rfc/rfc1738.txt">RFC
|
||||||
@ -53,21 +74,7 @@ URLs MUST conform to
|
|||||||
</blockquote>
|
</blockquote>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
High level functions are provided supporting the most common operations.
|
The following constants in the namespace can be set to control the default behavior of
|
||||||
These high level functions are implemented on top of a lower level
|
|
||||||
interface. By using the low-level interface, users can easily create their
|
|
||||||
own functions to access <em>any</em> operation supported by the FTP
|
|
||||||
protocol. For that, check the implementation.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p>
|
|
||||||
To use some of the functions in this module, a good understanding of
|
|
||||||
<a href="http://lua-users.org/wiki/FiltersSourcesAndSinks">
|
|
||||||
LTN012, Filters sources and sinks</a> is necessary.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p>
|
|
||||||
The following constants can be set to control the default behaviour of
|
|
||||||
the FTP module:
|
the FTP module:
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
@ -78,6 +85,7 @@ the FTP module:
|
|||||||
<li> <tt>USER</tt>: default anonymous user;
|
<li> <tt>USER</tt>: default anonymous user;
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
<!-- ftp.get ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
<!-- ftp.get ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
||||||
|
|
||||||
<p class=name id=get>
|
<p class=name id=get>
|
||||||
@ -116,7 +124,7 @@ optional arguments are the following:
|
|||||||
authentication. Defaults to "<tt>ftp:anonymous@anonymous.org</tt>";
|
authentication. Defaults to "<tt>ftp:anonymous@anonymous.org</tt>";
|
||||||
<li><tt>command</tt>: The FTP command used to obtain data. Defaults to
|
<li><tt>command</tt>: The FTP command used to obtain data. Defaults to
|
||||||
"<tt>retr</tt>", but see example below;
|
"<tt>retr</tt>", but see example below;
|
||||||
<li><tt>port</tt>: The port to contacct the server at. Defaults to 21;
|
<li><tt>port</tt>: The port to used for the control connection. Defaults to 21;
|
||||||
<li><tt>type</tt>: The transfer mode. Can take values "<tt>i</tt>" or
|
<li><tt>type</tt>: The transfer mode. Can take values "<tt>i</tt>" or
|
||||||
"<tt>a</tt>". Defaults to whatever is the server default;
|
"<tt>a</tt>". Defaults to whatever is the server default;
|
||||||
<li><tt>step</tt>: LTN12 pump step function used to pass data from the
|
<li><tt>step</tt>: LTN12 pump step function used to pass data from the
|
||||||
@ -192,9 +200,9 @@ optional arguments are the following:
|
|||||||
<ul>
|
<ul>
|
||||||
<li><tt>user</tt>, <tt>password</tt>: User name and password used for
|
<li><tt>user</tt>, <tt>password</tt>: User name and password used for
|
||||||
authentication. Defaults to "<tt>ftp:anonymous@anonymous.org</tt>";
|
authentication. Defaults to "<tt>ftp:anonymous@anonymous.org</tt>";
|
||||||
<li><tt>command</tt>: The FTP command used to obtain data. Defaults to
|
<li><tt>command</tt>: The FTP command used to send data. Defaults to
|
||||||
"<tt>retr</tt>", but see example below;
|
"<tt>stor</tt>", but see example below;
|
||||||
<li><tt>port</tt>: The port to contacct the server at. Defaults to 21;
|
<li><tt>port</tt>: The port to used for the control connection. Defaults to 21;
|
||||||
<li><tt>type</tt>: The transfer mode. Can take values "<tt>i</tt>" or
|
<li><tt>type</tt>: The transfer mode. Can take values "<tt>i</tt>" or
|
||||||
"<tt>a</tt>". Defaults to whatever is the server default;
|
"<tt>a</tt>". Defaults to whatever is the server default;
|
||||||
<li><tt>step</tt>: LTN12 pump step function used to pass data from the
|
<li><tt>step</tt>: LTN12 pump step function used to pass data from the
|
||||||
@ -213,7 +221,8 @@ local ftp = require("ftp")
|
|||||||
-- Log as user "diego" on server "ftp.tecgraf.puc-rio.br",
|
-- Log as user "diego" on server "ftp.tecgraf.puc-rio.br",
|
||||||
-- using password "nehab", and store a file "README" with contents
|
-- using password "nehab", and store a file "README" with contents
|
||||||
-- "wrong password, of course"
|
-- "wrong password, of course"
|
||||||
f, e = ftp.put("ftp://diego:nehab@ftp.tecgraf.puc-rio.br/README", "wrong password, of course")
|
f, e = ftp.put("ftp://diego:nehab@ftp.tecgraf.puc-rio.br/README",
|
||||||
|
"wrong password, of course")
|
||||||
</pre>
|
</pre>
|
||||||
|
|
||||||
<pre class=example>
|
<pre class=example>
|
||||||
@ -222,8 +231,8 @@ local ftp = require("ftp")
|
|||||||
local ltn12 = require("ltn12")
|
local ltn12 = require("ltn12")
|
||||||
|
|
||||||
-- Log as user "diego" on server "ftp.tecgraf.puc-rio.br",
|
-- Log as user "diego" on server "ftp.tecgraf.puc-rio.br",
|
||||||
-- using password "nehab", and append to the file "LOG", sending the
|
-- using password "nehab", and append to the remote file "LOG", sending the
|
||||||
-- contents of a local file
|
-- contents of the local file "LOCAL-LOG"
|
||||||
f, e = ftp.put{
|
f, e = ftp.put{
|
||||||
host = "ftp.tecgraf.puc-rio.br",
|
host = "ftp.tecgraf.puc-rio.br",
|
||||||
user = "diego",
|
user = "diego",
|
||||||
|
@ -37,8 +37,9 @@
|
|||||||
|
|
||||||
<p>
|
<p>
|
||||||
HTTP (Hyper Text Transfer Protocol) is the protocol used to exchange
|
HTTP (Hyper Text Transfer Protocol) is the protocol used to exchange
|
||||||
information between web-browsers and servers. The <tt>http.lua</tt>
|
information between web-browsers and servers. The <tt>http</tt>
|
||||||
module offers support for the client side of the HTTP protocol (i.e.,
|
namespace offers full support for the client side of the HTTP
|
||||||
|
protocol (i.e.,
|
||||||
the facilities that would be used by a web-browser implementation). The
|
the facilities that would be used by a web-browser implementation). The
|
||||||
implementation conforms to the HTTP/1.1 standard,
|
implementation conforms to the HTTP/1.1 standard,
|
||||||
<a href="http://www.cs.princeton.edu/~diego/rfc/rfc2616.txt">RFC
|
<a href="http://www.cs.princeton.edu/~diego/rfc/rfc2616.txt">RFC
|
||||||
@ -47,11 +48,20 @@ implementation conforms to the HTTP/1.1 standard,
|
|||||||
|
|
||||||
<p>
|
<p>
|
||||||
The module exports functions that provide HTTP functionality in different
|
The module exports functions that provide HTTP functionality in different
|
||||||
levels of abstraction, from the simple <a
|
levels of abstraction, from the simple
|
||||||
href="#get"><tt>get</tt></a> function to the generic, LTN12 based <a
|
<a href="#get"><tt>get</tt></a> function, through the generic
|
||||||
href="#request"><tt>request</tt></a> function.
|
LTN12 based <a href="#request"><tt>request</tt></a> function, down to
|
||||||
|
even lower-level if you bother to look through the source code.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
<p class=description> To obtain the <tt>ftp</tt> namespace, run:
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<pre class=example>
|
||||||
|
-- loads the HTTP module and any libraries it requires
|
||||||
|
local http = require("http")
|
||||||
|
</pre>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
URLs must conform to
|
URLs must conform to
|
||||||
<a href="http://www.cs.princeton.edu/~diego/rfc/rfc1738.txt">RFC
|
<a href="http://www.cs.princeton.edu/~diego/rfc/rfc1738.txt">RFC
|
||||||
@ -189,12 +199,12 @@ http.<b>request{</b><br>
|
|||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=description>
|
<p class=description>
|
||||||
Performs the generic HTTP request, controled by a request table.
|
Performs the generic HTTP request, controlled by a request table.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=parameters>
|
<p class=parameters>
|
||||||
The most important parameters are the <tt>url</tt> and the <em>simple</em> LTN12 <tt>sink</tt> that will receive the downloaded content.
|
The most important parameters are the <tt>url</tt> and the <em>simple</em> LTN12 <tt>sink</tt> that will receive the downloaded content.
|
||||||
Any part of the <tt>url</tt> can be overriden by including
|
Any part of the <tt>url</tt> can be overridden by including
|
||||||
the appropriate field in the request table.
|
the appropriate field in the request table.
|
||||||
If authentication information is provided, the function
|
If authentication information is provided, the function
|
||||||
uses the Basic Authentication Scheme (see <a href="#authentication">note</a>)
|
uses the Basic Authentication Scheme (see <a href="#authentication">note</a>)
|
||||||
@ -231,8 +241,8 @@ respt = {<br>
|
|||||||
</tt></blockquote>
|
</tt></blockquote>
|
||||||
|
|
||||||
<p class=return>
|
<p class=return>
|
||||||
Even when there was failure (URL not found, for example), the
|
Even when the server fails to provide the contents of the requested URL (URL not found, for example), the
|
||||||
function usually succeeds retrieving a message body (a web page informing the
|
it usually returns a message body (a web page informing the
|
||||||
URL was not found or some other useless page). To make sure the
|
URL was not found or some other useless page). To make sure the
|
||||||
operation was successful, check the returned status <tt>code</tt>. For
|
operation was successful, check the returned status <tt>code</tt>. For
|
||||||
a list of the possible values and their meanings, refer to <a
|
a list of the possible values and their meanings, refer to <a
|
||||||
@ -261,7 +271,6 @@ respt = http.request {
|
|||||||
-- ["content-Type"] = "text/html"
|
-- ["content-Type"] = "text/html"
|
||||||
-- }
|
-- }
|
||||||
</pre>
|
</pre>
|
||||||
</blockquote>
|
|
||||||
|
|
||||||
<p class=note id=authentication>
|
<p class=note id=authentication>
|
||||||
Note: Some URLs are protected by their
|
Note: Some URLs are protected by their
|
||||||
|
101
doc/index.html
101
doc/index.html
@ -37,21 +37,29 @@
|
|||||||
|
|
||||||
<p>
|
<p>
|
||||||
LuaSocket is a <a href="http://www.lua.org">Lua</a> extension library
|
LuaSocket is a <a href="http://www.lua.org">Lua</a> extension library
|
||||||
that is composed by two parts: a C layer that provides support for the TCP
|
that is composed by two parts: a C core that provides support for the TCP
|
||||||
and UDP transport layers, and a set of Lua modules that add support for
|
and UDP transport layers, and a set of Lua modules that add support for
|
||||||
the SMTP (sending e-mails), HTTP (WWW access) and FTP (uploading and
|
functionality commonly needed by applications that deal with the Internet.
|
||||||
downloading files) protocols and other functionality commonly needed by
|
|
||||||
applications that deal with the Internet.
|
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
Network support has been implemented so that it is both efficient and
|
The core support has been implemented so that it is both efficient and
|
||||||
simple to use. LuaSocket can be used by any Lua application once it has
|
simple to use. The core can be used by any Lua application once it has
|
||||||
been properly initialized by the interpreter running the
|
been properly initialized by the interpreter running the
|
||||||
Lua application. The code has been tested and runs well on several Windows
|
Lua application. The code has been tested and runs well on several Windows
|
||||||
and Unix platforms.
|
and Unix platforms.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
The most used modules implement the SMTP (sending e-mails), HTTP
|
||||||
|
(WWW access) and FTP (uploading and downloading files) client
|
||||||
|
protocols. These provide a very natural and generic interface to the e
|
||||||
|
functionality covered by the protocols.
|
||||||
|
In addition, you will find that the MIME (common encodings), URL (anything you
|
||||||
|
could possible want to do with one) and LTN12 (filters, sinks, sources
|
||||||
|
and pumps) modules can be very handy.
|
||||||
|
</p>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
The library is available under the same
|
The library is available under the same
|
||||||
<a href="http://www.lua.org/copyright.html">
|
<a href="http://www.lua.org/copyright.html">
|
||||||
@ -112,10 +120,10 @@ option, and should be able to run the automatic test procedures.
|
|||||||
<h2 id=thanks>Special thanks</h2>
|
<h2 id=thanks>Special thanks</h2>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
Throughout LuaSocket's history, many people gave sugestions that helped
|
Throughout LuaSocket's history, many people gave suggestions that helped
|
||||||
improve it. For that, I thank the Lua comunity.
|
improve it. For that, I thank the Lua community.
|
||||||
Special thanks go to
|
Special thanks go to
|
||||||
David Burgess, who has pushed the library to a new level of quality and
|
David Burgess, who has helped push the library to a new level of quality and
|
||||||
from whom I have learned a lot of stuff that doesn't show up in RFCs.
|
from whom I have learned a lot of stuff that doesn't show up in RFCs.
|
||||||
Special thanks also to Carlos Cassino, who played a big part in the
|
Special thanks also to Carlos Cassino, who played a big part in the
|
||||||
extensible design seen in the C core of LuaSocket 2.0.
|
extensible design seen in the C core of LuaSocket 2.0.
|
||||||
@ -127,28 +135,47 @@ extensible design seen in the C core of LuaSocket 2.0.
|
|||||||
|
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
Everything is new! Many changes for 2.0 happened in the C layer, which
|
<em>Everything</em> is new! Many changes for 2.0 happened in the C layer,
|
||||||
has been almost completely rewritten. The code has been ported to Lua 5.0
|
which has been almost completely rewritten. The code has been ported to
|
||||||
and greatly improved. There have also been some API changes
|
Lua 5.0 and greatly improved. There have also been some API changes
|
||||||
that made the interface simpler and more consistent. Here are some of
|
that made the interface simpler and more consistent. Here are some of
|
||||||
the changes that made it into version 2.0:
|
the changes that made it into version 2.0:
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<ul>
|
<ul>
|
||||||
<li> Major C code rewrite. Code is modular and extensible. Hopefully, next
|
<li> Major C code rewrite. Code is modular and extensible. Hopefully, other
|
||||||
versions will include code for local domain sockets, file descriptors,
|
developers will be motivated to provide code for SSL, local domain
|
||||||
pipes (on Unix) and named pipes (on windows) as a bonus;
|
sockets, file descriptors, pipes (on Unix) and named pipes etc;
|
||||||
|
|
||||||
<li> Following the Lua 5.0 trend, all functions provided by the library are
|
<li> Everything that is exported by the library is exported inside
|
||||||
in namespaces. These should be obtained with calls to the
|
namespaces. These should be obtained with calls to the
|
||||||
<tt>require</tt> function. Functions such as
|
<tt>require</tt> function;
|
||||||
|
|
||||||
|
<li> Functions such as
|
||||||
send/receive/timeout/close etc do not exist anymore as stand-alone
|
send/receive/timeout/close etc do not exist anymore as stand-alone
|
||||||
functions. They are now only available as methods of the appropriate
|
functions. They are now only available as methods of the appropriate
|
||||||
objects;
|
objects;
|
||||||
|
|
||||||
<li> All functions return a non-nil value as first return value if successful.
|
<li> All functions return a non-nil value as first return value if successful.
|
||||||
All functions return <b><tt>nil</tt></b> followed by error message
|
All functions return <b><tt>nil</tt></b> followed by error message
|
||||||
in case of error;
|
in case of error. This made the library much easier to use;
|
||||||
|
|
||||||
|
<li> Greatly reduced the number of times the C select is called
|
||||||
|
during data transfers, by calling only on failure. This might
|
||||||
|
improve a lot the maximum throughput;
|
||||||
|
|
||||||
|
<li> TCP has been changed to become more uniform. It's possible to first
|
||||||
|
create a TCP object,
|
||||||
|
then connect or bind if needed, and finally use I/O functions.
|
||||||
|
<tt>socket.connect</tt> and <tt>socket.bind</tt> functions are still
|
||||||
|
provided for simplicity;
|
||||||
|
|
||||||
|
<li> This allows for setting a timeout value before connecting;
|
||||||
|
|
||||||
|
<li> And also allows binding to a local address before connecting;
|
||||||
|
|
||||||
|
<li> New <tt>socket.dns.gethostname</tt> function and <tt>shutdown</tt>
|
||||||
|
method;
|
||||||
|
|
||||||
<li> Better error messages and parameter checking;
|
<li> Better error messages and parameter checking;
|
||||||
|
|
||||||
@ -157,20 +184,9 @@ the changes that made it into version 2.0:
|
|||||||
<li> UDP connected sockets can break association with peer by calling
|
<li> UDP connected sockets can break association with peer by calling
|
||||||
<tt>setpeername</tt> with address '<tt>*</tt>';
|
<tt>setpeername</tt> with address '<tt>*</tt>';
|
||||||
|
|
||||||
<li> TCP has been changed to become more uniform. First create an object,
|
<li> Sets returned by <tt>socket.select</tt> are associative;
|
||||||
then connect or bind if needed, and finally use I/O functions. The
|
|
||||||
<tt>socket.connect</tt> and <tt>socket.bind</tt> functions are still
|
|
||||||
provided for simplicity, but they just call <tt>socket.tcp</tt> followed
|
|
||||||
by the <tt>connect</tt> or <tt>bind/listen</tt> methods;
|
|
||||||
|
|
||||||
<li> Greatly reduced the number of times select is called during data
|
<li> Select checks if sockets have buffered data and returns immediately;
|
||||||
transfers, by calling only on failure;
|
|
||||||
|
|
||||||
<li> TCP can set timeout value before connecting and also bind to local
|
|
||||||
address before connecting;
|
|
||||||
|
|
||||||
<li> <tt>socket.select</tt> returns associative sets and checks if
|
|
||||||
sockets had buffered data;
|
|
||||||
|
|
||||||
<li> <tt>socket.sleep</tt> and <tt>socket.time</tt> are now part of the
|
<li> <tt>socket.sleep</tt> and <tt>socket.time</tt> are now part of the
|
||||||
library and are supported. They used to be available only when
|
library and are supported. They used to be available only when
|
||||||
@ -182,7 +198,7 @@ the changes that made it into version 2.0:
|
|||||||
high-level modules;
|
high-level modules;
|
||||||
|
|
||||||
<li> Socket options interface has been improved. TCP objects also
|
<li> Socket options interface has been improved. TCP objects also
|
||||||
support socket options and many other options were added.
|
support socket options and many new options were added.
|
||||||
|
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
@ -191,12 +207,23 @@ Lots of changes in the Lua modules, too!
|
|||||||
</p>
|
</p>
|
||||||
|
|
||||||
<ul>
|
<ul>
|
||||||
|
<li> Every module loads only the modules that it needs. There is no waste
|
||||||
|
of memory. LuaSocket core takes only 20k of memory;
|
||||||
|
|
||||||
<li> New MIME and LTN12 modules make all other modules much more powerful;
|
<li> New MIME and LTN12 modules make all other modules much more powerful;
|
||||||
|
|
||||||
<li> Support for multipart messages in the SMTP module;
|
<li> Support for multipart messages in the SMTP module;
|
||||||
<li> The old callback mechanism of FTP and HTTP has been replaced with LTN12 sources and sinks,
|
|
||||||
with advantage;
|
<li> The old callback mechanism of FTP and HTTP has been replaced with LTN12 sources and sinks, with advantage;
|
||||||
|
|
||||||
|
<li> Common implementation for low-level FTP and SMTP;
|
||||||
|
|
||||||
<li> FTP, HTTP, and SMTP are implemented in multiple levels in such a way
|
<li> FTP, HTTP, and SMTP are implemented in multiple levels in such a way
|
||||||
that users will have no problems extending the functionality.
|
that users will have no problems extending the functionality to satisfy
|
||||||
|
personal needs;
|
||||||
|
|
||||||
|
<li> SMTP knows how to perform LOGIN and PLAIN authentication.
|
||||||
|
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<!-- incompatible +++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
<!-- incompatible +++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
||||||
@ -208,7 +235,7 @@ that users will have no problems extending the functionality.
|
|||||||
<li> The introduction of namespaces affects all programs that use LuaSocket,
|
<li> The introduction of namespaces affects all programs that use LuaSocket,
|
||||||
specially code that relies on global functions. These are no longer
|
specially code that relies on global functions. These are no longer
|
||||||
available. Note that even the support modules (<tt>http</tt>, <tt>smtp</tt>
|
available. Note that even the support modules (<tt>http</tt>, <tt>smtp</tt>
|
||||||
etc) are independent now and should be "<tt>require</tt>ed";
|
etc) are independent now and should be "<tt>require</tt>"d;
|
||||||
|
|
||||||
<li> FTP, SMTP and HTTP are completely new; I am sure you will
|
<li> FTP, SMTP and HTTP are completely new; I am sure you will
|
||||||
agree the new stuff is better;
|
agree the new stuff is better;
|
||||||
|
@ -35,14 +35,22 @@
|
|||||||
|
|
||||||
<h2>Introduction</h2>
|
<h2>Introduction</h2>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
LuaSocket is a <a href="http://www.lua.org">Lua</a> extension library
|
||||||
|
that is composed by two parts: a C core that provides support for the TCP
|
||||||
|
and UDP transport layers, and a set of Lua modules that add support for
|
||||||
|
the SMTP (sending e-mails), HTTP (WWW access) and FTP (uploading and
|
||||||
|
downloading files) protocols and other functionality commonly needed by
|
||||||
|
applications that deal with the Internet. This introduction is about the C
|
||||||
|
core.
|
||||||
|
</p>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
Communication in LuaSocket is performed via I/O objects. These can
|
Communication in LuaSocket is performed via I/O objects. These can
|
||||||
represent different network domains. Currently, support is provided for TCP
|
represent different network domains. Currently, support is provided for TCP
|
||||||
and UDP, but nothing prevents other developers from implementing SSL, Local
|
and UDP, but nothing prevents other developers from implementing SSL, Local
|
||||||
Domain, Pipes, File Descriptors etc. I/O objects provide a standard
|
Domain, Pipes, File Descriptors etc. I/O objects provide a standard
|
||||||
interface to I/O across different domains and operating systems.
|
interface to I/O across different domains and operating systems.
|
||||||
LuaSocket 2.0 has been rewritten from scratch to simplify the future
|
|
||||||
addition of new domains.
|
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
@ -52,8 +60,17 @@ Second, the simplicity and the feel of the Lua language should be
|
|||||||
preserved. To achieve these goals, the LuaSocket API keeps the function names and semantics the C API whenever possible, but their usage in Lua has been greatly simplified.
|
preserved. To achieve these goals, the LuaSocket API keeps the function names and semantics the C API whenever possible, but their usage in Lua has been greatly simplified.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
One of the simplifications is the timeout control
|
One of the simplifications is the receive pattern capability.
|
||||||
|
Applications can read data from stream domains (such as TCP)
|
||||||
|
line by line, block by block, or until the connection is closed.
|
||||||
|
All I/O reads are buffered and the performance differences between
|
||||||
|
different receive patterns are negligible.
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
Another advantage is the flexible timeout control
|
||||||
mechanism. As in C, all I/O operations are blocking by default. For
|
mechanism. As in C, all I/O operations are blocking by default. For
|
||||||
example, the <a href=tcp.html#send><tt>send</tt></a>,
|
example, the <a href=tcp.html#send><tt>send</tt></a>,
|
||||||
<a href=tcp.html#receive><tt>receive</tt></a> and
|
<a href=tcp.html#receive><tt>receive</tt></a> and
|
||||||
@ -69,14 +86,6 @@ call might perform several OS calls, so that the two timeout values are
|
|||||||
<em>not</em> equivalent.
|
<em>not</em> equivalent.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p>
|
|
||||||
Another important difference is the receive pattern capability.
|
|
||||||
Applications can read data from stream domains (such as TCP)
|
|
||||||
line by line, block by block, or until the connection is closed.
|
|
||||||
All I/O reads are buffered and the performance differences between
|
|
||||||
different receive patterns are negligible.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
Finally, the host name resolution is transparent, meaning that most
|
Finally, the host name resolution is transparent, meaning that most
|
||||||
functions and methods accept both IP addresses and host names. In case a
|
functions and methods accept both IP addresses and host names. In case a
|
||||||
@ -89,13 +98,8 @@ functions from the DNS module are provided to convert between host names and IP
|
|||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
Previous versions of LuaSocket provided global functions for operating on
|
Together, these changes make network programming in LuaSocket much simpler
|
||||||
I/O objects. To give the library a Lua 5.0 feel, these have been eliminated
|
than it is in C, as the following sections will show.
|
||||||
from LuaSocket 2.0. I/O operations are only available as methods of the
|
|
||||||
corresponding I/O objects. Naturally, different I/O objects accept
|
|
||||||
different operations. The TCP and UDP objects are
|
|
||||||
introduced in the following sections, following a few words about
|
|
||||||
initialization.
|
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<!-- initializing +++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
<!-- initializing +++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
||||||
@ -103,13 +107,14 @@ initialization.
|
|||||||
<h3>Initializing the library</h3>
|
<h3>Initializing the library</h3>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
The core LuaSocket functionality is implemented in C, and usually available as
|
The core LuaSocket is almost entirely implemented in C. It is
|
||||||
a dynamic library which the interpreter can load when required.
|
usually available as a dynamic library which the interpreter can load
|
||||||
|
with the help of a loader module written in Lua.
|
||||||
Beginning with version 2.0 and following the Lua 5.0 trend, all LuaSocket
|
Beginning with version 2.0 and following the Lua 5.0 trend, all LuaSocket
|
||||||
functionality is defined inside a tables (or rather a namespaces). No global
|
functionality is defined inside tables (or rather a namespaces). No global
|
||||||
variables are ever created.
|
variables are ever created.
|
||||||
Namespaces are obtained with the <tt>require</tt> Lua function, which loads
|
Namespaces are obtained with the <tt>require</tt> Lua function, which loads
|
||||||
and initializes any required libraries and return the namespace.
|
and initializes any required library and returns the namespace.
|
||||||
For example, the core functionality or LuaSocket is usually available
|
For example, the core functionality or LuaSocket is usually available
|
||||||
from the "<tt>socket</tt>" namespace.
|
from the "<tt>socket</tt>" namespace.
|
||||||
</p>
|
</p>
|
||||||
@ -130,13 +135,14 @@ words, applications communicating through TCP can send and receive data as
|
|||||||
an error free stream of bytes. Data is split in one end and
|
an error free stream of bytes. Data is split in one end and
|
||||||
reassembled transparently on the other end. There are no boundaries in
|
reassembled transparently on the other end. There are no boundaries in
|
||||||
the data transfers. The library allows users to read data from the
|
the data transfers. The library allows users to read data from the
|
||||||
sockets in several different granularity: patterns are available for
|
sockets in several different granularities: patterns are available for
|
||||||
lines, arbitrary sized blocks or "read up to connection closed", all with
|
lines, arbitrary sized blocks or "read up to connection closed", all with
|
||||||
good performance.
|
good performance.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
The library distinguishes three types of TCP sockets: master, client and server sockets.
|
The library distinguishes three types of TCP sockets: <em>master</em>,
|
||||||
|
<em>client</em> and <em>server</em> sockets.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
@ -144,10 +150,11 @@ Master sockets are newly created TCP sockets returned by the function
|
|||||||
<a href=tcp.html#tcp><tt>socket.tcp</tt></a>. A master socket is
|
<a href=tcp.html#tcp><tt>socket.tcp</tt></a>. A master socket is
|
||||||
transformed into a server socket
|
transformed into a server socket
|
||||||
after it is associated with a <em>local</em> address by a call to the
|
after it is associated with a <em>local</em> address by a call to the
|
||||||
<a href=tcp.html#bind><tt>bind</tt></a> method. Conversely, it
|
<a href=tcp.html#bind><tt>bind</tt></a> method followed by a call to the
|
||||||
|
<a href=tcp.html#listen><tt>listen</tt></a>. Conversely, a master socket
|
||||||
can be changed into a client socket with the method
|
can be changed into a client socket with the method
|
||||||
<a href=tcp.html#connect><tt>connect</tt></a>,
|
<a href=tcp.html#connect><tt>connect</tt></a>,
|
||||||
that associates it with a <em>remote</em> address.
|
which associates it with a <em>remote</em> address.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
@ -158,7 +165,7 @@ client socket object is returned representing this connection. The
|
|||||||
other methods available for server socket objects are
|
other methods available for server socket objects are
|
||||||
<a href=tcp.html#getsockname><tt>getsockname</tt></a>,
|
<a href=tcp.html#getsockname><tt>getsockname</tt></a>,
|
||||||
<a href=tcp.html#setoption><tt>setoption</tt></a>,
|
<a href=tcp.html#setoption><tt>setoption</tt></a>,
|
||||||
<a href=tcp.html#settimeout><tt>settimeout</tt></a> and
|
<a href=tcp.html#settimeout><tt>settimeout</tt></a>, and
|
||||||
<a href=tcp.html#close><tt>close</tt></a>.
|
<a href=tcp.html#close><tt>close</tt></a>.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
@ -172,7 +179,8 @@ available for client socket objects are
|
|||||||
<a href=tcp.html#getsockname><tt>getsockname</tt></a>,
|
<a href=tcp.html#getsockname><tt>getsockname</tt></a>,
|
||||||
<a href=tcp.html#getpeername><tt>getpeername</tt></a>,
|
<a href=tcp.html#getpeername><tt>getpeername</tt></a>,
|
||||||
<a href=tcp.html#setoption><tt>setoption</tt></a>,
|
<a href=tcp.html#setoption><tt>setoption</tt></a>,
|
||||||
<a href=tcp.html#settimeout><tt>settimeout</tt></a> and
|
<a href=tcp.html#settimeout><tt>settimeout</tt></a>,
|
||||||
|
<a href=tcp.html#shutdown><tt>shutdown</tt></a>, and
|
||||||
<a href=tcp.html#close><tt>close</tt></a>.
|
<a href=tcp.html#close><tt>close</tt></a>.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
@ -185,7 +193,7 @@ A simple echo server, using LuaSocket. The program binds to an ephemeral
|
|||||||
port (one that is chosen by the operating system) on the local host and
|
port (one that is chosen by the operating system) on the local host and
|
||||||
awaits client connections on that port. When a connection is established,
|
awaits client connections on that port. When a connection is established,
|
||||||
the program reads a line from the remote end and sends it back, closing
|
the program reads a line from the remote end and sends it back, closing
|
||||||
the connection immediately after. You can test it using the telnet
|
the connection immediately. You can test it using the telnet
|
||||||
program.
|
program.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
@ -231,6 +239,12 @@ simplicity (no connection setup) and performance (no error checking or
|
|||||||
error correction).
|
error correction).
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
Note that although no guarantees are made, these days
|
||||||
|
networks are so good that, under normal circumstances, few errors
|
||||||
|
happen in practice.
|
||||||
|
</p>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
An UDP socket object is created by the
|
An UDP socket object is created by the
|
||||||
<a href=udp.html#udp><tt>socket.udp</tt></a> function. UDP
|
<a href=udp.html#udp><tt>socket.udp</tt></a> function. UDP
|
||||||
@ -288,14 +302,13 @@ error message.
|
|||||||
|
|
||||||
<pre class=example>
|
<pre class=example>
|
||||||
-- change here to the host an port you want to contact
|
-- change here to the host an port you want to contact
|
||||||
host = "localhost"
|
local host, port = "localhost", 13
|
||||||
port = 13
|
|
||||||
-- load namespace
|
-- load namespace
|
||||||
local socket = require("socket")
|
local socket = require("socket")
|
||||||
-- convert host name to ip address
|
-- convert host name to ip address
|
||||||
local ip = socket.try(socket.dns.toip(host))
|
local ip = socket.try(socket.dns.toip(host))
|
||||||
-- create a new UDP object
|
-- create a new UDP object
|
||||||
local udp = socket.udp()
|
local udp = socket.try(socket.udp())
|
||||||
-- contact daytime host
|
-- contact daytime host
|
||||||
socket.try(udp:sendto("anything", ip, port))
|
socket.try(udp:sendto("anything", ip, port))
|
||||||
-- retrieve the answer and print results
|
-- retrieve the answer and print results
|
||||||
|
@ -35,13 +35,21 @@
|
|||||||
|
|
||||||
<h2 id=ltn12>LTN12</h2>
|
<h2 id=ltn12>LTN12</h2>
|
||||||
|
|
||||||
<p> The LTN12 module implements the ideas described in
|
<p> The <tt>ltn12</tt> namespace implements the ideas described in
|
||||||
<a href="http://lua-users.org/wiki/FiltersSourcesAndSinks">
|
<a href="http://lua-users.org/wiki/FiltersSourcesAndSinks">
|
||||||
LTN012, Filters sources and sinks</a>. This manual simply describe the
|
LTN012, Filters sources and sinks</a>. This manual simply describes the
|
||||||
functions. Please refer to the LTN for a deeper explanation of the
|
functions. Please refer to the LTN for a deeper explanation of the
|
||||||
functionality provided by this module.
|
functionality provided by this module.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
<p class=description> To obtain the <tt>ltn12</tt> namespace, run:
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<pre class=example>
|
||||||
|
-- loads the LTN21 module
|
||||||
|
local ltn12 = require("ltn12")
|
||||||
|
</pre>
|
||||||
|
|
||||||
<!-- filters ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
<!-- filters ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
||||||
|
|
||||||
<h3 id="filter">Filters</h3>
|
<h3 id="filter">Filters</h3>
|
||||||
@ -68,15 +76,15 @@ The function returns the chained filter.
|
|||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=note>
|
<p class=note>
|
||||||
The nesting of filters can be arbritrary. For instance, the useless filter
|
The nesting of filters can be arbitrary. For instance, the useless filter
|
||||||
below doesn't do anything but return the data that was passed to it,
|
below doesn't do anything but return the data that was passed to it,
|
||||||
unaltered.
|
unaltered.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<pre class=example>
|
<pre class=example>
|
||||||
-- load required modules
|
-- load required modules
|
||||||
ltn12 = require("ltn12")
|
local ltn12 = require("ltn12")
|
||||||
mime = require("mime")
|
local mime = require("mime")
|
||||||
|
|
||||||
-- create a silly identity filter
|
-- create a silly identity filter
|
||||||
id = ltn12.filter.chain(
|
id = ltn12.filter.chain(
|
||||||
@ -165,12 +173,7 @@ ltn12.sink.<b>chain(</b>filter, sink<b>)</b>
|
|||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=description>
|
<p class=description>
|
||||||
Creates a new sink that passes data through a <tt>filter</tt> before sending
|
Creates and returns a new sink that passes data through a <tt>filter</tt> before sending it to a given <tt>sink</tt>.
|
||||||
it to a given <tt>sink</tt>.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p class=return>
|
|
||||||
The function returns the new sink.
|
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<!-- error ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
<!-- error ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
||||||
@ -180,7 +183,7 @@ ltn12.sink.<b>error(</b>message<b>)</b>
|
|||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=description>
|
<p class=description>
|
||||||
Creates and returns a sink that aborts transmission with an error
|
Creates and returns a sink that aborts transmission with the error
|
||||||
<tt>message</tt>.
|
<tt>message</tt>.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
@ -202,7 +205,7 @@ Creates a sink that sends data to a file.
|
|||||||
<p class=return>
|
<p class=return>
|
||||||
The function returns a sink that sends all data to the given <tt>handle</tt>
|
The function returns a sink that sends all data to the given <tt>handle</tt>
|
||||||
and closes the file when done, or a sink that aborts the transmission with
|
and closes the file when done, or a sink that aborts the transmission with
|
||||||
an error <tt>message</tt>
|
the error <tt>message</tt>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=note>
|
<p class=note>
|
||||||
@ -258,7 +261,7 @@ efficiently concatenated into a single string.
|
|||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=return>
|
<p class=return>
|
||||||
The function returns the sink and the table.
|
The function returns the sink and the table used to store the chunks.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<pre class=example>
|
<pre class=example>
|
||||||
@ -266,14 +269,14 @@ The function returns the sink and the table.
|
|||||||
local http = require("http")
|
local http = require("http")
|
||||||
local ltn12 = require("ltn12")
|
local ltn12 = require("ltn12")
|
||||||
|
|
||||||
-- the http.get function
|
-- a simplified http.get function
|
||||||
function get(u)
|
function http.get(u)
|
||||||
local t = {}
|
local t = {}
|
||||||
local respt = request{
|
local respt = request{
|
||||||
url = u,
|
url = u,
|
||||||
sink = ltn12.sink.table(t)
|
sink = ltn12.sink.table(t)
|
||||||
}
|
}
|
||||||
return table.concat(t), respt.headers, respt.code, respt.error
|
return table.concat(t), respt.headers, respt.code
|
||||||
end
|
end
|
||||||
</pre>
|
</pre>
|
||||||
|
|
||||||
@ -334,7 +337,7 @@ ltn12.source.<b>error(</b>message<b>)</b>
|
|||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=description>
|
<p class=description>
|
||||||
Creates and returns a source that aborts transmission with an error
|
Creates and returns a source that aborts transmission with the error
|
||||||
<tt>message</tt>.
|
<tt>message</tt>.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
@ -357,7 +360,7 @@ Creates a source that produces the contents of a file.
|
|||||||
The function returns a source that reads chunks of data from
|
The function returns a source that reads chunks of data from
|
||||||
given <tt>handle</tt> and returns it to the user,
|
given <tt>handle</tt> and returns it to the user,
|
||||||
closing the file when done, or a source that aborts the transmission with
|
closing the file when done, or a source that aborts the transmission with
|
||||||
an error <tt>message</tt>
|
the error <tt>message</tt>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=note>
|
<p class=note>
|
||||||
|
@ -36,7 +36,7 @@
|
|||||||
<h2 id=mime>MIME</h2>
|
<h2 id=mime>MIME</h2>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
The MIME module offers filters that apply and remove common
|
The <tt>mime</tt> namespace offers filters that apply and remove common
|
||||||
content transfer encodings, such as Base64 and Quoted-Printable.
|
content transfer encodings, such as Base64 and Quoted-Printable.
|
||||||
It also provides functions to break text into lines and change
|
It also provides functions to break text into lines and change
|
||||||
the end-of-line convention.
|
the end-of-line convention.
|
||||||
@ -55,6 +55,15 @@ follows the ideas presented in
|
|||||||
LTN012, Filters sources and sinks</a>.
|
LTN012, Filters sources and sinks</a>.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
<p class=description> To obtain the <tt>mime</tt> namespace, run:
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<pre class=example>
|
||||||
|
-- loads the MIME module and everything it requires
|
||||||
|
local mime = require("mime")
|
||||||
|
</pre>
|
||||||
|
|
||||||
|
|
||||||
<!-- High-level +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
<!-- High-level +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
||||||
|
|
||||||
<h3 id=high>High-level filters</h3>
|
<h3 id=high>High-level filters</h3>
|
||||||
@ -108,7 +117,7 @@ The function returns the created filter.
|
|||||||
|
|
||||||
<p class=name id="encode">
|
<p class=name id="encode">
|
||||||
mime.<b>encode(</b>"base64"<b>)</b><br>
|
mime.<b>encode(</b>"base64"<b>)</b><br>
|
||||||
mime.<b>encode(</b>"quoted-printable" [, mode])</b>
|
mime.<b>encode(</b>"quoted-printable" [, mode]<b>)</b>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=description>
|
<p class=description>
|
||||||
@ -278,7 +287,7 @@ that can be encoded unambiguously. <tt>B</tt> has the remaining bytes of
|
|||||||
<tt>C..D</tt>, <em>before</em> encoding.
|
<tt>C..D</tt>, <em>before</em> encoding.
|
||||||
If <tt>D</tt> is <tt><b>nil</b></tt>, <tt>A</tt> is padded with
|
If <tt>D</tt> is <tt><b>nil</b></tt>, <tt>A</tt> is padded with
|
||||||
the encoding of the remaining bytes of <tt>C</tt>.
|
the encoding of the remaining bytes of <tt>C</tt>.
|
||||||
Throughout encoding, occurences of CRLF are replaced by the
|
Throughout encoding, occurrences of CRLF are replaced by the
|
||||||
<tt>marker</tt>, which itself defaults to CRLF.
|
<tt>marker</tt>, which itself defaults to CRLF.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
@ -152,7 +152,6 @@
|
|||||||
<a href="socket.html#version">VERSION</a>.
|
<a href="socket.html#version">VERSION</a>.
|
||||||
</blockquote>
|
</blockquote>
|
||||||
</blockquote>
|
</blockquote>
|
||||||
</table>
|
|
||||||
|
|
||||||
<!-- tcp +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
<!-- tcp +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
||||||
|
|
||||||
|
@ -105,6 +105,8 @@ smtp.<b>send{</b><br>
|
|||||||
from = <i>string</i>,<br>
|
from = <i>string</i>,<br>
|
||||||
rcpt = <i>string</i> or <i>string-table</i>,<br>
|
rcpt = <i>string</i> or <i>string-table</i>,<br>
|
||||||
source = <i>LTN12 source</i>,<br>
|
source = <i>LTN12 source</i>,<br>
|
||||||
|
[user = <i>string</i>],<br>
|
||||||
|
[password = <i>string</i>],<br>
|
||||||
[server = <i>string</i>],<br>
|
[server = <i>string</i>],<br>
|
||||||
[port = <i>string</i>]<br>
|
[port = <i>string</i>]<br>
|
||||||
[domain = <i>string</i>],<br>
|
[domain = <i>string</i>],<br>
|
||||||
@ -127,7 +129,11 @@ address, or a string
|
|||||||
in case there is just one recipient.
|
in case there is just one recipient.
|
||||||
The contents of the message are given by a <em>simple</em> LTN12 <tt>source</tt>. Several
|
The contents of the message are given by a <em>simple</em> LTN12 <tt>source</tt>. Several
|
||||||
arguments are optional:
|
arguments are optional:
|
||||||
|
</p>
|
||||||
<ul>
|
<ul>
|
||||||
|
<li> <tt>user</tt>, <tt>password</tt>: User and password for
|
||||||
|
authentication. The function will attempt LOGIN and PLAIN authentication
|
||||||
|
methods if supported by the server (both are unsafe);
|
||||||
<li> <tt>server</tt>: Server to connect to. Defaults to "localhost";
|
<li> <tt>server</tt>: Server to connect to. Defaults to "localhost";
|
||||||
<li> <tt>port</tt>: Port to connect to. Defaults to 25;
|
<li> <tt>port</tt>: Port to connect to. Defaults to 25;
|
||||||
<li> <tt>domain</tt>: Domain name used to greet the server; Defaults to the
|
<li> <tt>domain</tt>: Domain name used to greet the server; Defaults to the
|
||||||
@ -135,7 +141,6 @@ local machine host name;
|
|||||||
<li> <tt>step</tt>: LTN12 pump step function used to pass data from the
|
<li> <tt>step</tt>: LTN12 pump step function used to pass data from the
|
||||||
source to the server. Defaults to the LTN12 <tt>pump.step</tt> function.
|
source to the server. Defaults to the LTN12 <tt>pump.step</tt> function.
|
||||||
</ul>
|
</ul>
|
||||||
</p>
|
|
||||||
|
|
||||||
<p class=return>
|
<p class=return>
|
||||||
If successful, the function returns 1. Otherwise, the function returns
|
If successful, the function returns 1. Otherwise, the function returns
|
||||||
@ -293,7 +298,7 @@ and an epilogue.
|
|||||||
|
|
||||||
<p class=return>
|
<p class=return>
|
||||||
The function returns a <em>simple</em> LTN12 source that produces the
|
The function returns a <em>simple</em> LTN12 source that produces the
|
||||||
message contents as defined by <tt>mesgt</tt>. Hopefuly, the following
|
message contents as defined by <tt>mesgt</tt>. Hopefully, the following
|
||||||
example will make things clear. When in doubt, refer to the appropriate RFC
|
example will make things clear. When in doubt, refer to the appropriate RFC
|
||||||
as listed in the introduction. </p>
|
as listed in the introduction. </p>
|
||||||
|
|
||||||
|
@ -164,7 +164,7 @@ source from a stream socket object.
|
|||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=parameters>
|
<p class=parameters>
|
||||||
<tt>Mode</tt> defines the behaviour of the source. The following
|
<tt>Mode</tt> defines the behavior of the source. The following
|
||||||
options are available:
|
options are available:
|
||||||
</p>
|
</p>
|
||||||
<ul>
|
<ul>
|
||||||
@ -194,15 +194,16 @@ Throws an exception in case of error.
|
|||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=parameters>
|
<p class=parameters>
|
||||||
</b>Ret<sub>1</sub>, ret<sub>2</sub> ... ret<sub>N</sub> can be arbitrary
|
<tt>Ret</tt><sub>1</sub>, <tt>ret</tt><sub>2</sub> ... <tt>ret</tt><sub>N</sub> can be arbitrary
|
||||||
arguments, but are usually the return values of a function call that
|
arguments, but are usually the return values of a function call that
|
||||||
nested with the call to <tt>try</tt>.
|
nested with the call to <tt>try</tt>.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p class=return>
|
<p class=return>
|
||||||
The function returns ret<sub>1</sub>, ret<sub>2</sub> ... ret<sub>N</sub> if
|
The function returns <tt>ret</tt><sub>1</sub>, <tt>ret</tt><sub>2</sub> ...
|
||||||
ret<sub>1</sub> is not <tt><b>nil</b></tt>. Otherwise, calls <tt>error</tt>
|
<tt>ret</tt><sub>N</sub> if
|
||||||
passing ret<sub>2</sub>.
|
<tt>ret</tt><sub>1</sub> is not <tt><b>nil</b></tt>. Otherwise, calls <tt>error</tt>
|
||||||
|
passing <tt>ret</tt><sub>2</sub>.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<pre class=example>
|
<pre class=example>
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
-----------------------------------------------------------------------------
|
||||||
|
-- Little program to convert to and from Base64
|
||||||
|
-- LuaSocket sample files
|
||||||
|
-- Author: Diego Nehab
|
||||||
|
-- RCS ID: $Id$
|
||||||
|
-----------------------------------------------------------------------------
|
||||||
local ltn12 = require("ltn12")
|
local ltn12 = require("ltn12")
|
||||||
local mime = require("mime")
|
local mime = require("mime")
|
||||||
local source = ltn12.source.file(io.stdin)
|
local source = ltn12.source.file(io.stdin)
|
||||||
|
@ -71,7 +71,7 @@ local function get_ERROR(dgram)
|
|||||||
end
|
end
|
||||||
|
|
||||||
-----------------------------------------------------------------------------
|
-----------------------------------------------------------------------------
|
||||||
-- High level TFTP API
|
-- The real work
|
||||||
-----------------------------------------------------------------------------
|
-----------------------------------------------------------------------------
|
||||||
local function tget(gett)
|
local function tget(gett)
|
||||||
local retries, dgram, sent, datahost, dataport, code
|
local retries, dgram, sent, datahost, dataport, code
|
||||||
|
@ -23,6 +23,7 @@ BLOCKSIZE = 2048
|
|||||||
-----------------------------------------------------------------------------
|
-----------------------------------------------------------------------------
|
||||||
-- returns a high level filter that cycles a low-level filter
|
-- returns a high level filter that cycles a low-level filter
|
||||||
function filter.cycle(low, ctx, extra)
|
function filter.cycle(low, ctx, extra)
|
||||||
|
assert(low)
|
||||||
return function(chunk)
|
return function(chunk)
|
||||||
local ret
|
local ret
|
||||||
ret, ctx = low(ctx, chunk, extra)
|
ret, ctx = low(ctx, chunk, extra)
|
||||||
@ -32,6 +33,7 @@ end
|
|||||||
|
|
||||||
-- chains two filters together
|
-- chains two filters together
|
||||||
local function chain2(f1, f2)
|
local function chain2(f1, f2)
|
||||||
|
assert(f1 and f2)
|
||||||
local co = coroutine.create(function(chunk)
|
local co = coroutine.create(function(chunk)
|
||||||
while true do
|
while true do
|
||||||
local filtered1 = f1(chunk)
|
local filtered1 = f1(chunk)
|
||||||
@ -95,6 +97,7 @@ end
|
|||||||
|
|
||||||
-- turns a fancy source into a simple source
|
-- turns a fancy source into a simple source
|
||||||
function source.simplify(src)
|
function source.simplify(src)
|
||||||
|
assert(src)
|
||||||
return function()
|
return function()
|
||||||
local chunk, err_or_new = src()
|
local chunk, err_or_new = src()
|
||||||
src = err_or_new or src
|
src = err_or_new or src
|
||||||
@ -118,6 +121,7 @@ end
|
|||||||
|
|
||||||
-- creates rewindable source
|
-- creates rewindable source
|
||||||
function source.rewind(src)
|
function source.rewind(src)
|
||||||
|
assert(src)
|
||||||
local t = {}
|
local t = {}
|
||||||
return function(chunk)
|
return function(chunk)
|
||||||
if not chunk then
|
if not chunk then
|
||||||
@ -132,6 +136,7 @@ end
|
|||||||
|
|
||||||
-- chains a source with a filter
|
-- chains a source with a filter
|
||||||
function source.chain(src, f)
|
function source.chain(src, f)
|
||||||
|
assert(src and f)
|
||||||
local co = coroutine.create(function()
|
local co = coroutine.create(function()
|
||||||
while true do
|
while true do
|
||||||
local chunk, err = src()
|
local chunk, err = src()
|
||||||
@ -186,6 +191,7 @@ end
|
|||||||
|
|
||||||
-- turns a fancy sink into a simple sink
|
-- turns a fancy sink into a simple sink
|
||||||
function sink.simplify(snk)
|
function sink.simplify(snk)
|
||||||
|
assert(snk)
|
||||||
return function(chunk, err)
|
return function(chunk, err)
|
||||||
local ret, err_or_new = snk(chunk, err)
|
local ret, err_or_new = snk(chunk, err)
|
||||||
if not ret then return nil, err_or_new end
|
if not ret then return nil, err_or_new end
|
||||||
@ -224,6 +230,7 @@ end
|
|||||||
|
|
||||||
-- chains a sink with a filter
|
-- chains a sink with a filter
|
||||||
function sink.chain(f, snk)
|
function sink.chain(f, snk)
|
||||||
|
assert(f and snk)
|
||||||
return function(chunk, err)
|
return function(chunk, err)
|
||||||
local filtered = f(chunk)
|
local filtered = f(chunk)
|
||||||
local done = chunk and ""
|
local done = chunk and ""
|
||||||
@ -248,6 +255,7 @@ end
|
|||||||
|
|
||||||
-- pumps all data from a source to a sink, using a step function
|
-- pumps all data from a source to a sink, using a step function
|
||||||
function pump.all(src, snk, step)
|
function pump.all(src, snk, step)
|
||||||
|
assert(src and snk)
|
||||||
step = step or pump.step
|
step = step or pump.step
|
||||||
while true do
|
while true do
|
||||||
local ret, err = step(src, snk)
|
local ret, err = step(src, snk)
|
||||||
|
33
src/smtp.lua
33
src/smtp.lua
@ -11,6 +11,7 @@
|
|||||||
local smtp = requirelib("smtp", "luaopen_smtp", getfenv(1))
|
local smtp = requirelib("smtp", "luaopen_smtp", getfenv(1))
|
||||||
local socket = require("socket")
|
local socket = require("socket")
|
||||||
local ltn12 = require("ltn12")
|
local ltn12 = require("ltn12")
|
||||||
|
local mime = require("mime")
|
||||||
local tp = require("tp")
|
local tp = require("tp")
|
||||||
|
|
||||||
-----------------------------------------------------------------------------
|
-----------------------------------------------------------------------------
|
||||||
@ -43,7 +44,7 @@ local metat = { __index = {} }
|
|||||||
function metat.__index:greet(domain)
|
function metat.__index:greet(domain)
|
||||||
socket.try(self.tp:check("2.."))
|
socket.try(self.tp:check("2.."))
|
||||||
socket.try(self.tp:command("EHLO", domain or DOMAIN))
|
socket.try(self.tp:command("EHLO", domain or DOMAIN))
|
||||||
return socket.try(self.tp:check("2.."))
|
return socket.skip(1, socket.try(self.tp:check("2..")))
|
||||||
end
|
end
|
||||||
|
|
||||||
function metat.__index:mail(from)
|
function metat.__index:mail(from)
|
||||||
@ -73,6 +74,32 @@ function metat.__index:close()
|
|||||||
return socket.try(self.tp:close())
|
return socket.try(self.tp:close())
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function metat.__index:login(user, password)
|
||||||
|
socket.try(self.tp:command("AUTH", "LOGIN"))
|
||||||
|
socket.try(self.tp:check("3.."))
|
||||||
|
socket.try(self.tp:command(mime.b64(user)))
|
||||||
|
socket.try(self.tp:check("3.."))
|
||||||
|
socket.try(self.tp:command(mime.b64(password)))
|
||||||
|
return socket.try(self.tp:check("2.."))
|
||||||
|
end
|
||||||
|
|
||||||
|
function metat.__index:plain(user, password)
|
||||||
|
local auth = "PLAIN " .. mime.b64("\0" .. user .. "\0" .. password)
|
||||||
|
socket.try(self.tp:command("AUTH", auth))
|
||||||
|
return socket.try(self.tp:check("2.."))
|
||||||
|
end
|
||||||
|
|
||||||
|
function metat.__index:auth(user, password, ext)
|
||||||
|
if not user or not password then return 1 end
|
||||||
|
if string.find(ext, "AUTH[^\n]+LOGIN") then
|
||||||
|
return self:login(user, password)
|
||||||
|
elseif string.find(ext, "AUTH[^\n]+PLAIN") then
|
||||||
|
return self:plain(user, password)
|
||||||
|
else
|
||||||
|
socket.try(nil, "authentication not supported")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
-- send message or throw an exception
|
-- send message or throw an exception
|
||||||
function metat.__index:send(mailt)
|
function metat.__index:send(mailt)
|
||||||
self:mail(mailt.from)
|
self:mail(mailt.from)
|
||||||
@ -205,10 +232,10 @@ end
|
|||||||
---------------------------------------------------------------------------
|
---------------------------------------------------------------------------
|
||||||
-- High level SMTP API
|
-- High level SMTP API
|
||||||
-----------------------------------------------------------------------------
|
-----------------------------------------------------------------------------
|
||||||
socket.protect = function(a) return a end
|
|
||||||
send = socket.protect(function(mailt)
|
send = socket.protect(function(mailt)
|
||||||
local con = open(mailt.server, mailt.port)
|
local con = open(mailt.server, mailt.port)
|
||||||
con:greet(mailt.domain)
|
local ext = con:greet(mailt.domain)
|
||||||
|
con:auth(mailt.user, mailt.password, ext)
|
||||||
con:send(mailt)
|
con:send(mailt)
|
||||||
con:quit()
|
con:quit()
|
||||||
return con:close()
|
return con:close()
|
||||||
|
@ -8,7 +8,7 @@ local qptest = "qptest.bin"
|
|||||||
local eqptest = "qptest.bin2"
|
local eqptest = "qptest.bin2"
|
||||||
local dqptest = "qptest.bin3"
|
local dqptest = "qptest.bin3"
|
||||||
|
|
||||||
local b64test = "luasocket.so"
|
local b64test = "luasocket.dylib"
|
||||||
local eb64test = "b64test.bin"
|
local eb64test = "b64test.bin"
|
||||||
local db64test = "b64test.bin2"
|
local db64test = "b64test.bin2"
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user