1c19800e8SDoug Rabson /* 2c19800e8SDoug Rabson * Copyright (c) 1997, 1998, 2002 Kungliga Tekniska H�gskolan 3c19800e8SDoug Rabson * (Royal Institute of Technology, Stockholm, Sweden). 4c19800e8SDoug Rabson * All rights reserved. 5c19800e8SDoug Rabson * 6c19800e8SDoug Rabson * Redistribution and use in source and binary forms, with or without 7c19800e8SDoug Rabson * modification, are permitted provided that the following conditions 8c19800e8SDoug Rabson * are met: 9c19800e8SDoug Rabson * 10c19800e8SDoug Rabson * 1. Redistributions of source code must retain the above copyright 11c19800e8SDoug Rabson * notice, this list of conditions and the following disclaimer. 12c19800e8SDoug Rabson * 13c19800e8SDoug Rabson * 2. Redistributions in binary form must reproduce the above copyright 14c19800e8SDoug Rabson * notice, this list of conditions and the following disclaimer in the 15c19800e8SDoug Rabson * documentation and/or other materials provided with the distribution. 16c19800e8SDoug Rabson * 17c19800e8SDoug Rabson * 3. Neither the name of the Institute nor the names of its contributors 18c19800e8SDoug Rabson * may be used to endorse or promote products derived from this software 19c19800e8SDoug Rabson * without specific prior written permission. 20c19800e8SDoug Rabson * 21c19800e8SDoug Rabson * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND 22c19800e8SDoug Rabson * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 23c19800e8SDoug Rabson * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 24c19800e8SDoug Rabson * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE 25c19800e8SDoug Rabson * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 26c19800e8SDoug Rabson * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 27c19800e8SDoug Rabson * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 28c19800e8SDoug Rabson * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 29c19800e8SDoug Rabson * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 30c19800e8SDoug Rabson * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 31c19800e8SDoug Rabson * SUCH DAMAGE. 32c19800e8SDoug Rabson */ 33c19800e8SDoug Rabson 34c19800e8SDoug Rabson #include "kcm_locl.h" 35c19800e8SDoug Rabson 36c19800e8SDoug Rabson RCSID("$Id: log.c 14566 2005-02-06 01:22:49Z lukeh $"); 37c19800e8SDoug Rabson 38c19800e8SDoug Rabson static krb5_log_facility *logf; 39c19800e8SDoug Rabson 40c19800e8SDoug Rabson void 41c19800e8SDoug Rabson kcm_openlog(void) 42c19800e8SDoug Rabson { 43c19800e8SDoug Rabson char **s = NULL, **p; 44c19800e8SDoug Rabson krb5_initlog(kcm_context, "kcm", &logf); 45c19800e8SDoug Rabson s = krb5_config_get_strings(kcm_context, NULL, "kcm", "logging", NULL); 46c19800e8SDoug Rabson if(s == NULL) 47c19800e8SDoug Rabson s = krb5_config_get_strings(kcm_context, NULL, "logging", "kcm", NULL); 48c19800e8SDoug Rabson if(s){ 49c19800e8SDoug Rabson for(p = s; *p; p++) 50c19800e8SDoug Rabson krb5_addlog_dest(kcm_context, logf, *p); 51c19800e8SDoug Rabson krb5_config_free_strings(s); 52c19800e8SDoug Rabson }else 53c19800e8SDoug Rabson krb5_addlog_dest(kcm_context, logf, DEFAULT_LOG_DEST); 54c19800e8SDoug Rabson krb5_set_warn_dest(kcm_context, logf); 55c19800e8SDoug Rabson } 56c19800e8SDoug Rabson 57c19800e8SDoug Rabson char* 58c19800e8SDoug Rabson kcm_log_msg_va(int level, const char *fmt, va_list ap) 59c19800e8SDoug Rabson { 60c19800e8SDoug Rabson char *msg; 61c19800e8SDoug Rabson krb5_vlog_msg(kcm_context, logf, &msg, level, fmt, ap); 62c19800e8SDoug Rabson return msg; 63c19800e8SDoug Rabson } 64c19800e8SDoug Rabson 65c19800e8SDoug Rabson char* 66c19800e8SDoug Rabson kcm_log_msg(int level, const char *fmt, ...) 67c19800e8SDoug Rabson { 68c19800e8SDoug Rabson va_list ap; 69c19800e8SDoug Rabson char *s; 70c19800e8SDoug Rabson va_start(ap, fmt); 71c19800e8SDoug Rabson s = kcm_log_msg_va(level, fmt, ap); 72c19800e8SDoug Rabson va_end(ap); 73c19800e8SDoug Rabson return s; 74c19800e8SDoug Rabson } 75c19800e8SDoug Rabson 76c19800e8SDoug Rabson void 77c19800e8SDoug Rabson kcm_log(int level, const char *fmt, ...) 78c19800e8SDoug Rabson { 79c19800e8SDoug Rabson va_list ap; 80c19800e8SDoug Rabson char *s; 81c19800e8SDoug Rabson va_start(ap, fmt); 82c19800e8SDoug Rabson s = kcm_log_msg_va(level, fmt, ap); 83c19800e8SDoug Rabson if(s) free(s); 84c19800e8SDoug Rabson va_end(ap); 85c19800e8SDoug Rabson } 86