blob: ed188142237c8662b98f6fecf4f9e147f7d51cff [file] [log] [blame]
// Copyright 2019 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 CHROMEOS_SERVICES_CELLULAR_SETUP_OTA_ACTIVATOR_H_
#define CHROMEOS_SERVICES_CELLULAR_SETUP_OTA_ACTIVATOR_H_
#include "base/callback.h"
#include "base/macros.h"
#include "chromeos/services/cellular_setup/public/mojom/cellular_setup.mojom.h"
#include "mojo/public/cpp/bindings/pending_remote.h"
#include "mojo/public/cpp/bindings/receiver.h"
namespace chromeos {
namespace cellular_setup {
// Activates a cellular SIM using the OTA mechanism. This class makes a single
// attempt at activation, then fires a callback on completion, regardless of
// success or failure. An OtaActivator object can only be used for one
// attempt; to perform a new activation attempt, use a separate OtaActivator
// instance.
class OtaActivator : public mojom::CarrierPortalHandler {
public:
~OtaActivator() override;
// Generates a mojo::PendingRemote<> bound to this instance. Only one
// mojo::PendingRemote<> may be bound to a single OtaActivator instance, so
// this function can only be called once.
mojo::PendingRemote<mojom::CarrierPortalHandler> GenerateRemote();
protected:
explicit OtaActivator(base::OnceClosure on_finished_callback);
void InvokeOnFinishedCallback();
base::OnceClosure on_finished_callback_;
mojo::Receiver<mojom::CarrierPortalHandler> receiver_{this};
DISALLOW_COPY_AND_ASSIGN(OtaActivator);
};
} // namespace cellular_setup
} // namespace chromeos
#endif // CHROMEOS_SERVICES_CELLULAR_SETUP_OTA_ACTIVATOR_H_