dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina Stephen Gallagher <sgallagh@redhat.com>
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina Copyright (C) 2010 Red Hat
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina This program is free software; you can redistribute it and/or modify
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina it under the terms of the GNU General Public License as published by
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina the Free Software Foundation; either version 3 of the License, or
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina (at your option) any later version.
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina This program is distributed in the hope that it will be useful,
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina but WITHOUT ANY WARRANTY; without even the implied warranty of
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina GNU General Public License for more details.
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina You should have received a copy of the GNU General Public License
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina along with this program. If not, see <http://www.gnu.org/licenses/>.
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina#include "providers/proxy/proxy_iface_generated.h"
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březinastatic int proxy_client_register(struct sbus_request *sbus_req,
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina proxy_cli = talloc_get_type(data, struct proxy_client);
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina DEBUG(SSSDBG_FATAL_FAILURE, "Connection holds no valid init data\n");
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina /* First thing, cancel the timeout */
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina "Cancel proxy client ID timeout [%p]\n", proxy_cli->timeout);
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina DEBUG(SSSDBG_FUNC_DATA, "Proxy client [%"PRIu32"] connected\n", cli_id);
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina /* Check the hash table */
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina if (!hash_has_key(proxy_cli->proxy_auth_ctx->request_table, &key)) {
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina "Unknown child ID. Killing the connection\n");
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina hret = hash_lookup(proxy_cli->proxy_auth_ctx->request_table, &key, &value);
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina "Hash error [%d]: %s\n", hret, hash_error_string(hret));
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina /* Signal that the child is up and ready to receive the request */
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina req = talloc_get_type(value.ptr, struct tevent_req);
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina child_ctx = tevent_req_data(req, struct proxy_child_ctx);
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina /* This should hopefully be impossible, but protect
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina * against it anyway. If we're not marked running, then
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina * the init_req will be NULL below and things will
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina DEBUG(SSSDBG_CRIT_FAILURE, "Client connection from a request "
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina "that's not marked as running\n");
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina init_ctx = tevent_req_data(child_ctx->init_req, struct pc_init_ctx);
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březinastatic void proxy_client_timeout(struct tevent_context *ev,
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina "Client timed out before Identification [%p]!\n", te);
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina proxy_cli = talloc_get_type(ptr, struct proxy_client);
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina /* If we time out here, we will also time out to
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina * pc_init_timeout(), so we'll finish the request
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březinaint proxy_client_init(struct sbus_connection *conn, void *data)
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina static struct iface_proxy_client iface_proxy_client = {
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina auth_ctx = talloc_get_type(data, struct proxy_auth_ctx);
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina /* When connection is lost we also free the client. */
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina proxy_cli = talloc_zero(conn, struct proxy_client);
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina DEBUG(SSSDBG_FATAL_FAILURE, "Out of memory, killing connection.\n");
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina /* Setup timeout in case client fails to register himself in time. */
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina proxy_cli->timeout = tevent_add_timer(auth_ctx->be->ev, proxy_cli, tv,
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina /* Connection is closed in the caller. */
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina DEBUG(SSSDBG_FATAL_FAILURE, "Out of memory, killing connection\n");
dea636af4d1902a081ee891f1b19ee2f8729d759Pavel Březina "Set-up proxy client ID timeout [%p]\n", proxy_cli->timeout);
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina /* Setup D-Bus interfaces and methods. */
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina ret = sbus_conn_register_iface(conn, &iface_proxy_client.vtable,
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina /* Connection is closed in the caller. */
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina DEBUG(SSSDBG_FATAL_FAILURE, "Unable to register D-Bus interface, "
e07d700ed9daf0cf96607fa2d72978cb2431b794Pavel Březina "killing connection [%d]: %s\n", ret, sss_strerror(ret));