1 /*
   2  * CDDL HEADER START
   3  *
   4  * The contents of this file are subject to the terms of the
   5  * Common Development and Distribution License (the "License").
   6  * You may not use this file except in compliance with the License.
   7  *
   8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
   9  * or http://www.opensolaris.org/os/licensing.
  10  * See the License for the specific language governing permissions
  11  * and limitations under the License.
  12  *
  13  * When distributing Covered Code, include this CDDL HEADER in each
  14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
  15  * If applicable, add the following below this CDDL HEADER, with the
  16  * fields enclosed by brackets "[]" replaced with your own identifying
  17  * information: Portions Copyright [yyyy] [name of copyright owner]
  18  *
  19  * CDDL HEADER END
  20  */
  21 /*
  22  * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
  23  */
  24 
  25 #include <fmdump.h>
  26 #include <stdio.h>
  27 #include <time.h>
  28 
  29 /*ARGSUSED*/
  30 static int
  31 info_short(fmd_log_t *lp, const fmd_log_record_t *rp, FILE *fp)
  32 {
  33         char buf[32];
  34 
  35         fmdump_printf(fp, "%-20s %-32s\n",
  36             fmdump_date(buf, sizeof (buf), rp), rp->rec_class);
  37 
  38         return (0);
  39 }
  40 
  41 /*ARGSUSED*/
  42 static int
  43 info_verb1(fmd_log_t *lp, const fmd_log_record_t *rp, FILE *fp)
  44 {
  45         char *uuid = "(absent)";
  46         char buf[32];
  47 
  48         (void) nvlist_lookup_string(rp->rec_nvl, FM_IREPORT_UUID, &uuid);
  49 
  50         fmdump_printf(fp, "%-20s %-36s %s\n",
  51             fmdump_date(buf, sizeof (buf), rp), uuid, rp->rec_class);
  52 
  53         return (0);
  54 }
  55 
  56 /*ARGSUSED*/
  57 static int
  58 info_verb23_cmn(fmd_log_t *lp, const fmd_log_record_t *rp, FILE *fp,
  59     nvlist_prtctl_t pctl)
  60 {
  61         char buf[32];
  62         char *uuid = "(absent)";
  63 
  64         (void) nvlist_lookup_string(rp->rec_nvl, FM_IREPORT_UUID, &uuid);
  65 
  66         fmdump_printf(fp, "%-20s.%9.9llu %s\n",
  67             fmdump_year(buf, sizeof (buf), rp), rp->rec_nsec, uuid);
  68 
  69         if (pctl)
  70                 nvlist_prt(rp->rec_nvl, pctl);
  71         else
  72                 nvlist_print(fp, rp->rec_nvl);
  73 
  74         fmdump_printf(fp, "\n");
  75         return (0);
  76 }
  77 
  78 static int
  79 info_verb2(fmd_log_t *lp, const fmd_log_record_t *rp, FILE *fp)
  80 {
  81         return (info_verb23_cmn(lp, rp, fp, NULL));
  82 }
  83 
  84 static int
  85 info_pretty(fmd_log_t *lp, const fmd_log_record_t *rp, FILE *fp)
  86 {
  87         nvlist_prtctl_t pctl;
  88         int rc;
  89 
  90         if ((pctl = nvlist_prtctl_alloc()) != NULL) {
  91                 nvlist_prtctl_setdest(pctl, fp);
  92                 nvlist_prtctlop_nvlist(pctl, fmdump_render_nvlist, NULL);
  93         }
  94 
  95         rc = info_verb23_cmn(lp, rp, fp, pctl);
  96 
  97         nvlist_prtctl_free(pctl);
  98         return (rc);
  99 }
 100 
 101 const fmdump_ops_t fmdump_info_ops = {
 102 "info", {
 103 {
 104 "TIME                 CLASS",
 105 (fmd_log_rec_f *)info_short
 106 }, {
 107 "TIME                 UUID                                 CLASS",
 108 (fmd_log_rec_f *)info_verb1
 109 }, {
 110 "TIME                           UUID",
 111 (fmd_log_rec_f *)info_verb2
 112 }, {
 113 "TIME                           UUID",
 114 (fmd_log_rec_f *)info_pretty
 115 }, {
 116 NULL, NULL
 117 } }
 118 };