blob: 3a4f06a73bca1fdbe5003a37e5c57fca29997994 [file] [log] [blame]
// Copyright 2021 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/ash/borealis/borealis_security_delegate.h"
#include "base/bind.h"
#include "base/callback.h"
#include "base/logging.h"
#include "chrome/browser/ash/borealis/borealis_features.h"
#include "chrome/browser/ash/borealis/borealis_service.h"
#include "chrome/browser/ash/borealis/borealis_util.h"
#include "chrome/browser/ash/borealis/borealis_window_manager.h"
#include "chromeos/ui/base/window_properties.h"
#include "third_party/cros_system_api/constants/vm_tools.h"
#include "ui/aura/window.h"
namespace borealis {
void BorealisSecurityDelegate::Build(
Profile* profile,
base::OnceCallback<void(std::unique_ptr<guest_os::GuestOsSecurityDelegate>)>
callback) {
BorealisService::GetForProfile(profile)->Features().IsAllowed(base::BindOnce(
[](Profile* profile,
base::OnceCallback<void(
std::unique_ptr<guest_os::GuestOsSecurityDelegate>)> callback,
BorealisFeatures::AllowStatus allow_status) {
if (allow_status != BorealisFeatures::AllowStatus::kAllowed) {
LOG(WARNING) << "Borealis is not allowed: " << allow_status;
std::move(callback).Run(nullptr);
return;
}
std::move(callback).Run(
std::make_unique<BorealisSecurityDelegate>(profile));
},
profile, std::move(callback)));
}
BorealisSecurityDelegate::BorealisSecurityDelegate(Profile* profile)
: profile_(profile) {}
BorealisSecurityDelegate::~BorealisSecurityDelegate() = default;
std::string BorealisSecurityDelegate::GetSecurityContext() const {
return vm_tools::kConciergeSecurityContext;
}
bool BorealisSecurityDelegate::CanSelfActivate(aura::Window* window) const {
return BorealisService::GetForProfile(profile_)
->WindowManager()
.GetShelfAppId(window) == kClientAppId;
}
bool BorealisSecurityDelegate::CanLockPointer(aura::Window* window) const {
return window->GetProperty(chromeos::kUseOverviewToExitPointerLock);
}
} // namespace borealis