doc: Make make distcheck work again.
[gnupg.git] / g10 / tdbdump.c
index 3f9e8b3..893c982 100644 (file)
@@ -1,11 +1,11 @@
 /* tdbdump.c
- * Copyright (C) 1998, 1999, 2000, 2001, 2003 Free Software Foundation, Inc.
+ * Copyright (C) 1998, 1999, 2000, 2001 Free Software Foundation, Inc.
  *
  * This file is part of GnuPG.
  *
  * GnuPG is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
+ * the Free Software Foundation; either version 3 of the License, or
  * (at your option) any later version.
  *
  * GnuPG is distributed in the hope that it will be useful,
@@ -14,8 +14,7 @@
  * GNU General Public License for more details.
  *
  * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
+ * along with this program; if not, see <http://www.gnu.org/licenses/>.
  */
 
 #include <config.h>
 #include <unistd.h>
 
 #include "gpg.h"
-#include "errors.h"
+#include "status.h"
 #include "iobuf.h"
 #include "keydb.h"
-#include "memory.h"
 #include "util.h"
 #include "trustdb.h"
 #include "options.h"
@@ -48,8 +46,8 @@
                      (x) >= 'A' && (x) <= 'F' ? ((x)-'A'+10) : ((x)-'a'+10))
 
 
-/****************
- * Wirte a record but die on error
+/*
+ * Write a record; die on error.
  */
 static void
 write_record( TRUSTREC *rec )
@@ -63,26 +61,29 @@ write_record( TRUSTREC *rec )
 }
 
 
-/****************
- * Dump the entire trustdb or only the entries of one key.
+/*
+ * Dump the entire trustdb to FP or only the entries of one key.
  */
 void
-list_trustdb( const char *username )
+list_trustdb (estream_t fp, const char *username)
 {
-    TRUSTREC rec;
-
-    init_trustdb();
-    /* for now we ignore the user ID */
-    if (1) {
-       ulong recnum;
-       int i;
-
-       printf("TrustDB: %s\n", tdbio_get_dbname() );
-       for(i=9+strlen(tdbio_get_dbname()); i > 0; i-- )
-           putchar('-');
-       putchar('\n');
-       for(recnum=0; !tdbio_read_record( recnum, &rec, 0); recnum++ )
-           tdbio_dump_record( &rec, stdout );
+  TRUSTREC rec;
+
+  (void)username;
+
+  init_trustdb();
+  /* For now we ignore the user ID. */
+  if (1)
+    {
+      ulong recnum;
+      int i;
+
+      es_fprintf (fp, "TrustDB: %s\n", tdbio_get_dbname ());
+      for (i = 9 + strlen (tdbio_get_dbname()); i > 0; i-- )
+        es_fputc ('-', fp);
+      es_putc ('\n', fp);
+      for (recnum=0; !tdbio_read_record (recnum, &rec, 0); recnum++)
+        tdbio_dump_record (&rec, fp);
     }
 }
 
@@ -96,23 +97,25 @@ list_trustdb( const char *username )
 void
 export_ownertrust()
 {
-    TRUSTREC rec;
-    ulong recnum;
-    int i;
-    byte *p;
-
-    init_trustdb();
-    printf(_("# List of assigned trustvalues, created %s\n"
-            "# (Use \"gpg --import-ownertrust\" to restore them)\n"),
-          asctimestamp( make_timestamp() ) );
-    for(recnum=0; !tdbio_read_record( recnum, &rec, 0); recnum++ ) {
-       if( rec.rectype == RECTYPE_TRUST ) {
-           if( !rec.r.trust.ownertrust )
-               continue;
-           p = rec.r.trust.fingerprint;
-           for(i=0; i < 20; i++, p++ )
-               printf("%02X", *p );
-           printf(":%u:\n", (unsigned int)rec.r.trust.ownertrust );
+  TRUSTREC rec;
+  ulong recnum;
+  int i;
+  byte *p;
+
+  init_trustdb();
+  es_printf (_("# List of assigned trustvalues, created %s\n"
+               "# (Use \"gpg --import-ownertrust\" to restore them)\n"),
+             asctimestamp( make_timestamp() ) );
+  for (recnum=0; !tdbio_read_record (recnum, &rec, 0); recnum++ )
+    {
+      if (rec.rectype == RECTYPE_TRUST)
+        {
+          if (!rec.r.trust.ownertrust)
+            continue;
+          p = rec.r.trust.fingerprint;
+          for (i=0; i < 20; i++, p++ )
+            es_printf("%02X", *p );
+          es_printf (":%u:\n", (unsigned int)rec.r.trust.ownertrust );
        }
     }
 }
@@ -121,7 +124,7 @@ export_ownertrust()
 void
 import_ownertrust( const char *fname )
 {
-    FILE *fp;
+    estream_t fp;
     int is_stdin=0;
     char line[256];
     char *p;
@@ -132,41 +135,51 @@ import_ownertrust( const char *fname )
     int rc;
 
     init_trustdb();
-    if( !fname || (*fname == '-' && !fname[1]) ) {
-       fp = stdin;
+    if( iobuf_is_pipe_filename (fname) ) {
+       fp = es_stdin;
        fname = "[stdin]";
        is_stdin = 1;
     }
-    else if( !(fp = fopen( fname, "r" )) ) {
-       log_error ( _("can't open `%s': %s\n"), fname, strerror(errno) );
+    else if( !(fp = es_fopen( fname, "r" )) ) {
+       log_error ( _("can't open '%s': %s\n"), fname, strerror(errno) );
        return;
     }
 
-    while( fgets( line, DIM(line)-1, fp ) ) {
+    if (is_secured_file (es_fileno (fp)))
+      {
+        es_fclose (fp);
+        gpg_err_set_errno (EPERM);
+       log_error (_("can't open '%s': %s\n"), fname, strerror(errno) );
+       return;
+      }
+
+    while (es_fgets (line, DIM(line)-1, fp)) {
        TRUSTREC rec;
 
        if( !*line || *line == '#' )
            continue;
        n = strlen(line);
        if( line[n-1] != '\n' ) {
-           log_error (_("\b%s: line too long\n"), fname );
+           log_error (_("error in '%s': %s\n"), fname, _("line too long") );
            /* ... or last line does not have a LF */
            break; /* can't continue */
        }
        for(p = line; *p && *p != ':' ; p++ )
-           if( !isxdigit(*p) )
+           if( !hexdigitp(p) )
                break;
        if( *p != ':' ) {
-           log_error (_("\b%s: error: missing colon\n"), fname );
+           log_error (_("error in '%s': %s\n"), fname, _("colon missing") );
            continue;
        }
        fprlen = p - line;
        if( fprlen != 32 && fprlen != 40 ) {
-           log_error (_("\b%s: error: invalid fingerprint\n"), fname );
+           log_error (_("error in '%s': %s\n"),
+                       fname, _("invalid fingerprint") );
            continue;
        }
        if( sscanf(p, ":%u:", &otrust ) != 1 ) {
-           log_error (_("\b%s: error: no ownertrust value\n"), fname );
+           log_error (_("error in '%s': %s\n"),
+                       fname, _("ownertrust value missing"));
            continue;
        }
        if( !otrust )
@@ -176,7 +189,7 @@ import_ownertrust( const char *fname )
            fpr[fprlen++] = HEXTOBIN(p[0]) * 16 + HEXTOBIN(p[1]);
        while (fprlen < 20)
            fpr[fprlen++] = 0;
-        
+
        rc = tdbio_search_trust_byfpr (fpr, &rec);
        if( !rc ) { /* found: update */
            if (rec.r.trust.ownertrust != otrust)
@@ -191,7 +204,7 @@ import_ownertrust( const char *fname )
                 any = 1;
               }
        }
-       else if( rc == -1 ) { /* not found: insert */
+       else if (gpg_err_code (rc) == GPG_ERR_NOT_FOUND) { /* insert */
             log_info("inserting ownertrust of %u\n", otrust );
             memset (&rec, 0, sizeof rec);
             rec.recnum = tdbio_new_recnum ();
@@ -202,14 +215,14 @@ import_ownertrust( const char *fname )
             any = 1;
        }
        else /* error */
-           log_error (_("\b%s: error finding trust record: %s\n"),
-                      fname, gpg_strerror (rc));
+           log_error (_("error finding trust record in '%s': %s\n"),
+                       fname, gpg_strerror (rc));
     }
-    if( ferror(fp) )
-       log_error (_("\b%s: read error: %s\n"), fname, strerror(errno) );
-    if( !is_stdin )
-       fclose(fp);
-    
+    if (es_ferror (fp))
+       log_error ( _("read error in '%s': %s\n"), fname, strerror(errno) );
+    if (!is_stdin)
+       es_fclose (fp);
+
     if (any)
       {
         revalidation_mark ();
@@ -217,7 +230,5 @@ import_ownertrust( const char *fname )
         if (rc)
           log_error (_("trustdb: sync failed: %s\n"), gpg_strerror (rc) );
       }
-    
-}
-
 
+}