Source code

Revision control

Copy as Markdown

Other Tools

# 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 repackage signing task into an actual task description.
"""
import os
from taskgraph.transforms.base import TransformSequence
from taskgraph.util.dependencies import get_primary_dependency
from taskgraph.util.schema import Schema
from voluptuous import Optional
from gecko_taskgraph.transforms.task import task_description_schema
from gecko_taskgraph.util.attributes import copy_attributes_from_dependent_job
from gecko_taskgraph.util.scriptworker import get_signing_cert_scope_per_platform
repackage_signing_description_schema = Schema(
{
Optional("label"): str,
Optional("attributes"): task_description_schema["attributes"],
Optional("dependencies"): task_description_schema["dependencies"],
Optional("job-from"): task_description_schema["job-from"],
Optional("treeherder"): task_description_schema["treeherder"],
Optional("shipping-product"): task_description_schema["shipping-product"],
Optional("shipping-phase"): task_description_schema["shipping-phase"],
}
)
SIGNING_FORMATS = {
"target.installer.exe": ["autograph_authenticode_sha2_stub"],
"target.stub-installer.exe": ["autograph_authenticode_sha2_stub"],
"target.installer.msi": ["autograph_authenticode_sha2"],
"target.installer.msix": ["autograph_authenticode_sha2"],
}
transforms = TransformSequence()
@transforms.add
def remove_name(config, jobs):
for job in jobs:
if "name" in job:
del job["name"]
yield job
transforms.add_validate(repackage_signing_description_schema)
@transforms.add
def make_repackage_signing_description(config, jobs):
for job in jobs:
dep_job = get_primary_dependency(config, job)
assert dep_job
attributes = copy_attributes_from_dependent_job(dep_job)
locale = attributes.get("locale", dep_job.attributes.get("locale"))
attributes["repackage_type"] = "repackage-signing"
treeherder = job.get("treeherder", {})
treeherder.setdefault("symbol", "rs(B)")
dep_th_platform = dep_job.task.get("extra", {}).get("treeherder-platform")
treeherder.setdefault("platform", dep_th_platform)
treeherder.setdefault(
"tier", dep_job.task.get("extra", {}).get("treeherder", {}).get("tier", 1)
)
treeherder.setdefault("kind", "build")
if locale:
treeherder["symbol"] = f"rs({locale})"
if config.kind == "repackage-signing-msi":
treeherder["symbol"] = "MSIs({})".format(locale or "N")
elif config.kind in (
"repackage-signing-msix",
"repackage-signing-shippable-l10n-msix",
):
# Like "MSIXs(Bs-multi)".
treeherder["symbol"] = "MSIXs({})".format(
dep_job.task.get("extra", {}).get("treeherder", {}).get("symbol", "B")
)
label = job["label"]
dep_kind = dep_job.kind
if "l10n" in dep_kind:
dep_kind = "repackage"
dependencies = {dep_kind: dep_job.label}
signing_dependencies = dep_job.dependencies
# This is so we get the build task etc in our dependencies to have better beetmover
# support. But for multi-locale MSIX packages, we don't want the signing task to directly
# depend on the langpack tasks.
dependencies.update(
{
k: v
for k, v in signing_dependencies.items()
if k != "docker-image"
and not k.startswith("shippable-l10n-signing-linux64")
}
)
description = (
"Signing of repackaged artifacts for locale '{locale}' for build '"
"{build_platform}/{build_type}'".format(
locale=attributes.get("locale", "en-US"),
build_platform=attributes.get("build_platform"),
build_type=attributes.get("build_type"),
)
)
build_platform = dep_job.attributes.get("build_platform")
is_shippable = dep_job.attributes.get("shippable")
signing_cert_scope = get_signing_cert_scope_per_platform(
build_platform, is_shippable, config
)
scopes = [signing_cert_scope]
upstream_artifacts = []
for artifact in sorted(dep_job.attributes.get("release_artifacts")):
basename = os.path.basename(artifact)
if basename in SIGNING_FORMATS:
upstream_artifacts.append(
{
"taskId": {"task-reference": f"<{dep_kind}>"},
"taskType": "repackage",
"paths": [artifact],
"formats": SIGNING_FORMATS[os.path.basename(artifact)],
}
)
task = {
"label": label,
"description": description,
"worker-type": "linux-signing" if is_shippable else "linux-depsigning",
"worker": {
"implementation": "scriptworker-signing",
"upstream-artifacts": upstream_artifacts,
"max-run-time": 3600,
},
"scopes": scopes,
"dependencies": dependencies,
"attributes": attributes,
"run-on-projects": dep_job.attributes.get("run_on_projects"),
"optimization": dep_job.optimization,
"treeherder": treeherder,
}
yield task