File: virtual_keyboard_log_source.cc

package info (click to toggle)
chromium 138.0.7204.183-1~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm-proposed-updates
  • size: 6,080,960 kB
  • sloc: cpp: 34,937,079; ansic: 7,176,967; javascript: 4,110,704; python: 1,419,954; asm: 946,768; xml: 739,971; pascal: 187,324; sh: 89,623; perl: 88,663; objc: 79,944; sql: 50,304; cs: 41,786; fortran: 24,137; makefile: 21,811; php: 13,980; tcl: 13,166; yacc: 8,925; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (136 lines) | stat: -rw-r--r-- 5,444 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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
// 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.

#include "chrome/browser/ash/system_logs/virtual_keyboard_log_source.h"

#include <memory>
#include <string>
#include <utility>

#include "ash/keyboard/keyboard_controller_impl.h"
#include "ash/keyboard/ui/keyboard_ui_controller.h"
#include "ash/keyboard/virtual_keyboard_controller.h"
#include "ash/public/cpp/keyboard/keyboard_types.h"
#include "ash/shell.h"
#include "base/strings/strcat.h"
#include "base/strings/string_number_conversions.h"
#include "base/strings/stringprintf.h"

namespace system_logs {

namespace {

std::string LogEntryForBooleanField(const std::string& field_name, bool value) {
  return base::StrCat({field_name, ": ", base::NumberToString(value), "\n"});
}

}  // namespace

VirtualKeyboardLogSource::VirtualKeyboardLogSource()
    : SystemLogsSource("VirtualKeyboard") {}

void VirtualKeyboardLogSource::Fetch(SysLogsSourceCallback callback) {
  DCHECK(!callback.is_null());

  auto response = std::make_unique<SystemLogsResponse>();

  keyboard::KeyboardUIController* keyboard_ui_controller =
      keyboard::KeyboardUIController::Get();
  ash::VirtualKeyboardController* virtual_keyboard_controller =
      ash::Shell::Get()->keyboard_controller()->virtual_keyboard_controller();

  std::string log_data;

  int touchscreen_count = 1;
  for (const ui::InputDevice& device :
       virtual_keyboard_controller->GetTouchscreens()) {
    const std::string touchscreen_count_converted =
        base::NumberToString(touchscreen_count);
    log_data += base::StrCat({"Touchscreen ", touchscreen_count_converted,
                              " Product ID"}) +
                ": " + base::StringPrintf("0x%04x", device.product_id) + "\n";
    log_data += base::StrCat({"Touchscreen ", touchscreen_count_converted,
                              " Vendor ID"}) +
                ": " + base::StringPrintf("0x%04x", device.vendor_id) + "\n";
    ++touchscreen_count;
  }

  log_data +=
      "Internal Keyboard Name: " +
      (virtual_keyboard_controller->GetInternalKeyboardName()
           ? virtual_keyboard_controller->GetInternalKeyboardName().value()
           : "No Internal Keyboard Detected") +
      "\n";
  log_data += "Is Internal Keyboard Ignored: " +
              base::NumberToString(
                  virtual_keyboard_controller->IsInternalKeyboardIgnored()) +
              "\n";

  int external_keyboard_count = 1;
  std::vector<ui::InputDevice> external_keyboards =
      virtual_keyboard_controller->GetExternalKeyboards();
  if (external_keyboards.size() == 0) {
    log_data += "No External Keyboard Detected\n";
  }
  for (const ui::InputDevice& device : external_keyboards) {
    const std::string external_keyboard_count_converted =
        base::NumberToString(external_keyboard_count);
    log_data +=
        base::StrCat({"External Keyboard ", external_keyboard_count_converted,
                      " Product ID"}) +
        ": " + base::StringPrintf("0x%04x", device.product_id) + "\n";
    log_data +=
        base::StrCat({"External Keyboard ", external_keyboard_count_converted,
                      " Vendor ID"}) +
        ": " + base::StringPrintf("0x%04x", device.vendor_id) + "\n";
    ++external_keyboard_count;
  }

  log_data += LogEntryForBooleanField(
      "Is External Keyboard Ignored: ",
      virtual_keyboard_controller->IsExternalKeyboardIgnored());
  log_data += LogEntryForBooleanField(
      "kPolicyEnabled Flag: ",
      keyboard_ui_controller->IsEnableFlagSet(
          keyboard::KeyboardEnableFlag::kPolicyEnabled));
  log_data += LogEntryForBooleanField(
      "kPolicyDisabled Flag: ",
      keyboard_ui_controller->IsEnableFlagSet(
          keyboard::KeyboardEnableFlag::kPolicyDisabled));
  log_data += LogEntryForBooleanField(
      "kAndroidDisabled Flag: ",
      keyboard_ui_controller->IsEnableFlagSet(
          keyboard::KeyboardEnableFlag::kAndroidDisabled));
  log_data += LogEntryForBooleanField(
      "kExtensionEnabled Flag: ",
      keyboard_ui_controller->IsEnableFlagSet(
          keyboard::KeyboardEnableFlag::kExtensionEnabled));
  log_data += LogEntryForBooleanField(
      "kExtensionDisabled Flag: ",
      keyboard_ui_controller->IsEnableFlagSet(
          keyboard::KeyboardEnableFlag::kExtensionDisabled));
  log_data += LogEntryForBooleanField(
      "kAccessibilityEnabled Flag: ",
      keyboard_ui_controller->IsEnableFlagSet(
          keyboard::KeyboardEnableFlag::kAccessibilityEnabled));
  log_data += LogEntryForBooleanField(
      "kShelfEnabled Flag: ", keyboard_ui_controller->IsEnableFlagSet(
                                  keyboard::KeyboardEnableFlag::kShelfEnabled));
  log_data += LogEntryForBooleanField(
      "kTouchEnabled Flag: ", keyboard_ui_controller->IsEnableFlagSet(
                                  keyboard::KeyboardEnableFlag::kTouchEnabled));
  log_data += LogEntryForBooleanField(
      "kCommandLineEnabled Flag: ",
      keyboard_ui_controller->IsEnableFlagSet(
          keyboard::KeyboardEnableFlag::kCommandLineEnabled));
  log_data += LogEntryForBooleanField(
      "kCommandLineDisabled Flag: ",
      keyboard_ui_controller->IsEnableFlagSet(
          keyboard::KeyboardEnableFlag::kCommandLineDisabled));
  response->emplace("virtual_keyboard", log_data);

  std::move(callback).Run(std::move(response));
}

}  // namespace system_logs