summaryrefslogtreecommitdiff
path: root/security/nss/cmd/ppcertdata/ppcertdata.c
diff options
context:
space:
mode:
Diffstat (limited to 'security/nss/cmd/ppcertdata/ppcertdata.c')
-rw-r--r--security/nss/cmd/ppcertdata/ppcertdata.c100
1 files changed, 0 insertions, 100 deletions
diff --git a/security/nss/cmd/ppcertdata/ppcertdata.c b/security/nss/cmd/ppcertdata/ppcertdata.c
deleted file mode 100644
index e1fb287b2..000000000
--- a/security/nss/cmd/ppcertdata/ppcertdata.c
+++ /dev/null
@@ -1,100 +0,0 @@
-/* This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-
-#include <stdio.h>
-#include <string.h>
-#include <ctype.h>
-#include <stdlib.h>
-#include "secutil.h"
-#include "nss.h"
-
-unsigned char binary_line[64 * 1024];
-
-int
-main(int argc, const char ** argv)
-{
- int skip_count = 0;
- int bytes_read;
- char line[133];
-
- if (argc > 1) {
- skip_count = atoi(argv[1]);
- }
- if (argc > 2 || skip_count < 0) {
- printf("Usage: %s [ skip_columns ] \n", argv[0]);
- return 1;
- }
-
- NSS_NoDB_Init(NULL);
-
- while (fgets(line, 132, stdin) && (bytes_read = strlen(line)) > 0 ) {
- int bytes_written;
- char * found;
- char * in = line + skip_count;
- int left = bytes_read - skip_count;
- int is_cert;
- int is_serial;
- int is_name;
- int is_hash;
- int use_pp = 0;
- int out = 0;
- SECItem der = {siBuffer, NULL, 0 };
-
- line[bytes_read] = 0;
- if (bytes_read <= skip_count)
- continue;
- fwrite(in, 1, left, stdout);
- found = strstr(in, "MULTILINE_OCTAL");
- if (!found)
- continue;
- fflush(stdout);
-
- is_cert = (NULL != strstr(in, "CKA_VALUE"));
- is_serial = (NULL != strstr(in, "CKA_SERIAL_NUMBER"));
- is_name = (NULL != strstr(in, "CKA_ISSUER")) ||
- (NULL != strstr(in, "CKA_SUBJECT"));
- is_hash = (NULL != strstr(in, "_HASH"));
- while (fgets(line, 132, stdin) &&
- (bytes_read = strlen(line)) > 0 ) {
- in = line + skip_count;
- left = bytes_read - skip_count;
-
- if ((left >= 3) && !strncmp(in, "END", 3))
- break;
- while (left >= 4) {
- if (in[0] == '\\' && isdigit(in[1]) &&
- isdigit(in[2]) && isdigit(in[3])) {
- left -= 4;
- binary_line[out++] = ((in[1] - '0') << 6) |
- ((in[2] - '0') << 3) |
- (in[3] - '0');
- in += 4;
- } else
- break;
- }
- }
- der.data = binary_line;
- der.len = out;
- if (is_cert)
- SECU_PrintSignedData(stdout, &der, "Certificate", 0,
- SECU_PrintCertificate);
- else if (is_name)
- SECU_PrintDERName(stdout, &der, "Name", 0);
- else if (is_serial) {
- if (out > 2 && binary_line[0] == 2 &&
- out == 2 + binary_line[1]) {
- der.data += 2;
- der.len -= 2;
- SECU_PrintInteger(stdout, &der, "DER Serial Number", 0);
- } else
- SECU_PrintInteger(stdout, &der, "Raw Serial Number", 0);
- } else if (is_hash)
- SECU_PrintAsHex(stdout, &der, "Hash", 0);
- else
- SECU_PrintBuf(stdout, "Other", binary_line, out);
- }
- NSS_Shutdown();
- return 0;
-}
-