worker-connection.c revision d03a871a77f8ec36f48f5fea98d810e51b186fdb
/* Copyright (c) 2011-2012 Dovecot authors, see the included COPYING file */
#include "lib.h"
#include "array.h"
#include "aqueue.h"
#include "ioloop.h"
#include "istream.h"
#include "ostream.h"
#include "str.h"
#include "strescape.h"
#include "master-service.h"
#include "indexer-queue.h"
#include "worker-connection.h"
#include <unistd.h>
#define INDEXER_PROTOCOL_MAJOR_VERSION 1
#define INDEXER_PROTOCOL_MINOR_VERSION 0
#define INDEXER_MASTER_HANDSHAKE "VERSION\tindexer-master-worker\t1\t0\n"
#define INDEXER_WORKER_NAME "indexer-worker-master"
struct worker_connection {
int refcount;
char *socket_path;
int fd;
char *request_username;
ARRAY(void *) request_contexts;
struct aqueue *request_queue;
unsigned int process_limit;
unsigned int version_received:1;
};
struct worker_connection *
worker_connection_create(const char *socket_path,
{
struct worker_connection *conn;
return conn;
}
{
return;
}
{
}
/* cancel any pending requests */
if (count > 0) {
i_error("Indexer worker disconnected, "
"discarding %u requests for %s",
}
/* conn->callback() can try to destroy us */
for (i = 0; i < count; i++) {
void *const *contextp =
}
}
{
}
static int
{
int percentage;
return -1;
}
return -1;
}
/* the request is finished */
}
return 0;
}
{
const char *line;
return;
}
if (!conn->version_received) {
return;
i_error("Indexer worker not compatible with this master "
"(mixed old and new binaries?)");
return;
}
}
if (conn->process_limit == 0) {
return;
conn->process_limit == 0) {
i_error("Indexer worker sent invalid handshake: %s",
line);
return;
}
}
break;
}
}
}
{
return -1;
}
return 0;
}
{
}
unsigned int *limit_r)
{
if (conn->process_limit == 0)
return FALSE;
return TRUE;
}
const struct indexer_request *request,
void *context)
{
else {
}
T_BEGIN {
} T_END;
}
{
}
{
return conn->request_username;
}