Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Remove Hangouts component #39660

Closed
ShivanKaul opened this issue Jul 9, 2024 · 12 comments · Fixed by brave/brave-core#24594
Closed

Remove Hangouts component #39660

ShivanKaul opened this issue Jul 9, 2024 · 12 comments · Fixed by brave/brave-core#24594

Comments

@ShivanKaul
Copy link
Collaborator

ShivanKaul commented Jul 9, 2024

(edited to add the Background section)

Test plan

See brave/brave-core#24594

Platforms

Linux, macOS, Windows

Description

We previously added the Hangouts extension to allow screen sharing: #1983. The setting is toggleable via the Hangouts setting in brave://settings/extensions.

The Hangouts extension uses private Chrome Web APIs: https://source.chromium.org/chromium/chromium/src/+/main:chrome/browser/resources/hangout_services/manifest_v3.json;l=24-30. We need to investigate if we still need this extension/component. Screen sharing does not seem dependent on this extension any more: disabling the Hangouts setting does not affect screen sharing on Google Meet but does prevent debugging information showing up (which is fine).

Note that we disable log uploading done by this (and other) private WebRTC APIs: #1993

Background

In 2019, Brave enabled the Hangouts Services extension to allow users to use Google Hangouts and Google Meet in the Brave browser. This extension fixed some broken Hangouts/Meet functionality in Brave (specifically, screen sharing would not work on Google Hangouts/Meet without the extension). At the time, Chromium was cautious about giving all websites access to the standards-compliant screen sharing API because of security concerns, which is presumably why Google special-cased this ability for Google’s websites only.

Having Google Meet/Hangouts work in Chrome but not Brave was a serious Web compatibility problem. Before enabling this extension by default, Brave made sure that we added a way for users to disable the Hangouts extension in brave://settings/extensions. We also proactively blocked automatic uploading of debugging information to Google’s servers, the same way we frequently modify Chromium to fix leaks and boost user privacy. However, we see now why this would have raised concerns among some users. In hindsight, a better approach would have been one similar to what we did with the Widevine extension: keep the extension off-by-default, and ask the user if they want to enable it on their first visit to a website with functionality that would be helped by the extension.

Over the years, we received clear reports from users that Google Meet did not work properly without the Hangouts Services extension, which is why we kept it on by default (though we should have revisited this sooner.) With the widespread adoption of screen sharing Web APIs, it’s clear the extension is no longer needed. Google deprecated Hangouts, and Google Meet works fine for Brave users without the extension. We have now changed our settings panel to leave the Hangouts Services extension off by default, and are removing the extension completely with the work in this issue.

@bsclifton
Copy link
Member

Hangouts of course has been EOL'ed but Google Meet working great with a few tests I've done with the extension disabled.

@ShivanKaul
Copy link
Collaborator Author

I went through the extension's permissions:

  1. desktopCapture: this doesn't seem necessary since the page can just use Screen Capture API
  2. enterprise.hardwarePlatform: this seems purely for logging purposes. We already disable uploading of logging information
  3. processes: logging related too, "continuously reporting relevant CPU usage information to the page."
  4. system.cpu: logging
  5. webrtcAudioPrivate: AFAICT not even being used by the extension
  6. webrtcDesktopCapturePrivate: Hmm, this might be used to allow screen sharing via a WebView. @bsclifton Does this option exist on Android? If yes, if you open a Google Meet link in a WebView (maybe if you click on the link in Messenger or WhatsApp?) are you able to share screen?
  7. webrtcLoggingPrivate: logging

@bsclifton
Copy link
Member

bsclifton commented Jul 10, 2024

@ShivanKaul I can check that tomorrow (RE: webrtcDesktopCapturePrivate on Android)

Should we make a separate issue to track disabling component first? This issue can track removing it entirely. I created brave/brave-core#24583 and added some tests that I manually ran through. Let me know what you think!

@ShivanKaul
Copy link
Collaborator Author

Yeah, that makes sense, like we discussed we don't need to block on disabling this in Nightly.

@ShivanKaul
Copy link
Collaborator Author

I created #39664 and edited the PR description for brave/brave-core#24583 to fix that instead.

bsclifton added a commit to brave/brave-core that referenced this issue Jul 10, 2024
Fixes brave/brave-browser#39664

Disabling will add the extension to a block list.
This won't affect people who have toggled the setting - for example,
someone who manually enabled or disabled.

Google Meet seems to work great with this extension blocked.

First step towards fixing brave/brave-browser#39660

Long term goal would be to remove the extension code:
https://source.chromium.org/chromium/chromium/src/+/main:chrome/browser/resources/hangout_services/manifest_v3.json;l=24-30
@rebron rebron added the priority/P2 A bad problem. We might uplift this to the next planned release. label Jul 10, 2024
@github-project-automation github-project-automation bot moved this to Completed in General Jul 12, 2024
@bsclifton bsclifton added this to the 1.69.x - Nightly milestone Jul 12, 2024
@stephendonner
Copy link

stephendonner commented Jul 15, 2024

Verification PASSED using

Brave | 1.69.106 Chromium: 127.0.6533.43 (Official Build) nightly (x86_64)
-- | --
Revision | 2778b12a30fa8f4d7ccd6caad101a7aabcfc6981
OS | macOS Version 11.7.10 (Build 20G1427)

Case 1: Upgrade, default - PASSED

  1. installed 1.67.123
  2. launched Brave (release)
  3. opened brave://settings/extensions
  4. confirmed Hangouts is toggled On/Enabled
  5. upgraded to 1.69.106 by renaming Brave-Browser profile to Brave-Browser-Nightly
  6. installed launched Brave 1.69.106 (nightly)
  7. opened brave://settings/extensions

Confirmed Hangouts is removed from brave://settings/extension

1.67.123 1.69.106
Screen Shot 2024-07-15 at 11 52 20 AM Screen Shot 2024-07-15 at 11 56 00 AM

Case 2: Upgrade, user-modified setting - PASSED

  1. installed and launched 1.67.123 (release)
  2. opened brave://settings/extensions
  3. toggled Hangouts from its default of Enabled to Disabled, and then finally toggled back to Enabled/On
  4. installed 1.69.98
  5. launched Brave (nightly)
  6. opened brave://settings/extensions
  7. looked at the value for the Hangouts preference
  8. loaded google.com
  9. opened the Developer Tools' Console
  10. pasted in the following:
chrome.runtime.sendMessage(
  "nkeimhogjdpnpccoofpliimaahmaaome",
  { method: "cpu.getInfo" },
  (response) => {
    console.log(JSON.stringify(response, null, 2));
  },
);
  1. loaded brave://extensions-internals
  2. searched for the nkeimhogjdpnpccoofpliimaahmaaome extension

Confirmed Hangouts - both its UI and its extensions -- was still removed

1.67.123 1.69.106 brave://extensions-internals Google.com
Screen Shot 2024-07-15 at 11 52 20 AM Screen Shot 2024-07-15 at 12 14 22 PM Screen Shot 2024-07-15 at 12 21 15 PM Screen Shot 2024-07-15 at 12 21 45 PM

Case 3: New profile - PASSED

Steps:

  1. installed 1.69.106
  2. launched Brave
  3. loaded brave://settings/extensions
  4. confirmed no Hangouts UI
  5. loaded brave://extensions-internals/
  6. searched for the nkeimhogjdpnpccoofpliimaahmaaome extension

Confirmed no UI nor Hangouts extensions shown

brave://extensions-internals brave://settings/extensions
Screen Shot 2024-07-15 at 12 34 50 PM Screen Shot 2024-07-15 at 12 35 06 PM

@ShivanKaul
Copy link
Collaborator Author

Just some background here:

In 2019, Brave enabled the Hangouts Services extension to allow users to use Google Hangouts and Google Meet in the Brave browser. This extension fixed some broken Hangouts/Meet functionality in Brave (specifically, screen sharing would not work on Google Hangouts/Meet without the extension). At the time, Chromium was cautious about giving all websites access to the standards-compliant screen sharing API because of security concerns, which is presumably why Google special-cased this ability for Google’s websites only.

Having Google Meet/Hangouts work in Chrome but not Brave was a serious Web compatibility problem. Before enabling this extension by default, Brave made sure that we added a way for users to disable the Hangouts extension in brave://settings/extensions. We also proactively blocked automatic uploading of debugging information to Google’s servers, the same way we frequently modify Chromium to fix leaks and boost user privacy. However, we see now why this would have raised concerns among some users. In hindsight, a better approach would have been one similar to what we did with the Widevine extension: keep the extension off-by-default, and ask the user if they want to enable it on their first visit to a website with functionality that would be helped by the extension.

Over the years, we received clear reports from users that Google Meet did not work properly without the Hangouts Services extension, which is why we kept it on by default (though we should have revisited this sooner.) With the widespread adoption of screen sharing Web APIs, it’s clear the extension is no longer needed. Google deprecated Hangouts, and Google Meet works fine for Brave users without the extension. We have now changed our settings panel to leave the Hangouts Services extension off by default, and are removing the extension completely with the work in this issue.

@MadhaviSeelam
Copy link

MadhaviSeelam commented Jul 23, 2024

Adding QA/Test-All-Platforms as per the issue description

@MadhaviSeelam
Copy link

Verification `PASSED using

Brave | 1.69.122 Chromium: 127.0.6533.57 (Official Build) beta (64-bit)
-- | --
Revision | bd77e9b76a8e67ff2bf9f62f1df7d60378ca811f
OS | Windows 11 Version 23H2 (Build 22631.3880)

Note: Hangout is enabled by default 1.67.123 in, however, in 1.67.134 & 1.68.127 it's disabled by default

1.67.123 1.67.134 1.68.127
image image image
image image image

Case 1: Upgrade, default - PASSED

  1. installed 1.68.127
  2. launched Brave
  3. opened brave://settings/extensions
  4. confirmed Hangouts is toggled Off/disabled
  5. upgraded to 1.69.122 by renaming Brave-Browser profile to Brave-Browser-Beta
  6. installed launched Brave 1.69.122 (Beta)
  7. opened brave://settings/extensions

Confirmed Hangouts is removed from brave://settings/extension

step 4 step 7
image image

Case 2: Upgrade, user-modified setting - PASSED

  1. installed and launched 1.67.123 (release)
  2. opened brave://settings/extensions
  3. toggled Hangouts from its default of disabled to enabled
  4. installed 1.69.122
  5. launched Brave (Beta)
  6. opened brave://settings/extensions
  7. verified Hangouts entry is no longer shown
  8. opened brave://extensions-internals/
  9. confirmed nkeimhogjdpnpccoofpliimaahmaaome is no longer there
  10. loaded google.com
  11. opened the Developer Tools' Console
  12. pasted in the following and hit Enter:
chrome.runtime.sendMessage(
  "nkeimhogjdpnpccoofpliimaahmaaome",
  { method: "cpu.getInfo" },
  (response) => {
    console.log(JSON.stringify(response, null, 2));
  },
);
  1. confirmed an error shown in console and no information shown.
step 3a step 3b step 7 step 9 step 13
image image image image image

Case 3: New profile - PASSED

Steps:

  1. installed 1.69.122
  2. launched Brave
  3. loaded brave://settings/extensions
  4. confirmed no Hangouts UI
  5. loaded brave://extensions-internals/
  6. searched for the nkeimhogjdpnpccoofpliimaahmaaome extension

Confirmed no UI nor Hangouts extensions shown

step 3 step 5
image image

@ghost
Copy link

ghost commented Jul 25, 2024

I see that the latest merge disabled it by default and this issue has been closed.

Anyway my question is about a group policy I had set regarding the Google Hangouts extension.
My goal is to never allow the extension from being enabled and loaded. Also to block it in case it was to ever be added back to Brave (highly doubtful). Will my policy conflict with the latest merge of disabling it?

{
    "WebRtcEventLogCollectionAllowed": false,
    "WebRtcTextLogCollectionAllowed": false,
    "ExtensionInstallBlocklist": [
      "nkeimhogjdpnpccoofpliimaahmaaome"
  ]
}

@ghost
Copy link

ghost commented Jul 27, 2024

Upon further testing there is no way to lock the slider in brave://settings/extensions with a group policy rule. And the one I tried above ^ does nothing.

Also many group policies are broken and dont carry over in Brave despite them being valid in brave://policy/

For example these two do not work on Brave:

  • EnableMediaRouter
  • ClearBrowsingDataOnExitList
{
    "EnableMediaRouter": false,
    "ClearBrowsingDataOnExitList": [
      "browsing_history",
      "download_history",
      "cookies_and_other_site_data",
      "cached_images_and_files",
      "password_signin",
      "autofill",
      "site_settings",
      "hosted_app_data"
  ]
}

@MadhaviSeelam
Copy link

MadhaviSeelam commented Jul 29, 2024

Verification PASSED using

Brave	1.69.128 Chromium: 127.0.6533.73 (Official Build) beta (64-bit) 
Revision	715445841b1da480bcc24c12077a6dc926951996
OS	Linux

Case 1: Upgrade, default - PASSED

  1. installed 1.68.128
  2. launched Brave
  3. opened brave://settings/extensions
  4. confirmed Hangouts is toggled Off/disabled
  5. upgraded to 1.69.128 by renaming Brave-Browser profile to Brave-Browser-Beta
  6. installed launched Brave 1.69.128 (Beta)
  7. opened brave://settings/extensions

Confirmed Hangouts is removed from brave://settings/extension

step 4 step 7
image image

Case 2: Upgrade, user-modified setting - PASSED

  1. installed and launched 1.68.128
  2. opened brave://settings/extensions
  3. toggled Hangouts from its default of disabled to enabled
  4. installed 1.69.128
  5. launched Brave (Beta)
  6. opened brave://settings/extensions
  7. verified Hangouts entry is no longer shown
  8. opened brave://extensions-internals/
  9. confirmed nkeimhogjdpnpccoofpliimaahmaaome is no longer there
  10. loaded google.com
  11. opened the Developer Tools' Console
  12. pasted in the following and hit Enter:
chrome.runtime.sendMessage(
  "nkeimhogjdpnpccoofpliimaahmaaome",
  { method: "cpu.getInfo" },
  (response) => {
    console.log(JSON.stringify(response, null, 2));
  },
);
  1. confirmed an error shown in console and no information shown.
step 3a step 3b step 7 step 9 step 13
image image image image image

Case 3: New profile - PASSED

Steps:

  1. installed 1.69.128
  2. launched Brave
  3. loaded brave://settings/extensions
  4. confirmed no Hangouts UI
  5. loaded brave://extensions-internals/
  6. searched for the nkeimhogjdpnpccoofpliimaahmaaome extension

Confirmed no UI nor Hangouts extensions shown

step 3 step 5
image image

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

5 participants