dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * CDDL HEADER START
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * The contents of this file are subject to the terms of the
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * Common Development and Distribution License (the "License").
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * You may not use this file except in compliance with the License.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * or http://www.opensolaris.org/os/licensing.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * See the License for the specific language governing permissions
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * and limitations under the License.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * When distributing Covered Code, include this CDDL HEADER in each
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * If applicable, add the following below this CDDL HEADER, with the
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * fields enclosed by brackets "[]" replaced with your own identifying
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * information: Portions Copyright [yyyy] [name of copyright owner]
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * CDDL HEADER END
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * Use is subject to license terms.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * logs error messages, either to stderr or syslog, depending on
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * the -d option
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra/* Socket to issue ioctl() to the kernel */
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * All routines log to syslog, unless the daemon is running in
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * the foreground, in which case the logging goes to stderr.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * The following logging functions are available:
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * logdebug(): A printf-like function for outputting debug messages
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * (messages at LOG_DEBUG) that are only of use to developers.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * logerr(): A printf-like function for outputting error messages
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * (messages at LOG_ERR) from the daemon.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * logperror*(): A set of functions used to output error messages
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * (messages at LOG_ERR); these automatically append strerror(errno)
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * and a newline to the message passed to them.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * NOTE: since the logging functions write to syslog, the messages passed
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * to them are not eligible for localization. Thus, gettext() must
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * *not* be used.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra/* PRINTFLIKE2 */
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra/* PRINTFLIKE1 */
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra (void) fprintf(stderr, "%s: %s\n", str, strerror(errno));
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misrailbd_check_client_config_auth(const struct passwd *pwd)
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra if (chkauthattr(NET_ILB_CONFIG_AUTH, pwd->pw_name) == 0) {
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misrailbd_check_client_enable_auth(const struct passwd *pwd)
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra if (chkauthattr(NET_ILB_ENABLE_AUTH, pwd->pw_name) == 0) {
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * input param. "err" should be one of the errnos defined in
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * this list is NOT complete.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra rc = ILB_STATUS_OK; /* for completeness' sake */
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra ilb_servers_info_cmd_t *kcmd = (ilb_servers_info_cmd_t *)cmdp;
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra sz = sizeof (*kcmd) + ((kcmd->num_servers - 1) *
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra ilb_rule_names_cmd_t *kcmd = (ilb_rule_names_cmd_t *)cmdp;
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra ((kcmd->num_names - 1) * sizeof (kcmd->buf));
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra ilb_servers_cmd_t *kcmd = (ilb_servers_cmd_t *)cmdp;
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra ((kcmd->num_servers - 1) * sizeof (kcmd->servers));
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * parameter 'sz' is optional (indicated by == 0); if it's not set
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * we try to derive it from cmdp->cmd
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra logdebug("do_ioctl: SIOCILB ioctl (%d) failed: %s",
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * Create an OK reply to a client request. It is assumed that the passed
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * in buffer is large enough to hold the reply.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra /* Default is one exchange of request/response. */
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * Create an error reply to a client request. It is assumed that the passed
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra * in buffer is large enough to hold the reply.
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misrailbd_reply_err(uint32_t *rbuf, size_t *rbufsz, ilb_status_t status)
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra /* Default is one exchange of request/response. */
dbed73cbda2229fd1aa6dc5743993cae7f0a7ee9Sangeeta Misra *rbufsz = sizeof (ilb_comm_t) + sizeof (ilb_status_t);