File: optimization_guide_internals.mojom

package info (click to toggle)
chromium 140.0.7339.127-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 6,192,880 kB
  • sloc: cpp: 35,093,808; ansic: 7,161,670; javascript: 4,199,694; python: 1,441,797; asm: 949,904; xml: 747,503; pascal: 187,748; perl: 88,691; sh: 88,248; objc: 79,953; sql: 52,714; cs: 44,599; fortran: 24,137; makefile: 22,114; tcl: 15,277; php: 13,980; yacc: 9,000; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (71 lines) | stat: -rw-r--r-- 2,838 bytes parent folder | download | duplicates (4)
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
// 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.

module optimization_guide_internals.mojom;

import "components/optimization_guide/core/optimization_guide_common.mojom";
import "mojo/public/mojom/base/time.mojom";

// Information on downloaded models to be displayed on WebUI page, for debugging
// purposes.
struct DownloadedModelInfo {
  // Serialization of OPTIMIZATION_TARGET enum in
  // //components/optimization_guide/proto/models.proto, e.g.,
  // "OPTIMIZATION_TARGET_PAINFUL_PAGE_LOAD".
  string optimization_target;
  // Version of the OPTIMIZATION_TARGET model, reflection of ModelInfo's version
  // field in //components/optimization_guide/proto/models.proo.
  int64 version;
  // TODO(crbug.com/40859328): Convert to mojo_base.mojo.FilePath type.
  string file_path;
};

// Information of logged client_ids to allow users to opt-out of logging.
// TODO(b/308642692): Add more fields as needed to be shown on the internals page.
struct LoggedClientIds {
  // Client id of the user, unique every day for each ModelExecutionFeature.
  int64 client_id;
};

// Information on Model Quality Logging Service (MQLS) logs to be displayed on
// WebUI page, for debugging purposes.
struct MqlsLog {
  // Feature associated with the MQLS log.
  string feature;
  // Serialization of proto to be uploaded as an MQLS log.
  string proto;
  // Status of the MQLS log upload.
  string status;
};

// Used by the WebUI page to bootstrap bidirectional communication.
interface PageHandlerFactory {
  // The WebUI calls this method when the page is first initialized.
  CreatePageHandler(pending_remote<Page> page);

  // The WebUI calls this method when the models page is open, to retrieve
  // information of downloaded models for debugging purposes.
  RequestDownloadedModelsInfo() =>
      (array<DownloadedModelInfo> downloaded_models_info);

  // The WebUI calls this method when the client id page is open, to retrieve
  // information of all client ids for the past 28 days to allow users to opt-out of logs.
  RequestLoggedModelQualityClientIds() =>
      (array<LoggedClientIds> logged_client_ids);

  // The WebUI calls this method when the MQLS logs page is open, to retrieve
  // information on MQLS logs for debugging purposes.
  RequestMqlsLogs() => (array<MqlsLog> mqls_logs);
};

// Renderer-side handler for internals WebUI page to process the updates from
// the OptimizationGuide service.
interface Page {
  // Notifies the page of a log event from the OptimizationGuide service.
  OnLogMessageAdded(mojo_base.mojom.Time event_time,
                    optimization_guide_common.mojom.LogSource log_source,
                    string source_file,
                    int64 source_line,
                    string message);
};