File: tab_group_sync_delegate.h

package info (click to toggle)
chromium 139.0.7258.138-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 6,120,676 kB
  • sloc: cpp: 35,100,869; ansic: 7,163,530; javascript: 4,103,002; python: 1,436,920; asm: 946,517; xml: 746,709; pascal: 187,653; perl: 88,691; sh: 88,436; objc: 79,953; sql: 51,488; cs: 44,583; fortran: 24,137; makefile: 22,147; tcl: 15,277; php: 13,980; yacc: 8,984; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (95 lines) | stat: -rw-r--r-- 4,236 bytes parent folder | download | duplicates (5)
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
// Copyright 2024 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef COMPONENTS_SAVED_TAB_GROUPS_DELEGATE_TAB_GROUP_SYNC_DELEGATE_H_
#define COMPONENTS_SAVED_TAB_GROUPS_DELEGATE_TAB_GROUP_SYNC_DELEGATE_H_

#include <memory>
#include <set>

#include "base/uuid.h"
#include "components/saved_tab_groups/public/saved_tab_group.h"
#include "components/saved_tab_groups/public/tab_group_sync_service.h"
#include "components/saved_tab_groups/public/types.h"

namespace tab_groups {

// Home for platform specific logic for tab group sync. Contains helper methods
// for applying incoming remote updates to the local tab model, which platforms
// need to implement. Ideally should own a local mutation helper that will apply
// the mutation. Also should own the local tab model observer which will observe
// the local tab model and invoke TabGroupSyncService directly or via a remote
// mutation helper that will propagate the changes to sync.
class TabGroupSyncDelegate {
 public:
  // A RAII class that indicates to the TabGroupSyncDelegate that several
  // operations will happen before it is necessary to reflect all the updates.
  class [[maybe_unused, nodiscard]] ScopedBatchOperation {
   public:
    virtual ~ScopedBatchOperation() = default;
  };

  virtual ~TabGroupSyncDelegate() = default;

  // Notify the delegate that several operations are about to happen. The
  // returned token should be kept alive until the operations complete, at which
  // point it must be deleted.
  virtual std::unique_ptr<ScopedBatchOperation> StartBatchOperation();

  // Called to open a given saved tab group in the local tab model.
  // The `context` can be used to specify the browser window in which the tab
  // group should be opened.
  virtual std::optional<LocalTabGroupID> HandleOpenTabGroupRequest(
      const base::Uuid& sync_tab_group_id,
      std::unique_ptr<TabGroupActionContext> context) = 0;

  // Called to pause / resume the local observer.
  virtual std::unique_ptr<ScopedLocalObservationPauser>
  CreateScopedLocalObserverPauser() = 0;

  // Called to create a local tab group for the given sync representation.
  virtual void CreateLocalTabGroup(const SavedTabGroup& tab_group) = 0;

  // Called to close the specified local tab group.
  virtual void CloseLocalTabGroup(const LocalTabGroupID& local_id) = 0;

  // Called to start listening for changes to a local group. The local group
  // will be updated based on the connected saved group. Desktop only.
  virtual void ConnectLocalTabGroup(const SavedTabGroup& group) = 0;

  // Called to stop listening for changes to a local group. Desktop only.
  virtual void DisconnectLocalTabGroup(const LocalTabGroupID& local_id) = 0;

  // Called to update local tab group to match the given saved tab group. This
  // will open new tabs, close tabs, and navigate tabs to match the saved group.
  // Connects to the local tab group if it is not already connected and begins
  // listening for changes to the local group.
  virtual void UpdateLocalTabGroup(const SavedTabGroup& group) = 0;

  // Called to get all the local tab group IDs across all local tab models.
  virtual std::vector<LocalTabGroupID> GetLocalTabGroupIds() = 0;

  // Called to get the local tab IDs associated with a given tab group.
  virtual std::vector<LocalTabID> GetLocalTabIdsForTabGroup(
      const LocalTabGroupID& local_tab_group_id) = 0;

  // Called to get the currently selected tabs from the tab model. The result
  // should contain selected tabs across all browser windows.
  virtual std::set<LocalTabID> GetSelectedTabs() = 0;

  // Called to get the title of a tab from the tab model.
  virtual std::u16string GetTabTitle(const LocalTabID& local_tab_id) = 0;

  // Local To Remote mutation methods.

  // Helper function to create a SavedTabGroup for the given local tab group ID.
  // Caller is supposed to handle the SavedTabGroup, e.g. add to the sync
  // service.
  virtual std::unique_ptr<SavedTabGroup> CreateSavedTabGroupFromLocalGroup(
      const LocalTabGroupID& local_tab_group_id) = 0;
};

}  // namespace tab_groups

#endif  // COMPONENTS_SAVED_TAB_GROUPS_DELEGATE_TAB_GROUP_SYNC_DELEGATE_H_