1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 // This utility can dump the contents of CRL set, optionally augmented with a
14 #include "base/at_exit.h"
15 #include "base/file_util.h"
16 #include "base/memory/ref_counted.h"
17 #include "base/strings/string_number_conversions.h"
18 #include "net/cert/crl_set.h"
19 #include "net/cert/crl_set_storage.h"
21 static int Usage(const char* argv0
) {
22 fprintf(stderr
, "Usage: %s <crl-set file> [<delta file>]"
23 " [<resulting output file>]\n", argv0
);
27 int main(int argc
, char** argv
) {
28 base::AtExitManager at_exit_manager
;
30 base::FilePath crl_set_filename
, delta_filename
, output_filename
;
32 if (argc
< 2 || argc
> 4)
33 return Usage(argv
[0]);
35 crl_set_filename
= base::FilePath::FromUTF8Unsafe(argv
[1]);
37 delta_filename
= base::FilePath::FromUTF8Unsafe(argv
[2]);
39 output_filename
= base::FilePath::FromUTF8Unsafe(argv
[3]);
41 std::string crl_set_bytes
, delta_bytes
;
42 if (!base::ReadFileToString(crl_set_filename
, &crl_set_bytes
))
44 if (!delta_filename
.empty() &&
45 !base::ReadFileToString(delta_filename
, &delta_bytes
)) {
49 scoped_refptr
<net::CRLSet
> crl_set
, final_crl_set
;
50 if (!net::CRLSetStorage::Parse(crl_set_bytes
, &crl_set
)) {
51 fprintf(stderr
, "Failed to parse CRLSet\n");
55 if (!delta_bytes
.empty()) {
56 if (!net::CRLSetStorage::ApplyDelta(crl_set
, delta_bytes
, &final_crl_set
)) {
57 fprintf(stderr
, "Failed to apply delta to CRLSet\n");
61 final_crl_set
= crl_set
;
64 if (!output_filename
.empty()) {
65 const std::string out
= net::CRLSetStorage::Serialize(final_crl_set
);
66 if (base::WriteFile(output_filename
, out
.data(), out
.size()) == -1) {
67 fprintf(stderr
, "Failed to write resulting CRL set\n");
72 const net::CRLSet::CRLList
& crls
= final_crl_set
->crls();
73 for (net::CRLSet::CRLList::const_iterator i
= crls
.begin(); i
!= crls
.end();
75 printf("%s\n", base::HexEncode(i
->first
.data(), i
->first
.size()).c_str());
76 for (std::vector
<std::string
>::const_iterator j
= i
->second
.begin();
77 j
!= i
->second
.end(); j
++) {
78 printf(" %s\n", base::HexEncode(j
->data(), j
->size()).c_str());