Move certificateProvider out of //ash

This change is a necessary part of smart cards migration to Lacros.

Bug: 1291887
Change-Id: I418d617da74b4eda7a8d660f509c53926536cf4d
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3645419
Reviewed-by: Hidehiko Abe <[email protected]>
Reviewed-by: Reilly Grant <[email protected]>
Commit-Queue: Oleksandr Kulkov <[email protected]>
Reviewed-by: Maksim Ivanov <[email protected]>
Reviewed-by: Vasilii Sukhanov <[email protected]>
Reviewed-by: Peter Kasting <[email protected]>
Reviewed-by: Denis Kuznetsov <[email protected]>
Reviewed-by: Ted Choc <[email protected]>
Reviewed-by: Alexander Alekseev <[email protected]>
Reviewed-by: David Benjamin <[email protected]>
Cr-Commit-Position: refs/heads/main@{#1010040}
diff --git a/chrome/browser/certificate_provider/sign_requests.h b/chrome/browser/certificate_provider/sign_requests.h
new file mode 100644
index 0000000..ccb3d20
--- /dev/null
+++ b/chrome/browser/certificate_provider/sign_requests.h
@@ -0,0 +1,92 @@
+// Copyright 2015 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.
+
+#ifndef CHROME_BROWSER_CERTIFICATE_PROVIDER_SIGN_REQUESTS_H_
+#define CHROME_BROWSER_CERTIFICATE_PROVIDER_SIGN_REQUESTS_H_
+
+#include <map>
+#include <string>
+#include <utility>
+#include <vector>
+
+#include "base/callback.h"
+#include "base/memory/ref_counted.h"
+#include "components/account_id/account_id.h"
+#include "net/cert/x509_certificate.h"
+#include "net/ssl/ssl_private_key.h"
+#include "third_party/abseil-cpp/absl/types/optional.h"
+
+namespace chromeos {
+namespace certificate_provider {
+
+class SignRequests {
+ public:
+  using ExtensionNameRequestIdPair = std::pair<std::string, int>;
+
+  SignRequests();
+  ~SignRequests();
+
+  // Returns the id of the new request. The returned request id is specific to
+  // the given extension.
+  int AddRequest(
+      const std::string& extension_id,
+      const scoped_refptr<net::X509Certificate>& certificate,
+      const absl::optional<AccountId>& authenticating_user_account_id,
+      net::SSLPrivateKey::SignCallback callback);
+
+  // Returns the list of requests that correspond to the authentication of the
+  // given user.
+  std::vector<ExtensionNameRequestIdPair> FindRequestsForAuthenticatingUser(
+      const AccountId& authenticating_user_account_id) const;
+
+  // Returns false if no request with the given id for |extension_id|
+  // could be found. Otherwise removes the request and sets |certificate| and
+  // |callback| to the values that were provided with AddRequest().
+  bool RemoveRequest(const std::string& extension_id,
+                     int request_id,
+                     scoped_refptr<net::X509Certificate>* certificate,
+                     net::SSLPrivateKey::SignCallback* callback);
+
+  // Remove all pending requests for this extension and return their
+  // callbacks.
+  std::vector<net::SSLPrivateKey::SignCallback> RemoveAllRequests(
+      const std::string& extension_id);
+
+ private:
+  struct Request {
+    Request(const scoped_refptr<net::X509Certificate>& certificate,
+            const absl::optional<AccountId>& authenticating_user_account_id,
+            net::SSLPrivateKey::SignCallback callback);
+    Request(Request&& other);
+    Request& operator=(Request&&);
+    ~Request();
+
+    scoped_refptr<net::X509Certificate> certificate;
+    absl::optional<AccountId> authenticating_user_account_id;
+    net::SSLPrivateKey::SignCallback callback;
+  };
+
+  // Holds state of all sign requests to a single extension.
+  struct RequestsState {
+    RequestsState();
+    RequestsState(RequestsState&& other);
+    RequestsState& operator=(RequestsState&&);
+    ~RequestsState();
+
+    // Maps from request id to the request state.
+    std::map<int, Request> pending_requests;
+
+    // The request id that will be used for the next sign request to this
+    // extension.
+    int next_free_id = 0;
+  };
+
+  // Contains the state of all sign requests per extension.
+  std::map<std::string, RequestsState> extension_to_requests_;
+};
+
+}  // namespace certificate_provider
+}  // namespace chromeos
+
+#endif  // CHROME_BROWSER_CERTIFICATE_PROVIDER_SIGN_REQUESTS_H_