Part of twisted.mail.pop3 View Source View In Hierarchy
Known subclasses: twisted.mail.protocols.VirtualPOP3
Implements interfaces: twisted.internet.interfaces.IProducer
Instance Variable | portal | A portal for authentication. (type: Portal ) |
Instance Variable | factory | A server factory which provides an interface for querying capabilities of
the server. (type: IServerFactory
provider) |
Instance Variable | timeOut | The number of seconds to wait for a command from the client before
disconnecting. (type: int ) |
Instance Variable | schedule | A callable that arranges for an iterator to be cooperatively iterated over
along with all other iterators which have been passed to it such that
runtime is divided between all of them. It returns a deferred which fires
when the iterator finishes. (type: callable that takes interator and returns Deferred ) |
Instance Variable | magic | An APOP challenge. If not set, an APOP challenge string will be generated
when a connection is made. (type: bytes
or NoneType ) |
Instance Variable | mbox | The mailbox for the authenticated user. (type: IMailbox
provider) |
Instance Variable | state | The state which indicates what type of messages are expected from the
client. Valid states are 'COMMAND' and 'AUTH' (type: bytes ) |
Instance Variable | blocked | A list of blocked commands. While a response to a command is being
generated by the server, other commands are blocked. When no command is
outstanding, blocked is set to none. Otherwise, it contains a
list of information about blocked commands. Each list entry consists of
the command and the arguments to the command. (type: NoneType
or list
of 2-tuple
of (1) bytes
(2) tuple
of bytes ) |
Method | connectionMade | Send a greeting to the client after the connection has been made. |
Method | connectionLost | Clean up when the connection has been lost. |
Method | generateMagic | Generate an APOP challenge. |
Method | successResponse | Send a response indicating success. |
Method | failResponse | Send a response indicating failure. |
Method | lineReceived | Pass a received line to a state machine function. |
Method | state_COMMAND | Handle received lines for the COMMAND state in which commands from the client are expected. |
Method | processCommand | Dispatch a command from the client for handling. |
Method | listCapabilities | Return a list of server capabilities suitable for use in a CAPA response. |
Method | do_CAPA | Handle a CAPA command. |
Method | do_AUTH | Handle an AUTH command. |
Method | state_AUTH | Handle received lines for the AUTH state in which an authentication challenge response from the client is expected. |
Method | do_APOP | Handle an APOP command. |
Method | do_USER | Handle a USER command. |
Method | do_PASS | Handle a PASS command. |
Method | do_STAT | Handle a STAT command. |
Method | do_LIST | Handle a LIST command. |
Method | do_UIDL | Handle a UIDL command. |
Method | do_TOP | Handle a TOP command. |
Method | do_RETR | Handle a RETR command. |
Method | transformChunk | Transform a chunk of a message to POP3 message format. |
Method | finishedFileTransfer | Send the termination sequence. |
Method | do_DELE | Handle a DELE command. |
Method | do_NOOP | Handle a NOOP command. |
Method | do_RSET | Handle a RSET command. |
Method | do_LAST | Handle a LAST command. |
Method | do_RPOP | Handle an RPOP command. |
Method | do_QUIT | Handle a QUIT command. |
Method | authenticateUserAPOP | Perform APOP authentication. |
Method | authenticateUserPASS | Perform authentication for a username/password login. |
Instance Variable | _userIs | The username sent with the USER command. (type: bytes
or NoneType ) |
Instance Variable | _onLogout | The function to be executed when the connection is lost. (type: no-argument callable or NoneType ) |
Instance Variable | _highest | The 1-based index of the highest message retrieved. (type: int ) |
Instance Variable | _auth | Authorization credentials. (type: IUsernameHashedPassword
provider) |
Method | _unblock | Process as many blocked commands as possible. |
Method | _cbMailbox | Complete successful authentication. |
Method | _ebMailbox | Handle an expected authentication failure. |
Method | _ebUnexpected | Handle an unexpected authentication failure. |
Method | _longOperation | Stop timeouts and block further command processing while a long operation completes. |
Method | _coiterate | Direct the output of an iterator to the transport and arrange for iteration to take place. |
Method | _getMessageFile | Retrieve the size and contents of a message. |
Method | _sendMessageContent | Send the contents of a message. |
Inherited from LineOnlyReceiver:
Class Variable | delimiter | The line-ending delimiter to use. By default this is b'\r\n' . |
Class Variable | MAX_LENGTH | The maximum length of a line to allow (If a sent line is longer than this, the connection is dropped). Default is 16384. |
Method | dataReceived | Translates bytes into lines, and calls lineReceived. |
Method | sendLine | Sends a line to the other end of the connection. |
Method | lineLengthExceeded | Called when the maximum line length has been reached. Override if it needs to be dealt with in some special way. |
Inherited from Protocol (via LineOnlyReceiver):
Method | logPrefix | Return a prefix matching the class name, to identify log messages related to this protocol instance. |
Inherited from BaseProtocol (via LineOnlyReceiver, Protocol):
Method | makeConnection | Make a connection to a transport and a server. |
Inherited from TimeoutMixin:
Method | callLater | Wrapper around reactor.callLater for test purpose. |
Method | resetTimeout | Reset the timeout count down. |
Method | setTimeout | Change the timeout period |
Method | timeoutConnection | Called when the connection times out. |
Method | __timedOut | Undocumented |
IServerFactory
provider)
int
)
Deferred
)
NoneType
)
bytes
)
blocked
is set to none. Otherwise, it contains a
list of information about blocked commands. Each list entry consists of
the command and the arguments to the command. (type: NoneType
or list
of 2-tuple
of (1) bytes
(2) tuple
of bytes
)
Parameters | reason | The reason the connection was terminated. (type: Failure ) |
Returns | An RFC 822 message id format string. (type: bytes ) |
Parameters | message | An object whose string representation should be included in the response. (type: stringifyable object ) |
Parameters | message | An object whose string representation should be included in the response. (type: stringifyable object ) |
Parameters | line | A received line. (type: bytes ) |
If there are no more blocked commands, set up for the next command to be sent immediately.
Parameters | _ | Ignored. (type: object ) |
Parameters | line | A received command. (type: bytes ) |
If the AUTH extension is not supported, send an error response. If an authentication mechanism was not specified in the command, send a list of all supported authentication methods. Otherwise, send an authentication challenge to the client and transition to the AUTH state.
Parameters | args | The name of an authentication mechanism. (type: bytes
or NoneType ) |
Transition back to the COMMAND state. Check the credentials and
complete the authorization process with the _cbMailbox
callback function on success or the _ebMailbox
and _ebUnexpected
errback functions on failure.
Parameters | line | The challenge response. (type: bytes ) |
Perform APOP authentication and complete the authorization process with
the _cbMailbox
callback function on success or the _ebMailbox
and _ebUnexpected
errback functions on failure.
Parameters | user | A username. (type: bytes ) |
digest | An MD5 digest string. (type: bytes ) |
Save the mailbox and logout function for the authenticated user and send a successful response to the client.
Parameters | interface | The interface supported by the avatar. (type: zope.interface.Interface ) |
avatar | The mailbox for the authenticated user. (type: IMailbox
provider) | |
logout | The function to be invoked when the session is terminated. (type: no-argument callable) | |
user | The user being authenticated. (type: bytes ) |
Send an appropriate error response for a LoginDenied
or
LoginFailed
authentication failure.
Parameters | failure | The authentication error. (type: Failure ) |
Send an error response for an unexpected authentication failure.
Parameters | failure | The authentication error. (type: Failure ) |
Save the username and send a successful response prompting the client for the password.
Parameters | user | A username. (type: bytes ) |
If a USER command was previously received, authenticate the user and
complete the authorization process with the _cbMailbox
callback function on success or the _ebMailbox
and _ebUnexpected
errback functions on failure. If a USER command was not previously
received, send an error response.
Parameters | password | A password. (type: bytes ) |
Parameters | d | A deferred which triggers at the completion of a long operation. (type: Deferred ) |
Returns | A deferred which triggers after command processing resumes and timeouts
restart after the completion of a long operation. (type: Deferred ) |
Returns | A deferred which triggers after the response to the STAT command has been
issued. (type: Deferred ) |
Parameters | i | A 1-based message index. (type: bytes ) |
Returns | A deferred which successfully fires with the size of the message and a file
containing the contents of the message. (type: Deferred
which successfully fires with 2-tuple
of (1) int ,
(2) file-like object) |
Parameters | i | A 1-based message index. (type: bytes ) |
fpWrapper | (type: callable that takes a file-like object and returns a file-like object) | |
successResponse | (type: callable that takes int
and returns bytes ) | |
Returns | A deferred which triggers after the message has been sent. (type: Deferred ) |
Make sure each line ends with '\r\n'
and byte-stuff the
termination character ('.'
) by adding an extra one when one
appears at the beginning of a line.
Parameters | chunk | A string to transform. (type: bytes ) |
Returns | The transformed string. (type: bytes ) |
Parameters | lastsent | The last character of the file. (type: bytes ) |
Mark a message for deletion and issue a successful response.
Parameters | i | A 1-based message index. (type: int ) |
Unmark any messages that have been flagged for deletion.
Respond with the 1-based index of the highest retrieved message.
RPOP is not supported. Send an error response.
Parameters | user | A username. (type: bytes ) |
Remove any messages marked for deletion, issue a successful response, and drop the connection.
Parameters | user | The name of the user attempting to log in. (type: bytes ) |
digest | The challenge response. (type: bytes ) | |
Returns | A deferred which fires when authentication is complete. If successful, it
returns an IMailbox interface,
a mailbox, and a function to be invoked with the session is terminated. If
authentication fails, the deferred fails with an UnathorizedLogin
error. (type: Deferred
which successfully results in 3-tuple
of (1) IMailbox ,
(2) IMailbox
provider, (3) no-argument callable) | |
Raises | cred.error.UnauthorizedLogin | When authentication fails. |
Parameters | user | The name of the user attempting to log in. (type: bytes ) |
password | The password to authenticate with. (type: bytes ) | |
Returns | A deferred which fires when authentication is complete. If successful, it
returns a pop3.IMailbox
interface, a mailbox, and a function to be invoked with the session is
terminated. If authentication fails, the deferred fails with an UnathorizedLogin
error. (type: Deferred
which successfully results in 3-tuple
of (1) IMailbox ,
(2) IMailbox
provider, (3) no-argument callable) | |
Raises | cred.error.UnauthorizedLogin | When authentication fails. |