chromium/chrome/browser/ash/file_manager/fusebox_daemon.h

// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CHROME_BROWSER_ASH_FILE_MANAGER_FUSEBOX_DAEMON_H_
#define CHROME_BROWSER_ASH_FILE_MANAGER_FUSEBOX_DAEMON_H_

#include <map>
#include <string>

#include "base/component_export.h"
#include "base/memory/raw_ptr.h"
#include "base/memory/ref_counted.h"
#include "base/memory/weak_ptr.h"
#include "chromeos/ash/components/disks/disk_mount_manager.h"

namespace file_manager {

class COMPONENT_EXPORT(ASH_DBUS_CROS_DISKS) FuseBoxDaemon
    : public base::RefCounted<FuseBoxDaemon> {
 public:
  // Returns the fusebox daemon. Creates the fusebox daemon if needed.
  static scoped_refptr<FuseBoxDaemon> GetInstance();

  // Attach fusebox storage: adds fusebox daemon <mount-point>/subdir used to
  // serve the content of the Chrome storage::FileSystemURL |url| via FUSE to
  // the Linux file system. The <mount-point>/subdir content is read-write by
  // default: use |read_only| true to make the content read-only.
  void AttachStorage(const std::string& subdir,
                     const std::string& url,
                     bool read_only);

  // Detach fusebox storage: removes fusebox daemon <mount-point>/subdir.
  void DetachStorage(const std::string& subdir);

 private:
  friend class base::RefCounted<FuseBoxDaemon>;

  FuseBoxDaemon();
  ~FuseBoxDaemon();

  // Cros-disks mount manager.
  using CrosDisksMountManager = ::ash::disks::DiskMountManager;
  raw_ptr<CrosDisksMountManager> cros_disks_mount_manager_ = nullptr;

  // FuseBox daemon URI: cros-disks URI protocol is fusebox://<mount-point>.
  static char* CrosDisksFuseBoxHelperURI() {
    static char kCrosDisksFuseBoxHelperURI[] = "fusebox://fusebox";
    return kCrosDisksFuseBoxHelperURI;
  }

  // Construction creates and mounts the cros-disks fusebox daemon.
  using FuseBoxMountInfo = ::ash::disks::DiskMountManager::MountPoint;
  void MountResponse(ash::MountError error, const FuseBoxMountInfo& info);

  // True if the fusebox daemon was successfully mounted.
  bool mounted_ = false;

  // List of `AttachStorage` calls prior to the fusebox daemon mount.
  using UrlReadOnlyPair = std::pair<std::string, bool>;
  std::map<std::string, UrlReadOnlyPair> pending_attach_storage_calls_;

  // base::WeakPtr{this} factory.
  base::WeakPtrFactory<FuseBoxDaemon> weak_ptr_factory_{this};
};

}  // namespace file_manager

#endif  // CHROME_BROWSER_ASH_FILE_MANAGER_FUSEBOX_DAEMON_H_