1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
|
// 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/functional/bind.h"
#include "base/functional/callback.h"
#include "base/logging.h"
#include "base/memory/ptr_util.h"
#include "chrome/browser/ash/borealis/borealis_features.h"
#include "chrome/browser/ash/borealis/borealis_service.h"
#include "chrome/browser/ash/borealis/borealis_service_factory.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 "ui/aura/window.h"
namespace borealis {
void BorealisSecurityDelegate::Build(
Profile* profile,
std::string vm_name,
base::OnceCallback<void(std::unique_ptr<guest_os::GuestOsSecurityDelegate>)>
callback) {
BorealisServiceFactory::GetForProfile(profile)->Features().IsAllowed(
base::BindOnce(
[](Profile* profile, std::string vm_name,
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;
}
BorealisSecurityDelegate* delegate =
new BorealisSecurityDelegate(profile, std::move(vm_name));
// Use WrapUnique due to private constructor.
std::move(callback).Run(base::WrapUnique(delegate));
},
profile, std::move(vm_name), std::move(callback)));
}
BorealisSecurityDelegate::~BorealisSecurityDelegate() = default;
bool BorealisSecurityDelegate::CanSelfActivate(aura::Window* window) const {
return BorealisServiceFactory::GetForProfile(profile_)
->WindowManager()
.GetShelfAppId(window) == kClientAppId;
}
bool BorealisSecurityDelegate::CanLockPointer(aura::Window* window) const {
return window->GetProperty(chromeos::kUseOverviewToExitPointerLock);
}
exo::SecurityDelegate::SetBoundsPolicy BorealisSecurityDelegate::CanSetBounds(
aura::Window* window) const {
return exo::SecurityDelegate::SetBoundsPolicy::ADJUST_IF_DECORATED;
}
// static
std::unique_ptr<BorealisSecurityDelegate>
BorealisSecurityDelegate::MakeForTesting(Profile* profile) {
BorealisSecurityDelegate* delegate =
new BorealisSecurityDelegate(profile, std::string());
// Use WrapUnique due to private constructor.
return base::WrapUnique(delegate);
}
BorealisSecurityDelegate::BorealisSecurityDelegate(Profile* profile,
std::string vm_name)
: guest_os::GuestOsSecurityDelegate(std::move(vm_name)),
profile_(profile) {}
} // namespace borealis
|