| // 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 |