g10: Fix import/export filter property match.
[gnupg.git] / g10 / tdbdump.c
index 5e7b685..5ea903f 100644 (file)
@@ -14,7 +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, see <http://www.gnu.org/licenses/>.
+ * along with this program; if not, see <https://www.gnu.org/licenses/>.
  */
 
 #include <config.h>
 #include <string.h>
 #include <errno.h>
 #include <ctype.h>
-#include <assert.h>
 #include <sys/types.h>
 #include <sys/stat.h>
 #include <fcntl.h>
 #include <unistd.h>
 
 #include "gpg.h"
-#include "status.h"
-#include "iobuf.h"
+#include "../common/status.h"
+#include "../common/iobuf.h"
 #include "keydb.h"
-#include "util.h"
+#include "../common/util.h"
 #include "trustdb.h"
 #include "options.h"
 #include "packet.h"
 #include "main.h"
-#include "i18n.h"
+#include "../common/i18n.h"
 #include "tdbio.h"
 
 
                      (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 )
+write_record (ctrl_t ctrl, TRUSTREC *rec)
 {
-    int rc = tdbio_write_record( rec );
+    int rc = tdbio_write_record (ctrl, rec);
     if( !rc )
        return;
     log_error(_("trust record %lu, type %d: write failed: %s\n"),
-                           rec->recnum, rec->rectype, g10_errstr(rc) );
+                           rec->recnum, rec->rectype, gpg_strerror (rc) );
     tdbio_invalid();
 }
 
 
-/****************
- * 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 (ctrl_t ctrl, 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 (ctrl, 0);
+  /* 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);
     }
 }
 
@@ -92,34 +94,36 @@ list_trustdb( const char *username )
  * Print a list of all defined owner trust value.
  */
 void
-export_ownertrust()
+export_ownertrust (ctrl_t ctrl)
 {
-    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 (ctrl, 0);
+  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 );
        }
     }
 }
 
 
 void
-import_ownertrust( const char *fname )
+import_ownertrust (ctrl_t ctrl, const char *fname )
 {
-    FILE *fp;
+    estream_t fp;
     int is_stdin=0;
     char line[256];
     char *p;
@@ -129,33 +133,33 @@ import_ownertrust( const char *fname )
     int any = 0;
     int rc;
 
-    init_trustdb();
+    init_trustdb (ctrl, 0);
     if( iobuf_is_pipe_filename (fname) ) {
-       fp = stdin;
+       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;
     }
 
-    if (is_secured_file (fileno (fp)))
+    if (is_secured_file (es_fileno (fp)))
       {
-        fclose (fp);
-        errno = EPERM;
-       log_error (_("can't open `%s': %s\n"), fname, strerror(errno) );
+        es_fclose (fp);
+        gpg_err_set_errno (EPERM);
+       log_error (_("can't open '%s': %s\n"), fname, strerror(errno) );
        return;
       }
 
-    while( fgets( line, DIM(line)-1, fp ) ) {
+    while (es_fgets (line, DIM(line)-1, fp)) {
        TRUSTREC rec;
 
        if( !*line || *line == '#' )
            continue;
        n = strlen(line);
        if( line[n-1] != '\n' ) {
-           log_error (_("error in `%s': %s\n"), fname, _("line too long") );
+           log_error (_("error in '%s': %s\n"), fname, _("line too long") );
            /* ... or last line does not have a LF */
            break; /* can't continue */
        }
@@ -163,17 +167,17 @@ import_ownertrust( const char *fname )
            if( !hexdigitp(p) )
                break;
        if( *p != ':' ) {
-           log_error (_("error in `%s': %s\n"), fname, _("colon missing") );
+           log_error (_("error in '%s': %s\n"), fname, _("colon missing") );
            continue;
        }
        fprlen = p - line;
        if( fprlen != 32 && fprlen != 40 ) {
-           log_error (_("error in `%s': %s\n"),
+           log_error (_("error in '%s': %s\n"),
                        fname, _("invalid fingerprint") );
            continue;
        }
        if( sscanf(p, ":%u:", &otrust ) != 1 ) {
-           log_error (_("error in `%s': %s\n"),
+           log_error (_("error in '%s': %s\n"),
                        fname, _("ownertrust value missing"));
            continue;
        }
@@ -184,48 +188,50 @@ 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)
               {
-                if( rec.r.trust.ownertrust )
-                  log_info("changing ownertrust from %u to %u\n",
-                           rec.r.trust.ownertrust, otrust );
-                else
-                  log_info("setting ownertrust to %u\n", otrust );
+                if (!opt.quiet)
+                  {
+                    if( rec.r.trust.ownertrust )
+                      log_info("changing ownertrust from %u to %u\n",
+                               rec.r.trust.ownertrust, otrust );
+                    else
+                      log_info("setting ownertrust to %u\n", otrust );
+                  }
                 rec.r.trust.ownertrust = otrust;
-                write_record (&rec );
+                write_record (ctrl, &rec);
                 any = 1;
               }
        }
-       else if( rc == -1 ) { /* not found: insert */
-            log_info("inserting ownertrust of %u\n", otrust );
+       else if (gpg_err_code (rc) == GPG_ERR_NOT_FOUND) { /* insert */
+            if (!opt.quiet)
+              log_info("inserting ownertrust of %u\n", otrust );
             memset (&rec, 0, sizeof rec);
-            rec.recnum = tdbio_new_recnum ();
+            rec.recnum = tdbio_new_recnum (ctrl);
             rec.rectype = RECTYPE_TRUST;
             memcpy (rec.r.trust.fingerprint, fpr, 20);
             rec.r.trust.ownertrust = otrust;
-            write_record (&rec );
+            write_record (ctrl, &rec);
             any = 1;
        }
        else /* error */
-           log_error (_("error finding trust record in `%s': %s\n"),
-                       fname, g10_errstr(rc));
+           log_error (_("error finding trust record in '%s': %s\n"),
+                       fname, gpg_strerror (rc));
     }
-    if( ferror(fp) )
-       log_error ( _("read error in `%s': %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 ();
+        revalidation_mark (ctrl);
         rc = tdbio_sync ();
         if (rc)
-          log_error (_("trustdb: sync failed: %s\n"), g10_errstr(rc) );
+          log_error (_("trustdb: sync failed: %s\n"), gpg_strerror (rc) );
       }
-    
-}
-
 
+}