xref: /aosp_15_r20/external/cronet/net/cert/client_cert_verifier.h (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1*6777b538SAndroid Build Coastguard Worker // Copyright 2015 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker 
5*6777b538SAndroid Build Coastguard Worker #ifndef NET_CERT_CLIENT_CERT_VERIFIER_H_
6*6777b538SAndroid Build Coastguard Worker #define NET_CERT_CLIENT_CERT_VERIFIER_H_
7*6777b538SAndroid Build Coastguard Worker 
8*6777b538SAndroid Build Coastguard Worker #include <memory>
9*6777b538SAndroid Build Coastguard Worker 
10*6777b538SAndroid Build Coastguard Worker #include "net/base/completion_once_callback.h"
11*6777b538SAndroid Build Coastguard Worker #include "net/base/net_export.h"
12*6777b538SAndroid Build Coastguard Worker 
13*6777b538SAndroid Build Coastguard Worker namespace net {
14*6777b538SAndroid Build Coastguard Worker 
15*6777b538SAndroid Build Coastguard Worker class X509Certificate;
16*6777b538SAndroid Build Coastguard Worker 
17*6777b538SAndroid Build Coastguard Worker // ClientCertVerifier represents a service for verifying certificates.
18*6777b538SAndroid Build Coastguard Worker class NET_EXPORT ClientCertVerifier {
19*6777b538SAndroid Build Coastguard Worker  public:
20*6777b538SAndroid Build Coastguard Worker   class Request {
21*6777b538SAndroid Build Coastguard Worker    public:
22*6777b538SAndroid Build Coastguard Worker     Request() = default;
23*6777b538SAndroid Build Coastguard Worker 
24*6777b538SAndroid Build Coastguard Worker     Request(const Request&) = delete;
25*6777b538SAndroid Build Coastguard Worker     Request& operator=(const Request&) = delete;
26*6777b538SAndroid Build Coastguard Worker 
27*6777b538SAndroid Build Coastguard Worker     // Destruction of the Request cancels it.
28*6777b538SAndroid Build Coastguard Worker     virtual ~Request() = default;
29*6777b538SAndroid Build Coastguard Worker   };
30*6777b538SAndroid Build Coastguard Worker 
31*6777b538SAndroid Build Coastguard Worker   virtual ~ClientCertVerifier() = default;
32*6777b538SAndroid Build Coastguard Worker 
33*6777b538SAndroid Build Coastguard Worker   // Verifies the given certificate as a client certificate.
34*6777b538SAndroid Build Coastguard Worker   // Returns OK if successful or an error code upon failure.
35*6777b538SAndroid Build Coastguard Worker   virtual int Verify(X509Certificate* cert,
36*6777b538SAndroid Build Coastguard Worker                      CompletionOnceCallback callback,
37*6777b538SAndroid Build Coastguard Worker                      std::unique_ptr<Request>* out_req) = 0;
38*6777b538SAndroid Build Coastguard Worker };
39*6777b538SAndroid Build Coastguard Worker 
40*6777b538SAndroid Build Coastguard Worker }  // namespace net
41*6777b538SAndroid Build Coastguard Worker 
42*6777b538SAndroid Build Coastguard Worker #endif  // NET_CERT_CLIENT_CERT_VERIFIER_H_
43