blob: 416702083218287ea101260d5b0a4bb0aa39b762 [file] [log] [blame]
// Copyright 2019 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.
#include "hermes/daemon.h"
#include <memory>
#include <utility>
#include <base/threading/thread_task_runner_handle.h>
#include <chromeos/dbus/service_constants.h>
#include <google-lpa/lpa/core/lpa.h>
#include "hermes/context.h"
#include "hermes/modem_qrtr.h"
#include "hermes/socket_qrtr.h"
namespace hermes {
Daemon::Daemon()
: DBusServiceDaemon(kHermesServiceName),
executor_(base::ThreadTaskRunnerHandle::Get()),
smdp_(&logger_, &executor_),
glib_bridge_(std::make_unique<glib_bridge::GlibBridge>()) {
glib_bridge::ForwardLogs();
}
void Daemon::RegisterDBusObjectsAsync(
brillo::dbus_utils::AsyncEventSequencer* sequencer) {
static_assert(USE_QRTR, "Only QRTR modems are supported");
modem_ =
ModemQrtr::Create(std::make_unique<SocketQrtr>(), &logger_, &executor_);
lpa::core::Lpa::Builder b;
b.SetEuiccCard(modem_.get())
.SetSmdpClientFactory(&smdp_)
.SetSmdsClientFactory(&smds_)
.SetLogger(&logger_);
lpa_ = b.Build();
Context::Initialize(bus_, lpa_.get(), &executor_, &adaptor_factory_,
modem_.get());
manager_ = std::make_unique<Manager>();
auto cb = base::BindOnce([](int err) {
if (err) {
LOG(ERROR) << "eSIM init failed with err:" << err;
return;
}
LOG(INFO) << "eSIM init finished";
});
modem_->Initialize(manager_.get(), std::move(cb));
}
} // namespace hermes