// Copyright 2014 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 COMPONENTS_PAIRING_CONTROLLER_PAIRING_CONTROLLER_H_
#define COMPONENTS_PAIRING_CONTROLLER_PAIRING_CONTROLLER_H_
#include <string>
#include <vector>
#include "base/macros.h"
namespace chromeos {
class UserContext;
}
namespace content {
class BrowserContext;
}
namespace pairing_chromeos {
class ControllerPairingController {
public:
enum Stage {
STAGE_NONE,
STAGE_INITIALIZATION_ERROR,
STAGE_DEVICES_DISCOVERY,
STAGE_DEVICE_NOT_FOUND,
STAGE_ESTABLISHING_CONNECTION,
STAGE_ESTABLISHING_CONNECTION_ERROR,
STAGE_WAITING_FOR_CODE_CONFIRMATION,
STAGE_HOST_UPDATE_IN_PROGRESS,
STAGE_HOST_CONNECTION_LOST,
STAGE_WAITING_FOR_CREDENTIALS,
STAGE_HOST_ENROLLMENT_IN_PROGRESS,
STAGE_HOST_ENROLLMENT_ERROR,
STAGE_PAIRING_DONE,
STAGE_FINISHED
};
class Observer {
public:
Observer();
virtual ~Observer();
// Called when pairing has moved on from one stage to another.
virtual void PairingStageChanged(Stage new_stage) = 0;
// Called when new device was discovered or existing device was lost.
// This notification is made only on |STAGE_DEVICES_DISCOVERY| stage.
virtual void DiscoveredDevicesListChanged() = 0;
private:
DISALLOW_COPY_AND_ASSIGN(Observer);
};
typedef std::vector<std::string> DeviceIdList;
ControllerPairingController();
virtual ~ControllerPairingController();
// Returns current stage of pairing process.
virtual Stage GetCurrentStage() = 0;
// Starts pairing process. Can be called only on |STAGE_NONE| stage.
virtual void StartPairing() = 0;
// Returns list of discovered devices. Can be called only on
// |STAGE_DEVICES_DISCOVERY| stage.
virtual DeviceIdList GetDiscoveredDevices() = 0;
// This method is called to start pairing with the device having |device_id|
// ID. Can be called only on |STAGE_DEVICES_DISCOVERY| stage.
virtual void ChooseDeviceForPairing(const std::string& device_id) = 0;
// Rescan for devices to pair with. Can be called only on
// stages |STAGE_DEVICE_NOT_FOUND|, |STAGE_ESTABLISHING_CONNECTION_ERROR|,
// |STAGE_HOST_ENROLLMENT_ERROR|.
virtual void RepeatDiscovery() = 0;
// Returns pairing confirmation code.
// Could be called only on |STATE_WAITING_FOR_CODE_CONFIRMATION| stage.
virtual std::string GetConfirmationCode() = 0;
// Called to confirm or deny confirmation code. Can be called only on
// |STAGE_WAITING_FOR_CODE_CONFIRMATION| stage.
virtual void SetConfirmationCodeIsCorrect(bool correct) = 0;
// Set the values that will be sent to the host if it needs to be configured.
virtual void SetHostConfiguration(bool accepted_eula,
const std::string& lang,
const std::string& timezone,
bool send_reports,
const std::string& keyboard_layout) = 0;
// Called when user successfully authenticated on GAIA page. Can be called
// only on |STAGE_WAITING_FOR_CREDENTIALS| stage.
// |auth_token| will be sent to the host to be used for enrollment.
virtual void OnAuthenticationDone(const std::string& domain,
const std::string& auth_token) = 0;
// Installs app and starts session.
// Can be called only on |STAGE_PAIRING_DONE| stage.
virtual void StartSession() = 0;
virtual void AddObserver(Observer* observer) = 0;
virtual void RemoveObserver(Observer* observer) = 0;
private:
DISALLOW_COPY_AND_ASSIGN(ControllerPairingController);
};
} // namespace pairing_chromeos
#endif // COMPONENTS_PAIRING_CONTROLLER_PAIRING_CONTROLLER_H_