NAME
Net::IMAP::Server::Connection - Connection to a client
DESCRIPTION
Maintains all of the state for a client connection to the IMAP server.
METHODS
new
Creates a new connection; the server will take care of this step.
server
Returns the Net::IMAP::Server that this connection is on.
coro
Returns the Coro process associated with this connection. For things interacting with this conneciton, it will probably be the current coroutine, except for interactions coming from event loops.
io_handle
Returns the IO handle that can be used to read from or write to the client.
model
Gets or sets the Net::IMAP::Server::DefaultModel or descendant associated with this connection. Note that connections which have not authenticated yet do not have a model.
auth
Gets or sets the Net::IMAP::Server::DefaultAuth or descendant associated with this connection. Note that connections which have not authenticated yet do not have an auth object.
client_id
When called with no arguments, returns a hashref of identifying information provided by the client. When key-value pairs are provided, sets the client properties. See RFC 2971.
selected [MAILBOX]
Gets or sets the currently selected mailbox for this connection. This may trigger the sending of untagged notifications to the client.
greeting
Sends out a one-line untagged greeting to the client.
handle_lines
The main line handling loop. Since we are using Coro, this cedes to other coroutines whenever we block, given them a chance to run. We additionally cede after handling every command.
update_timer
Updates the inactivity timer.
timer [EV watcher]
Returns the EV watcher in charge of the inactivity timer.
handle_command
Handles a single line from the client. This is not quite the same as handling a command, because of client literals and continuation commands.
pending
If a connection has pending state, contains the callback that will receive the next line of input.
close
Shuts down this connection, also closing the model and mailboxes.
parse_command LINE
Parses the line into the tag
, ommand
, and options
. Returns undef if parsing fails for some reason.
is_unauth
Returns true if the connection is unauthenticated.
is_auth
Returns true if the connection is authenticated.
is_selected
Returns true if the connection has selected a mailbox.
is_encrypted
Returns true if the connection is protected by SSL or TLS.
poll
Polls the currently selected mailbox, and resets the poll timer.
force_poll
Forces a poll of the selected mailbox the next chance we get.
last_poll
Gets or sets the last time the selected mailbox was polled, in seconds since the epoch.
send_untagged
Sends any untagged updates about the current mailbox to the client.
get_messages STR
Parses and returns messages fitting the given sequence range. This is on the connection and not the mailbox because messages have connection-dependent sequence numbers.
sequence MESSAGE
Returns the sequence number for the given message.
capability
Returns the current capability list for this connection, as a string. Connections not under TLS or SSL always have the LOGINDISABLED
capability, and no authentication capabilities. The "auth_class" in Net::IMAP::Server's "sasl_provides" in Net::IMAP::Server::DefaultAuth method is used to list known AUTH=
types.
session_flags MESSAGE
log MESSAGE
Logs the message to standard error, using warn
.
untagged_response STRING
Sends an untagged response to the client; a newline ia automatically appended.
out STRING
Sends the mesage to the client. If the client's connection has dropped, or the send fails for whatever reason, "close" the connection and then die, which is caught by "handle_lines".