blob: f64266f5fc93cfa3390de54f37e064fbdcf6e427 [file] [log] [blame]
// Copyright 2017 The Fuchsia 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 <stdlib.h>
#include <chrono>
#include <fstream>
#include <memory>
#include <string>
#include <thread>
#include <utility>
#include <fuchsia/cobalt/cpp/fidl.h>
#include <lib/async-loop/cpp/loop.h>
#include <lib/async/cpp/task.h>
#include "garnet/bin/cobalt/app/cobalt_app.h"
#include "garnet/bin/cobalt/app/product_hack.h"
#include "lib/fxl/command_line.h"
#include "lib/fxl/log_settings_command_line.h"
#include "lib/fxl/logging.h"
// Command-line flags
// Used to override kScheduleIntervalDefault;
constexpr fxl::StringView kScheduleIntervalSecondsFlagName =
"schedule_interval_seconds";
constexpr fxl::StringView kInitialIntervalSecondsFlagName =
"initial_interval_seconds";
// Used to override kMinIntervalDefault;
constexpr fxl::StringView kMinIntervalSecondsFlagName = "min_interval_seconds";
// We want to only upload every hour. This is the interval that will be
// approached by the uploader.
const std::chrono::hours kScheduleIntervalDefault(1);
// We start uploading every minute and exponentially back off until we reach 1
// hour.
const std::chrono::minutes kInitialIntervalDefault(1);
// We send Observations to the Shuffler more frequently than kScheduleInterval
// under some circumstances, namely, if there is memory pressure or if we
// are explicitly asked to do so via the RequestSendSoon() method. This value
// is a safety parameter. We do not make two attempts within a period of this
// specified length.
const std::chrono::seconds kMinIntervalDefault(10);
int main(int argc, const char** argv) {
setenv("GRPC_DEFAULT_SSL_ROOTS_FILE_PATH", "/config/ssl/cert.pem", 1);
// Parse the flags.
const auto command_line = fxl::CommandLineFromArgcArgv(argc, argv);
fxl::SetLogSettingsFromCommandLine(command_line);
if (fxl::GetVlogVerbosity() >= 10) {
setenv("GRPC_VERBOSITY", "DEBUG", 1);
setenv("GRPC_TRACE", "all,-timer,-timer_check", 1);
}
// Parse the schedule_interval_seconds flag.
std::chrono::seconds schedule_interval =
std::chrono::duration_cast<std::chrono::seconds>(
kScheduleIntervalDefault);
std::chrono::seconds initial_interval =
std::chrono::duration_cast<std::chrono::seconds>(kInitialIntervalDefault);
std::string flag_value;
if (command_line.GetOptionValue(kScheduleIntervalSecondsFlagName,
&flag_value)) {
int num_seconds = std::stoi(flag_value);
if (num_seconds > 0) {
schedule_interval = std::chrono::seconds(num_seconds);
// Set initial_interval, it can still be overridden by a flag.
initial_interval = std::chrono::seconds(num_seconds);
}
}
// Parse the initial_interval_seconds flag.
flag_value.clear();
if (command_line.GetOptionValue(kInitialIntervalSecondsFlagName,
&flag_value)) {
int num_seconds = std::stoi(flag_value);
if (num_seconds > 0) {
initial_interval = std::chrono::seconds(num_seconds);
}
}
// Parse the min_interval_seconds flag.
std::chrono::seconds min_interval =
std::chrono::duration_cast<std::chrono::seconds>(kMinIntervalDefault);
flag_value.clear();
if (command_line.GetOptionValue(kMinIntervalSecondsFlagName, &flag_value)) {
int num_seconds = std::stoi(flag_value);
// We allow min_interval = 0.
if (num_seconds >= 0) {
min_interval = std::chrono::seconds(num_seconds);
}
}
FXL_LOG(INFO) << "Cobalt client schedule params: schedule_interval="
<< schedule_interval.count()
<< " seconds, min_interval=" << min_interval.count()
<< " seconds, initial_interval=" << initial_interval.count()
<< " seconds.";
async::Loop loop(&kAsyncLoopConfigAttachToThread);
cobalt::CobaltApp app(loop.dispatcher(), schedule_interval, min_interval,
initial_interval, cobalt::hack::GetLayer());
loop.Run();
return 0;
}