2008-06-12 20:14:17 +00:00
|
|
|
/*
|
2009-03-29 20:19:18 +00:00
|
|
|
* log.c - logging and debugging functions
|
2008-06-12 20:14:17 +00:00
|
|
|
*
|
|
|
|
* This file is part of the SSH Library
|
|
|
|
*
|
2009-03-29 20:19:18 +00:00
|
|
|
* Copyright (c) 2008 by Aris Adamantiadis
|
|
|
|
*
|
2008-06-12 20:14:17 +00:00
|
|
|
* The SSH Library is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2.1 of the License, or (at your
|
|
|
|
* option) any later version.
|
|
|
|
*
|
|
|
|
* The SSH Library is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
|
|
|
* License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* along with the SSH Library; see the file COPYING. If not, write to
|
|
|
|
* the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
|
2009-03-29 20:19:18 +00:00
|
|
|
* MA 02111-1307, USA.
|
|
|
|
*/
|
2008-06-12 20:14:17 +00:00
|
|
|
|
2009-03-29 20:19:18 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <string.h>
|
2011-09-10 11:49:53 +02:00
|
|
|
#include <sys/time.h>
|
2011-09-11 14:38:44 +02:00
|
|
|
#include <time.h>
|
2008-06-12 20:14:17 +00:00
|
|
|
|
2009-05-05 07:19:50 +00:00
|
|
|
#include "libssh/priv.h"
|
2011-09-10 11:49:53 +02:00
|
|
|
#include "libssh/misc.h"
|
2009-09-23 23:51:04 +02:00
|
|
|
#include "libssh/session.h"
|
2009-05-05 07:19:50 +00:00
|
|
|
|
|
|
|
/**
|
2010-04-04 15:13:15 +02:00
|
|
|
* @defgroup libssh_log The SSH logging functions.
|
|
|
|
* @ingroup libssh
|
2009-05-05 07:19:50 +00:00
|
|
|
*
|
2010-04-04 15:13:15 +02:00
|
|
|
* Logging functions for debugging and problem resolving.
|
|
|
|
*
|
|
|
|
* @{
|
2008-06-12 20:14:17 +00:00
|
|
|
*/
|
2009-03-29 20:19:18 +00:00
|
|
|
|
2011-09-10 11:49:53 +02:00
|
|
|
static int current_timestring(int hires, char *buf, size_t len)
|
|
|
|
{
|
|
|
|
char tbuf[64];
|
|
|
|
struct timeval tv;
|
|
|
|
struct tm *tm;
|
|
|
|
time_t t;
|
|
|
|
|
|
|
|
gettimeofday(&tv, NULL);
|
|
|
|
t = (time_t) tv.tv_sec;
|
|
|
|
|
|
|
|
tm = localtime(&t);
|
|
|
|
if (tm == NULL) {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (hires) {
|
|
|
|
strftime(tbuf, sizeof(tbuf) - 1, "%Y/%m/%d %H:%M:%S", tm);
|
|
|
|
snprintf(buf, len, "%s.%06ld", tbuf, tv.tv_usec);
|
|
|
|
} else {
|
|
|
|
strftime(tbuf, sizeof(tbuf) - 1, "%Y/%m/%d %H:%M:%S", tm);
|
|
|
|
snprintf(buf, len, "%s", tbuf);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2011-07-19 22:16:28 +02:00
|
|
|
/** @internal
|
|
|
|
* @brief do the actual work of logging an event
|
|
|
|
*/
|
|
|
|
|
2011-09-10 11:49:53 +02:00
|
|
|
static void do_ssh_log(struct ssh_common_struct *common,
|
|
|
|
int verbosity,
|
|
|
|
const char *function,
|
|
|
|
const char *buffer) {
|
|
|
|
char date[64] = {0};
|
|
|
|
int rc;
|
|
|
|
|
|
|
|
if (common->callbacks && common->callbacks->log_function) {
|
|
|
|
char buf[1024];
|
|
|
|
|
|
|
|
snprintf(buf, sizeof(buf), "%s: %s", function, buf);
|
|
|
|
|
|
|
|
common->callbacks->log_function((ssh_session)common,
|
|
|
|
verbosity,
|
|
|
|
buf,
|
|
|
|
common->callbacks->userdata);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
rc = current_timestring(1, date, sizeof(date));
|
|
|
|
if (rc == 0) {
|
2011-09-11 15:02:25 +02:00
|
|
|
fprintf(stderr, "[%s, %d] %s", date, verbosity, function);
|
2011-07-19 22:16:28 +02:00
|
|
|
} else {
|
2011-09-11 15:02:25 +02:00
|
|
|
fprintf(stderr, "[%d] %s", verbosity, function);
|
2011-07-19 22:16:28 +02:00
|
|
|
}
|
2011-09-10 11:49:53 +02:00
|
|
|
fprintf(stderr, " %s\n", buffer);
|
|
|
|
}
|
2011-07-19 22:16:28 +02:00
|
|
|
|
2011-09-10 11:49:53 +02:00
|
|
|
/* legacy function */
|
|
|
|
void ssh_log(ssh_session session,
|
|
|
|
int verbosity,
|
|
|
|
const char *format, ...)
|
|
|
|
{
|
|
|
|
char buffer[1024];
|
|
|
|
va_list va;
|
2011-07-19 22:16:28 +02:00
|
|
|
|
2011-09-10 11:49:53 +02:00
|
|
|
if (verbosity <= session->common.log_verbosity) {
|
|
|
|
va_start(va, format);
|
|
|
|
vsnprintf(buffer, sizeof(buffer), format, va);
|
|
|
|
va_end(va);
|
|
|
|
do_ssh_log(&session->common, verbosity, "", buffer);
|
2011-07-19 22:16:28 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-09-10 11:49:53 +02:00
|
|
|
void ssh_log_function(ssh_session session,
|
|
|
|
int verbosity,
|
|
|
|
const char *function,
|
|
|
|
const char *format, ...)
|
|
|
|
{
|
2009-05-05 07:19:50 +00:00
|
|
|
char buffer[1024];
|
|
|
|
va_list va;
|
|
|
|
|
2011-07-19 22:16:28 +02:00
|
|
|
if (verbosity <= session->common.log_verbosity) {
|
2009-05-05 07:19:50 +00:00
|
|
|
va_start(va, format);
|
|
|
|
vsnprintf(buffer, sizeof(buffer), format, va);
|
|
|
|
va_end(va);
|
2011-09-10 11:49:53 +02:00
|
|
|
do_ssh_log(&session->common, verbosity, function, buffer);
|
2011-07-19 22:16:28 +02:00
|
|
|
}
|
|
|
|
}
|
2009-05-05 07:19:50 +00:00
|
|
|
|
2011-07-19 22:16:28 +02:00
|
|
|
/** @internal
|
|
|
|
* @brief log a SSH event with a common pointer
|
|
|
|
* @param common The SSH/bind session.
|
|
|
|
* @param verbosity The verbosity of the event.
|
|
|
|
* @param format The format string of the log entry.
|
|
|
|
*/
|
|
|
|
void ssh_log_common(struct ssh_common_struct *common, int verbosity, const char *format, ...){
|
|
|
|
char buffer[1024];
|
|
|
|
va_list va;
|
2009-05-05 07:19:50 +00:00
|
|
|
|
2011-07-19 22:16:28 +02:00
|
|
|
if (verbosity <= common->log_verbosity) {
|
|
|
|
va_start(va, format);
|
|
|
|
vsnprintf(buffer, sizeof(buffer), format, va);
|
|
|
|
va_end(va);
|
2011-09-10 11:49:53 +02:00
|
|
|
do_ssh_log(common, verbosity, "common", buffer);
|
2009-05-05 07:19:50 +00:00
|
|
|
}
|
2008-06-12 20:14:17 +00:00
|
|
|
}
|
|
|
|
|
2010-08-28 21:32:08 +02:00
|
|
|
/** @} */
|
2010-04-04 15:13:15 +02:00
|
|
|
|
|
|
|
/* vim: set ts=4 sw=4 et cindent: */
|