blob: f69ffb26f3fe1c5cd5d86271c47db9871edf82a8 [file] [log] [blame]
// Copyright 2014 The Chromium OS 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 BUFFET_PRIVET_SECURITY_DELEGATE_H_
#define BUFFET_PRIVET_SECURITY_DELEGATE_H_
#include <memory>
#include <set>
#include <string>
#include <base/time/time.h>
#include <chromeos/secure_blob.h>
#include "buffet/privet/privet_types.h"
namespace privetd {
enum class PairingType {
kPinCode,
kEmbeddedCode,
kUltrasound32,
kAudible32,
};
enum class CryptoType {
kNone,
kSpake_p224,
kSpake_p256,
};
// 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,
chromeos::ErrorPtr* error) = 0;
virtual bool ConfirmPairing(const std::string& session_id,
const std::string& client_commitment,
std::string* fingerprint,
std::string* signature,
chromeos::ErrorPtr* error) = 0;
virtual bool CancelPairing(const std::string& session_id,
chromeos::ErrorPtr* error) = 0;
};
bool StringToPairingType(const std::string& mode, PairingType* id);
std::string PairingTypeToString(PairingType id);
bool StringToAuthScope(const std::string& scope, AuthScope* id);
std::string AuthScopeToString(AuthScope id);
} // namespace privetd
#endif // BUFFET_PRIVET_SECURITY_DELEGATE_H_