blob: 3ea26c0fdcd332f54df34b9069dd9f44c4a41f2d [file] [log] [blame]
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#import <Foundation/Foundation.h>
#include "base/memory/ref_counted.h"
#include "net/cert/cert_status_flags.h"
namespace net {
class X509Certificate;
#pragma mark - CRWSessionCertificateStorage
namespace web {
// Serialization keys used in CRWSessionCertificateStorage's NSCoding
// implementation.
extern NSString* const kCertificateSerializationKey;
extern NSString* const kHostSerializationKey;
extern NSString* const kStatusSerializationKey;
} // namespace web
// A serializable representation of a certificate.
@interface CRWSessionCertificateStorage : NSObject<NSCoding>
// Designated initializer.
- (instancetype)initWithCertificate:(scoped_refptr<net::X509Certificate>)cert
host:(const std::string&)host
- (instancetype)init NS_UNAVAILABLE;
// The certificate represented by this storage.
@property(nonatomic, readonly) net::X509Certificate* certificate;
// The hostname of the page that issued |certificate|.
@property(nonatomic, readonly) std::string& host;
// The allowance chosen for the certificate.
@property(nonatomic, readonly) net::CertStatus status;
#pragma mark - CRWSessionCertificatePolicyCacheStorage
namespace web {
// Serialization key used in CRWSessionCertificatePolicyCacheStorage's NSCoding
// implementation.
extern NSString* const kCertificateStoragesKey;
} // namespace web
// A serializable representation of a list of allowed certificates.
@interface CRWSessionCertificatePolicyCacheStorage : NSObject<NSCoding>
// The certificate policy storages for this session.
@property(nonatomic, strong) NSSet* certificateStorages;