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

Upgrade patches from Chromium 76.0.3809.62 to Chromium 76.0.3809.72 #2976

Merged
merged 4 commits into from
Jul 25, 2019

Conversation

mkarolin
Copy link
Collaborator

@mkarolin mkarolin commented Jul 23, 2019

Fixes brave/brave-browser#5299
Related PR: brave/brave-browser#5364

Submitter Checklist:

Test Plan:

Reviewer Checklist:

  • New files have MPL-2.0 license header.
  • Request a security/privacy review as needed.
  • Adequate test coverage exists to prevent regressions
  • Verify test plan is specified in PR before merging to source

After-merge Checklist:

  • The associated issue milestone is set to the smallest version that the
    changes has landed on.
  • All relevant documentation has been updated.

@mkarolin mkarolin added CI/skip-android Do not run CI builds for Android CI/skip-linux CI/skip-ios Do not run CI builds for iOS labels Jul 23, 2019
@mkarolin mkarolin added this to the 0.69.x - Nightly milestone Jul 23, 2019
@mkarolin mkarolin requested a review from bridiver as a code owner July 23, 2019 02:21
@mkarolin mkarolin self-assigned this Jul 23, 2019
@mkarolin mkarolin removed CI/skip-android Do not run CI builds for Android CI/skip-ios Do not run CI builds for iOS CI/skip-linux labels Jul 23, 2019
@mkarolin mkarolin force-pushed the 76.0.3809.72 branch 2 times, most recently from 7cb1994 to a11f747 Compare July 23, 2019 20:40
An instance of |model.CodeSignConfig|.
"""
config_class = config.CodeSignConfig
+ """
Copy link
Collaborator Author

@mkarolin mkarolin Jul 23, 2019

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This section needs to be commented out because identity and keychain below used to be passed into create_config as parameters, but now are packed into config_args parameter. Chromium probably never runs into error here because they successfully import their secret internal config and don't have an exception in the try.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we can still use this as you do in the sign_brave.py. I'm porting their recent changes from sign_chrome.py to your sign_brave.py and I think that will work as you did before which is basically removing the section where they do the import of their config.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's the section where they do the import of their config that I commented out here in the patch, not the config_class, github's snippet isn't helping here.

@mkarolin mkarolin force-pushed the 76.0.3809.72 branch 2 times, most recently from 33972b9 to 872eb82 Compare July 24, 2019 03:26
@mkarolin mkarolin force-pushed the 76.0.3809.72 branch 3 times, most recently from 20f75ba to 79799d9 Compare July 24, 2019 17:13
@mkarolin mkarolin requested a review from bsclifton July 24, 2019 17:21
@mkarolin mkarolin changed the title WIP: Upgrade patches from Chromium 76.0.3809.62 to Chromium 76.0.3809.72 Upgrade patches from Chromium 76.0.3809.62 to Chromium 76.0.3809.72 Jul 24, 2019
mkarolin added 3 commits July 24, 2019 15:22
- Changes dependency from chrome_helper_app to chrome_helper_app_default
  since there are now mulitple 'chrome_helper_app's.

- Clears output directory from path created by GN but not expected by the
  signing script.

Chromium changes:

https://chromium.googlesource.com/chromium/src/+/4be2698e4784

commit 4be2698e4784b68198d1062a54942ae232c57c24
Author: Robert Sesek <[email protected]>
Date:   Mon Jun 17 17:41:28 2019 +0000

    Create more Mac Helper application bundles.

    In order to enable the hardened runtime, which restricts things such as
    writable-executable memory and loading code signed by a different Team
    ID, special code signing entitlements must be granted to the Helper.
    To keep the capabilities scoped to the process types that require them,
    this CL adds two new variants of the Helper app: one for renderers
    and one for plugins.

    Currently all three Helpers will be code signed in the same way without
    any entitlements, but this will change in the future.

    Tbr: [email protected]
    Bug: 850193

which is rolled into c76 with:

https://chromium.googlesource.com/chromium/src/+/194826d6f8a3a0d932e18ed0f5452fd5c488e490

commit 194826d6f8a3a0d932e18ed0f5452fd5c488e490
Author: Robert Sesek <[email protected]>
Date:   Wed Jul 17 22:28:42 2019 +0000

    [BRANCH ONLY] Roll-up cherry pick of changes to notarize Chrome on macOS.

    App notarization is going to be required on macOS 10.15, which is
    expected to be released when M76 is on stable channel. This series of
    changes makes modifications to Chrome's helper processes, adding
    multiple variants with different code signing entitlements, as well as
    changes to the signing scripts to support notarization.

    This cherry-picks the following 15 commits to the M76/3809 branch:

    7f66190e7365 [Mac] Stop pretending that browser_tests/InProcessBrowserTest are bundled.
    ceaa2666e0eb Grant the browser several entitlements needed for the hardened runtime.
    4be2698e4784 Create more Mac Helper application bundles.
    3fa9da4e877a Give the new Mac helper variants the entitlements they require.
    4aa3a22f4387 Code sign all Mac executables with the hardened runtime option.
    4f72ae052e11 [Mac] Run the proxy_resolver service in the Renderer helper.
    c2b068a99ae2 Copy KeystoneRegistration.framework with a bundle_data rule for the root.
    4f6b2b188f29 [Mac] Delete CFBundleBlocker and third_party/mach_override.
    2f8e936c6909 macOS Signing Scripts: Add module responsible for notarization.
    62d2a3f09545 macOS Signing Scripts: Drop support for resource rules.
    ec608fec2fd1 macOS Signing Scripts: Create the notarization sentinel file.
    91b8140d5cb0 macOS Signing Scripts: Run the notarization stapler through xcrun.
    4312c1f9a695 macOS Signing Scripts: Do not staple the AlertNotificationService.xpc bundle.
    59347283139c macOS Signing Scripts: Write "yes-1" to the notarization sentinel file.
    4d22852510f5 Mac: Sign the inner framework only once per bundle ID

    Bug: 850199
Fixes brave/brave-browser#4922
Fixes brave/brave-browser#5036

Rolls a couple of patches into a single function in script/signing_helper.py.
Use single import directive.
Generate Widevine signature file before signing framework part.
Instead of using a modified copy of sign_chrome.py (named sign_brave.py)
leverage the original sign_chrome.py by patching it to call into brave's
signing_helper.py for a config override.

The patch also comments out a section of sign_chrome.py that causes a
runtime error due to wrong variables names.

# Invoke python script to do the signing.
PARAMS="--input $SOURCE_DIR --output $DEST_DIR --keychain $MAC_SIGNING_KEYCHAIN --identity $MAC_SIGNING_IDENTIFIER --no-dmg --no-notarize"
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@mbacchi, chrome/installer/mac/sign_chrome.py now takes --notarize/--no-notarize, --notary-user, and --notary-password arguments. Possibly, we can use their script for notarization? We aren't creating dmg in this step, so it would have to be notarized separately.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That's the approach I'm taking right now, I'm trying to leverage their scripts as much as possible. I'm getting close to something that I can get your opinion on.

@mkarolin
Copy link
Collaborator Author

Passed CI, ready for review.

Copy link
Member

@bsclifton bsclifton left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Beautiful! Great work, @mkarolin! 😄

@bsclifton bsclifton merged commit 79e5321 into master Jul 25, 2019
@bsclifton bsclifton deleted the 76.0.3809.72 branch July 25, 2019 20:47
bsclifton added a commit that referenced this pull request Jul 26, 2019
Upgrade patches from Chromium 76.0.3809.62 to Chromium 76.0.3809.72
bsclifton added a commit that referenced this pull request Jul 26, 2019
Upgrade patches from Chromium 76.0.3809.62 to Chromium 76.0.3809.72
bsclifton added a commit that referenced this pull request Jul 26, 2019
Upgrade patches from Chromium 76.0.3809.62 to Chromium 76.0.3809.72
bsclifton added a commit that referenced this pull request Jul 30, 2019
Upgrade patches from Chromium 76.0.3809.62 to Chromium 76.0.3809.72
bsclifton added a commit that referenced this pull request Jul 30, 2019
Upgrade patches from Chromium 76.0.3809.62 to Chromium 76.0.3809.72
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Upgrade from Chromium 76.0.3809.62 to Chromium 76.0.3809.72
4 participants