File: optimization_guide_internals.mojom

package info (click to toggle)
chromium 144.0.7559.109-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 5,915,868 kB
  • sloc: cpp: 35,866,215; ansic: 7,599,035; javascript: 3,623,761; python: 1,639,407; xml: 833,084; asm: 716,173; pascal: 185,323; sh: 88,763; perl: 88,699; objc: 79,984; sql: 58,217; cs: 42,430; fortran: 24,101; makefile: 20,747; tcl: 15,277; php: 14,022; yacc: 9,059; ruby: 7,553; awk: 3,720; lisp: 3,233; lex: 1,330; ada: 727; jsp: 228; sed: 36
file content (71 lines) | stat: -rw-r--r-- 2,838 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
// 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);
};