Annotation of embedaddon/strongswan/src/swanctl/commands/log.c, revision 1.1.1.1

1.1       misho       1: /*
                      2:  * Copyright (C) 2014 Martin Willi
                      3:  * Copyright (C) 2014 revosec AG
                      4:  *
                      5:  * This program is free software; you can redistribute it and/or modify it
                      6:  * under the terms of the GNU General Public License as published by the
                      7:  * Free Software Foundation; either version 2 of the License, or (at your
                      8:  * option) any later version.  See <http://www.fsf.org/copyleft/gpl.txt>.
                      9:  *
                     10:  * This program is distributed in the hope that it will be useful, but
                     11:  * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
                     12:  * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
                     13:  * for more details.
                     14:  */
                     15: 
                     16: #include "command.h"
                     17: 
                     18: #include <errno.h>
                     19: #include <unistd.h>
                     20: 
                     21: CALLBACK(log_cb, void,
                     22:        command_format_options_t *format, char *name, vici_res_t *msg)
                     23: {
                     24:        if (*format & COMMAND_FORMAT_RAW)
                     25:        {
                     26:                vici_dump(msg, "log", *format & COMMAND_FORMAT_PRETTY, stdout);
                     27:        }
                     28:        else
                     29:        {
                     30:                char *current, *next;
                     31: 
                     32:                current = vici_find_str(msg, NULL, "msg");
                     33:                while (current)
                     34:                {
                     35:                        next = strchr(current, '\n');
                     36:                        printf("%.2d[%s] ", vici_find_int(msg, 0, "thread"),
                     37:                                   vici_find_str(msg, "   ", "group"));
                     38:                        if (next == NULL)
                     39:                        {
                     40:                                printf("%s\n", current);
                     41:                                break;
                     42:                        }
                     43:                        printf("%.*s\n", (int)(next - current), current);
                     44:                        current = next + 1;
                     45:                }
                     46:        }
                     47: }
                     48: 
                     49: static int logcmd(vici_conn_t *conn)
                     50: {
                     51:        command_format_options_t format = COMMAND_FORMAT_NONE;
                     52:        char *arg;
                     53:        int ret;
                     54: 
                     55:        while (TRUE)
                     56:        {
                     57:                switch (command_getopt(&arg))
                     58:                {
                     59:                        case 'h':
                     60:                                return command_usage(NULL);
                     61:                        case 'P':
                     62:                                format |= COMMAND_FORMAT_PRETTY;
                     63:                                /* fall through to raw */
                     64:                        case 'r':
                     65:                                format |= COMMAND_FORMAT_RAW;
                     66:                                continue;
                     67:                        case EOF:
                     68:                                break;
                     69:                        default:
                     70:                                return command_usage("invalid --log option");
                     71:                }
                     72:                break;
                     73:        }
                     74: 
                     75:        if (vici_register(conn, "log", log_cb, &format) != 0)
                     76:        {
                     77:                ret = errno;
                     78:                fprintf(stderr, "registering for log failed: %s\n", strerror(errno));
                     79:                return ret;
                     80:        }
                     81: 
                     82:        wait_sigint();
                     83: 
                     84:        fprintf(stderr, "disconnecting...\n");
                     85: 
                     86:        return 0;
                     87: }
                     88: 
                     89: /**
                     90:  * Register the command.
                     91:  */
                     92: static void __attribute__ ((constructor))reg()
                     93: {
                     94:        command_register((command_t) {
                     95:                logcmd, 'T', "log", "trace logging output",
                     96:                {"[--raw|--pretty]"},
                     97:                {
                     98:                        {"help",                'h', 0, "show usage information"},
                     99:                        {"raw",                 'r', 0, "dump raw response message"},
                    100:                        {"pretty",              'P', 0, "dump raw response message in pretty print"},
                    101:                }
                    102:        });
                    103: }

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>