1116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch// Copyright 2014 The Chromium Authors. All rights reserved.
2116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch// Use of this source code is governed by a BSD-style license that can be
3116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch// found in the LICENSE file.
4116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch
5116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch#ifndef NET_CERT_CRL_SET_STORAGE_H_
6116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch#define NET_CERT_CRL_SET_STORAGE_H_
7116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch
8116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch#include <string>
9116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch#include <utility>
10116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch#include <vector>
11116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch
12116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch#include "base/strings/string_piece.h"
13116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch#include "net/base/net_export.h"
14116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch#include "net/cert/crl_set.h"
15116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch
16116680a4aac90f2aa7413d9095a592090648e557Ben Murdochnamespace base {
17116680a4aac90f2aa7413d9095a592090648e557Ben Murdochclass DictionaryValue;
18116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch}
19116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch
20116680a4aac90f2aa7413d9095a592090648e557Ben Murdochnamespace net {
21116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch
22116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch// Static helpers to save and load CRLSet.
23116680a4aac90f2aa7413d9095a592090648e557Ben Murdochclass NET_EXPORT CRLSetStorage {
24116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch public:
25116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  // Parse parses the bytes in |data| and, on success, puts a new CRLSet in
26116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  // |out_crl_set| and returns true.
27116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  static bool Parse(base::StringPiece data,
28116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch                    scoped_refptr<CRLSet>* out_crl_set);
29116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch
30116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  // ApplyDelta returns a new CRLSet in |out_crl_set| that is the result of
31116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  // updating |in_crl_set| with the delta information in |delta_bytes|.
32116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  static bool ApplyDelta(const CRLSet* in_crl_set,
33116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch                         const base::StringPiece& delta_bytes,
34116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch                         scoped_refptr<CRLSet>* out_crl_set);
35116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch
36116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  // GetIsDeltaUpdate extracts the header from |bytes|, sets *is_delta to
37116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  // whether |bytes| is a delta CRL set or not and returns true. In the event
38116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  // of a parse error, it returns false.
39116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  static bool GetIsDeltaUpdate(const base::StringPiece& bytes, bool *is_delta);
40116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch
41116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  // Serialize returns a string of bytes suitable for passing to Parse. Parsing
42116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  // and serializing a CRLSet is a lossless operation - the resulting bytes
43116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  // will be equal.
44116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  static std::string Serialize(const CRLSet* crl_set);
45116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch
46116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch private:
47116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  // CopyBlockedSPKIsFromHeader sets |blocked_spkis_| to the list of values
48116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  // from "BlockedSPKIs" in |header_dict|.
49116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch  static bool CopyBlockedSPKIsFromHeader(CRLSet* crl_set,
50116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch                                         base::DictionaryValue* header_dict);
51116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch};
52116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch
53116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch}  // namespace net
54116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch
55116680a4aac90f2aa7413d9095a592090648e557Ben Murdoch#endif  // NET_CERT_CRL_SET_STORAGE_H_
56