| // 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() {} |
| |
| // Creates access token for the given scope, user id and |time|. |
| virtual bool CreateAccessToken(AuthType auth_type, |
| const std::string& auth_code, |
| AuthScope desired_scope, |
| std::string* access_token, |
| AuthScope* granted_scope, |
| base::TimeDelta* ttl, |
| ErrorPtr* error) = 0; |
| |
| // Validates |token| and returns scope, user id parsed from that. |
| virtual bool ParseAccessToken(const std::string& token, |
| UserInfo* user_info, |
| ErrorPtr* error) 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 list of auth methods supported by devices. |
| virtual std::set<AuthType> GetAuthTypes() const = 0; |
| |
| // Returns Root Client Authorization Token. |
| virtual std::string ClaimRootClientAuthToken(ErrorPtr* error) = 0; |
| |
| // Confirms pending token claim or checks that token is valid for the active |
| // secret. |
| virtual bool ConfirmClientAuthToken(const std::string& token, |
| ErrorPtr* error) = 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; |
| |
| virtual std::string CreateSessionId() = 0; |
| }; |
| |
| } // namespace privet |
| } // namespace weave |
| |
| #endif // LIBWEAVE_SRC_PRIVET_SECURITY_DELEGATE_H_ |