// Copyright 2012 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chromeos/ash/components/system/kiosk_oem_manifest_parser.h"
#include <memory>
#include "base/json/json_file_value_serializer.h"
#include "base/values.h"
namespace ash {
namespace {
const char kEnterpriseManaged[] = "enterprise_managed";
const char kAllowReset[] = "can_exit_enrollment";
const char kDeviceRequisition[] = "device_requisition";
const char kKeyboardDrivenOobe[] = "keyboard_driven_oobe";
} // namespace
KioskOemManifestParser::Manifest::Manifest()
: enterprise_managed(false),
can_exit_enrollment(true),
keyboard_driven_oobe(false) {}
bool KioskOemManifestParser::Load(const base::FilePath& kiosk_oem_file,
KioskOemManifestParser::Manifest* manifest) {
int error_code = JSONFileValueDeserializer::JSON_NO_ERROR;
std::string error_msg;
auto deserializer =
std::make_unique<JSONFileValueDeserializer>(kiosk_oem_file);
std::unique_ptr<base::Value> value =
deserializer->Deserialize(&error_code, &error_msg);
if (error_code != JSONFileValueDeserializer::JSON_NO_ERROR || !value ||
!value->is_dict()) {
return false;
}
base::Value::Dict& value_dict = value->GetDict();
if (auto* v = value_dict.FindString(kDeviceRequisition)) {
manifest->device_requisition = *v;
}
if (std::optional<bool> v = value_dict.FindBool(kKeyboardDrivenOobe)) {
manifest->keyboard_driven_oobe = *v;
}
if (std::optional<bool> v = value_dict.FindBool(kEnterpriseManaged)) {
manifest->enterprise_managed = *v;
} else {
return false;
}
if (std::optional<bool> v = value_dict.FindBool(kAllowReset)) {
manifest->can_exit_enrollment = *v;
} else {
return false;
}
return true;
}
} // namespace ash