/usr/include/dovecot/imap-client.h is in dovecot-dev 1:2.2.22-1ubuntu2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 | #ifndef IMAP_CLIENT_H
#define IMAP_CLIENT_H
#include "imap-commands.h"
#include "message-size.h"
#define CLIENT_COMMAND_QUEUE_MAX_SIZE 4
/* Maximum number of CONTEXT=SEARCH UPDATEs. Clients probably won't need more
than a few, so this is mainly to avoid more or less accidental pointless
resource usage. */
#define CLIENT_MAX_SEARCH_UPDATES 10
struct client;
struct mail_storage;
struct mail_storage_service_ctx;
struct imap_parser;
struct imap_arg;
struct imap_urlauth_context;
struct mailbox_keywords {
/* All keyword names. The array itself exists in mail_index.
Keywords are currently only appended, they're never removed. */
const ARRAY_TYPE(keywords) *names;
/* Number of keywords announced to client via FLAGS/PERMANENTFLAGS.
This relies on keywords not being removed while mailbox is
selected. */
unsigned int announce_count;
};
struct imap_search_update {
char *tag;
struct mail_search_result *result;
bool return_uids;
pool_t fetch_pool;
struct imap_fetch_context *fetch_ctx;
};
enum client_command_state {
/* Waiting for more input */
CLIENT_COMMAND_STATE_WAIT_INPUT,
/* Waiting to be able to send more output */
CLIENT_COMMAND_STATE_WAIT_OUTPUT,
/* Waiting for external interaction */
CLIENT_COMMAND_STATE_WAIT_EXTERNAL,
/* Wait for other commands to finish execution */
CLIENT_COMMAND_STATE_WAIT_UNAMBIGUITY,
/* Waiting for other commands to finish so we can sync */
CLIENT_COMMAND_STATE_WAIT_SYNC,
/* Command is finished */
CLIENT_COMMAND_STATE_DONE
};
struct client_command_context {
struct client_command_context *prev, *next;
struct client *client;
pool_t pool;
/* IMAP command tag */
const char *tag;
/* Name of this command */
const char *name;
/* Parameters for this command. These are generated from parsed IMAP
arguments, so they may not be exactly the same as how client sent
them. */
const char *args;
enum command_flags cmd_flags;
command_func_t *func;
void *context;
/* Module-specific contexts. */
ARRAY(union imap_module_context *) module_contexts;
struct imap_parser *parser;
enum client_command_state state;
/* time when command handling was started - typically this is after
reading all the parameters. */
struct timeval start_time;
/* io_loop_get_wait_usecs()'s value when the command was started */
uint64_t start_ioloop_wait_usecs;
/* how many usecs this command itself has spent running */
uint64_t running_usecs;
/* how many bytes of client input/output command has used */
uint64_t bytes_in, bytes_out;
struct client_sync_context *sync;
unsigned int uid:1; /* used UID command */
unsigned int cancel:1; /* command is wanted to be cancelled */
unsigned int param_error:1;
unsigned int search_save_result:1; /* search result is being updated */
unsigned int search_save_result_used:1; /* command uses search save */
unsigned int temp_executed:1; /* temporary execution state tracking */
unsigned int tagline_sent:1;
unsigned int executing:1;
};
struct imap_client_vfuncs {
/* Export client state into buffer. Returns 1 if ok, 0 if some state
couldn't be preserved, -1 if temporary internal error occurred. */
int (*state_export)(struct client *client, bool internal,
buffer_t *dest, const char **error_r);
/* Import a single block of client state from the given data. Returns
number of bytes successfully imported from the block, or 0 if state
is corrupted or contains unknown data (e.g. some plugin is no longer
loaded), -1 if temporary internal error occurred. */
ssize_t (*state_import)(struct client *client, bool internal,
const unsigned char *data, size_t size,
const char **error_r);
void (*destroy)(struct client *client, const char *reason);
};
struct client {
struct client *prev, *next;
struct imap_client_vfuncs v;
const char *session_id;
const char *const *userdb_fields; /* for internal session saving/restoring */
int fd_in, fd_out;
struct io *io;
struct istream *input;
struct ostream *output;
struct timeout *to_idle, *to_idle_output, *to_delayed_input;
pool_t pool;
struct mail_storage_service_user *service_user;
const struct imap_settings *set;
string_t *capability_string;
struct mail_user *user;
struct mailbox *mailbox;
struct mailbox_keywords keywords;
unsigned int sync_counter;
uint32_t messages_count, recent_count, uidvalidity;
enum mailbox_feature enabled_features;
time_t last_input, last_output;
unsigned int bad_counter;
/* one parser is kept here to be used for new commands */
struct imap_parser *free_parser;
/* command_pool is cleared when the command queue gets empty */
pool_t command_pool;
/* New commands are always prepended to the queue */
struct client_command_context *command_queue;
unsigned int command_queue_size;
uint64_t sync_last_full_modseq;
uint64_t highest_fetch_modseq;
/* For imap_logout_format statistics: */
unsigned int fetch_hdr_count, fetch_body_count;
uint64_t fetch_hdr_bytes, fetch_body_bytes;
unsigned int deleted_count, expunged_count, trashed_count;
/* SEARCHRES extension: Last saved SEARCH result */
ARRAY_TYPE(seq_range) search_saved_uidset;
/* SEARCH=CONTEXT extension: Searches that get updated */
ARRAY(struct imap_search_update) search_updates;
/* NOTIFY extension */
struct imap_notify_context *notify_ctx;
uint32_t notify_uidnext;
/* client input/output is locked by this command */
struct client_command_context *input_lock;
struct client_command_context *output_cmd_lock;
/* command changing the mailbox */
struct client_command_context *mailbox_change_lock;
/* IMAP URLAUTH context (RFC4467) */
struct imap_urlauth_context *urlauth_ctx;
/* Module-specific contexts. */
ARRAY(union imap_module_context *) module_contexts;
/* syncing marks this TRUE when it sees \Deleted flags. this is by
EXPUNGE for Outlook-workaround. */
unsigned int sync_seen_deletes:1;
unsigned int disconnected:1;
unsigned int destroyed:1;
unsigned int handling_input:1;
unsigned int syncing:1;
unsigned int id_logged:1;
unsigned int mailbox_examined:1;
unsigned int anvil_sent:1;
unsigned int tls_compression:1;
unsigned int input_skip_line:1; /* skip all the data until we've
found a new line */
unsigned int modseqs_sent_since_sync:1;
unsigned int notify_immediate_expunges:1;
unsigned int notify_count_changes:1;
unsigned int notify_flag_changes:1;
unsigned int imap_metadata_enabled:1;
unsigned int nonpermanent_modseqs:1;
unsigned int state_import_bad_idle_done:1;
unsigned int state_import_idle_continue:1;
};
struct imap_module_register {
unsigned int id;
};
union imap_module_context {
struct imap_client_vfuncs super;
struct imap_module_register *reg;
};
extern struct imap_module_register imap_module_register;
extern struct client *imap_clients;
extern unsigned int imap_client_count;
/* Create new client with specified input/output handles. socket specifies
if the handle is a socket. */
struct client *client_create(int fd_in, int fd_out, const char *session_id,
struct mail_user *user,
struct mail_storage_service_user *service_user,
const struct imap_settings *set);
void client_destroy(struct client *client, const char *reason) ATTR_NULL(2);
/* Disconnect client connection */
void client_disconnect(struct client *client, const char *reason);
void client_disconnect_with_error(struct client *client, const char *msg);
/* Send a line of data to client. */
void client_send_line(struct client *client, const char *data);
/* Send a line of data to client. Returns 1 if ok, 0 if buffer is getting full,
-1 if error. This should be used when you're (potentially) sending a lot of
lines to client. */
int client_send_line_next(struct client *client, const char *data);
/* Send line of data to client, prefixed with client->tag. You need to prefix
the data with "OK ", "NO " or "BAD ". */
void client_send_tagline(struct client_command_context *cmd, const char *data);
/* Send a BAD command reply to client via client_send_tagline(). If there have
been too many command errors, the client is disconnected. msg may be NULL,
in which case the error is looked up from imap_parser. */
void client_send_command_error(struct client_command_context *cmd,
const char *msg);
/* Send a NO command reply with the default internal error message to client
via client_send_tagline(). */
void client_send_internal_error(struct client_command_context *cmd);
/* Read a number of arguments. Returns TRUE if everything was read or
FALSE if either needs more data or error occurred. */
bool client_read_args(struct client_command_context *cmd, unsigned int count,
unsigned int flags, const struct imap_arg **args_r);
/* Reads a number of string arguments. ... is a list of pointers where to
store the arguments. */
bool client_read_string_args(struct client_command_context *cmd,
unsigned int count, ...);
/* SEARCHRES extension: Call if $ is being used/updated, returns TRUE if we
have to wait for an existing SEARCH SAVE to finish. */
bool client_handle_search_save_ambiguity(struct client_command_context *cmd);
int client_enable(struct client *client, enum mailbox_feature features);
/* Send client processing to imap-idle process. If successful, returns TRUE
and destroys the client. */
bool imap_client_hibernate(struct client **client);
struct imap_search_update *
client_search_update_lookup(struct client *client, const char *tag,
unsigned int *idx_r);
void client_search_updates_free(struct client *client);
struct client_command_context *client_command_alloc(struct client *client);
void client_command_cancel(struct client_command_context **cmd);
void client_command_free(struct client_command_context **cmd);
bool client_handle_unfinished_cmd(struct client_command_context *cmd);
/* Handle any pending command input. This must be run at the end of all
I/O callbacks after they've (potentially) finished some commands. */
void client_continue_pending_input(struct client *client);
void client_add_missing_io(struct client *client);
const char *client_stats(struct client *client);
void client_input(struct client *client);
bool client_handle_input(struct client *client);
int client_output(struct client *client);
void clients_destroy_all(struct mail_storage_service_ctx *storage_service);
#endif
|