#!/bin/bash # Copyright 2018 The gVisor Authors. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # Parse arguments. We require more than two arguments, which are the private # keyring, the e-mail associated with the signer, and the list of packages. if [ "$#" -le 3 ]; then echo "usage: $0 " exit 1 fi declare -r private_key=$(readlink -e "$1") declare -r signer="$2" declare -r component="$3" shift; shift; shift # Verbose from this point. set -xeo pipefail # Create a temporary working directory. We don't remove this, as we ultimately # print this result and allow the caller to copy wherever they would like. declare -r tmpdir=$(mktemp -d /tmp/repoXXXXXX) # Create a temporary keyring, and ensure it is cleaned up. declare -r keyring=$(mktemp /tmp/keyringXXXXXX.gpg) cleanup() { rm -f "${keyring}" } trap cleanup EXIT gpg --no-default-keyring --keyring "${keyring}" --import "${private_key}" >&2 # Copy the packages, and ensure permissions are correct. for pkg in "$@"; do name=$(basename "${pkg}" .deb) name=$(basename "${name}" .changes) arch=${name##*_} if [[ "${name}" == "${arch}" ]]; then continue # Not a regular package. fi mkdir -p "${tmpdir}"/"${component}"/binary-"${arch}" cp -a "${pkg}" "${tmpdir}"/"${component}"/binary-"${arch}" done find "${tmpdir}" -type f -exec chmod 0644 {} \; # Ensure there are no symlinks hanging around; these may be remnants of the # build process. They may be useful for other things, but we are going to build # an index of the actual packages here. find "${tmpdir}" -type l -exec rm -f {} \; # Sign all packages. for file in "${tmpdir}"/"${component}"/binary-*/*.deb; do dpkg-sig -g "--no-default-keyring --keyring ${keyring}" --sign builder "${file}" >&2 done # Build the package list. for dir in "${tmpdir}"/"${component}"/binary-*; do (cd "${dir}" && apt-ftparchive packages . | gzip > Packages.gz) done # Build the release list. (cd "${tmpdir}" && apt-ftparchive release . > Release) # Sign the release. (cd "${tmpdir}" && gpg --no-default-keyring --keyring "${keyring}" --clearsign -o InRelease Release >&2) (cd "${tmpdir}" && gpg --no-default-keyring --keyring "${keyring}" -abs -o Release.gpg Release >&2) # Show the results. echo "${tmpdir}"