| // Copyright 2015 The Weave 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 LIBWEAVE_SRC_PRIVET_SECURITY_DELEGATE_H_ | 
 | #define LIBWEAVE_SRC_PRIVET_SECURITY_DELEGATE_H_ | 
 |  | 
 | #include <memory> | 
 | #include <set> | 
 | #include <string> | 
 |  | 
 | #include <base/time/time.h> | 
 |  | 
 | #include "src/privet/privet_types.h" | 
 |  | 
 | namespace weave { | 
 | namespace privet { | 
 |  | 
 | // Interface to provide Security related logic for |PrivetHandler|. | 
 | class SecurityDelegate { | 
 |  public: | 
 |   virtual ~SecurityDelegate() = default; | 
 |  | 
 |   // Creates access token for the given scope, user id and |time|. | 
 |   virtual std::string CreateAccessToken(const UserInfo& user_info, | 
 |                                         const base::Time& time) = 0; | 
 |  | 
 |   // Validates |token| and returns scope and user id parsed from that. | 
 |   virtual UserInfo ParseAccessToken(const std::string& token, | 
 |                                     base::Time* time) const = 0; | 
 |  | 
 |   // Returns list of pairing methods by device. | 
 |   virtual std::set<PairingType> GetPairingTypes() const = 0; | 
 |  | 
 |   // Returns list of crypto methods supported by devices. | 
 |   virtual std::set<CryptoType> GetCryptoTypes() const = 0; | 
 |  | 
 |   // Returns true if |auth_code| provided by client is valid. Client should | 
 |   // obtain |auth_code| during pairing process. | 
 |   virtual bool IsValidPairingCode(const std::string& auth_code) const = 0; | 
 |  | 
 |   virtual bool StartPairing(PairingType mode, | 
 |                             CryptoType crypto, | 
 |                             std::string* session_id, | 
 |                             std::string* device_commitment, | 
 |                             ErrorPtr* error) = 0; | 
 |  | 
 |   virtual bool ConfirmPairing(const std::string& session_id, | 
 |                               const std::string& client_commitment, | 
 |                               std::string* fingerprint, | 
 |                               std::string* signature, | 
 |                               ErrorPtr* error) = 0; | 
 |  | 
 |   virtual bool CancelPairing(const std::string& session_id, | 
 |                              ErrorPtr* error) = 0; | 
 | }; | 
 |  | 
 | }  // namespace privet | 
 | }  // namespace weave | 
 |  | 
 | #endif  // LIBWEAVE_SRC_PRIVET_SECURITY_DELEGATE_H_ |