From 26a029d407be480d791972afb5975cf62c9360a6 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Fri, 19 Apr 2024 02:47:55 +0200 Subject: Adding upstream version 124.0.1. Signed-off-by: Daniel Baumann --- .../gecko_taskgraph/transforms/hardened_signing.py | 111 +++++++++++++++++++++ 1 file changed, 111 insertions(+) create mode 100644 taskcluster/gecko_taskgraph/transforms/hardened_signing.py (limited to 'taskcluster/gecko_taskgraph/transforms/hardened_signing.py') diff --git a/taskcluster/gecko_taskgraph/transforms/hardened_signing.py b/taskcluster/gecko_taskgraph/transforms/hardened_signing.py new file mode 100644 index 0000000000..edc8aaf68e --- /dev/null +++ b/taskcluster/gecko_taskgraph/transforms/hardened_signing.py @@ -0,0 +1,111 @@ +# This Source Code Form is subject to the terms of the Mozilla Public +# License, v. 2.0. If a copy of the MPL was not distributed with this +# file, You can obtain one at http://mozilla.org/MPL/2.0/. +""" +Transform the signing task into an actual task description. +""" + +import copy + +from taskgraph.transforms.base import TransformSequence +from taskgraph.util.dependencies import get_primary_dependency +from taskgraph.util.keyed_by import evaluate_keyed_by + +from gecko_taskgraph.util.attributes import release_level + +transforms = TransformSequence() + +PROVISIONING_PROFILE_FILENAMES = { + "firefox": "orgmozillafirefox.provisionprofile", + "devedition": "orgmozillafirefoxdeveloperedition.provisionprofile", + "nightly": "orgmozillanightly.provisionprofile", +} + + +@transforms.add +def add_hardened_sign_config(config, jobs): + for job in jobs: + if ( + "signing" not in config.kind + or "macosx" not in job["attributes"]["build_platform"] + ): + yield job + continue + + dep_job = get_primary_dependency(config, job) + assert dep_job + project_level = release_level(config.params["project"]) + is_shippable = dep_job.attributes.get("shippable", False) + hardened_signing_type = "developer" + + # If project is production AND shippable build, then use production entitlements + # Note: debug builds require developer entitlements + if project_level == "production" and is_shippable: + hardened_signing_type = "production" + + # Evaluating can mutate the original config, so we must deepcopy + hardened_sign_config = evaluate_keyed_by( + copy.deepcopy(config.graph_config["mac-signing"]["hardened-sign-config"]), + "hardened-sign-config", + {"hardened-signing-type": hardened_signing_type}, + ) + if not isinstance(hardened_sign_config, list): + raise Exception("hardened-sign-config must be a list") + + for sign_cfg in hardened_sign_config: + if isinstance(sign_cfg.get("entitlements"), dict): + sign_cfg["entitlements"] = evaluate_keyed_by( + sign_cfg["entitlements"], + "entitlements", + { + "build-platform": dep_job.attributes.get("build_platform"), + "project": config.params["project"], + }, + ) + + if "entitlements" in sign_cfg and not sign_cfg.get( + "entitlements", "" + ).startswith("http"): + sign_cfg["entitlements"] = config.params.file_url( + sign_cfg["entitlements"] + ) + + job["worker"]["hardened-sign-config"] = hardened_sign_config + job["worker"]["mac-behavior"] = "mac_sign_and_pkg_hardened" + yield job + + +@transforms.add +def add_provisioning_profile_config(config, jobs): + for job in jobs: + dep_job = get_primary_dependency(config, job) + assert dep_job + if ( + # Ensure signing task + "signing" in config.kind + # Ensure macosx platform + and "macosx" in job["attributes"]["build_platform"] + # Ensure project is considered production + and release_level(config.params["project"]) == "production" + # Ensure build is shippable + and dep_job.attributes.get("shippable", False) + ): + # Note that the check order here is important, as mozilla-central can build devedition + if "devedition" in dep_job.attributes.get("build_platform", ""): + # Devedition + filename = PROVISIONING_PROFILE_FILENAMES["devedition"] + elif config.params["project"] == "mozilla-central": + # Nightly + filename = PROVISIONING_PROFILE_FILENAMES["nightly"] + else: + # Release, beta, esr and variants should all use default firefox app id + # For full list of projects, see RELEASE_PROJECTS in taskcluster/gecko_taskgraph/util/attributes.py + filename = PROVISIONING_PROFILE_FILENAMES["firefox"] + + job["worker"]["provisioning-profile-config"] = [ + { + "profile_name": filename, + "target_path": "/Contents/embedded.provisionprofile", + }, + ] + yield job -- cgit v1.2.3