Mercurial > dovecot > core-2.2
view src/lib-auth/auth-client.c @ 9984:097588a7903c HEAD
lib-auth: Changed API to connect to only a single specified auth socket.
Login processes now always connect to socket called "auth".
author | Timo Sirainen <tss@iki.fi> |
---|---|
date | Wed, 07 Oct 2009 17:46:14 -0400 |
parents | b9faf4db2a9f |
children | c610321584ca |
line wrap: on
line source
/* Copyright (c) 2005-2009 Dovecot authors, see the included COPYING file */ #include "lib.h" #include "array.h" #include "auth-client-private.h" #include "auth-server-connection.h" struct auth_client * auth_client_init(const char *auth_socket_path, unsigned int client_pid, bool debug) { struct auth_client *client; client = i_new(struct auth_client, 1); client->client_pid = client_pid; client->auth_socket_path = i_strdup(auth_socket_path); client->debug = debug; client->conn = auth_server_connection_init(client); (void)auth_server_connection_connect(client->conn); return client; } void auth_client_deinit(struct auth_client **_client) { struct auth_client *client = *_client; *_client = NULL; auth_server_connection_deinit(&client->conn); i_free(client->auth_socket_path); i_free(client); } bool auth_client_is_connected(struct auth_client *client) { return client->conn->handshake_received; } void auth_client_set_connect_notify(struct auth_client *client, auth_connect_notify_callback_t *callback, void *context) { client->connect_notify_callback = callback; client->connect_notify_context = context; } const struct auth_mech_desc * auth_client_get_available_mechs(struct auth_client *client, unsigned int *mech_count) { return array_get(&client->conn->available_auth_mechs, mech_count); } const struct auth_mech_desc * auth_client_find_mech(struct auth_client *client, const char *name) { const struct auth_mech_desc *mechs; unsigned int i, count; mechs = array_get(&client->conn->available_auth_mechs, &count); for (i = 0; i < count; i++) { if (strcasecmp(mechs[i].name, name) == 0) return &mechs[i]; } return NULL; } void auth_client_get_connect_id(struct auth_client *client, unsigned int *server_pid_r, unsigned int *connect_uid_r) { *server_pid_r = client->conn->server_pid; *connect_uid_r = client->conn->connect_uid; }