1
0
mirror of https://github.com/etcd-io/etcd.git synced 2026-02-05 15:46:51 +01:00
Files
etcd/scripts/updatebom.sh
Ivan Valdes 5bf8e5ae50 Use workspace modules to generate the bom
Signed-off-by: Ivan Valdes <ivan@vald.es>
2025-10-22 13:11:34 -07:00

56 lines
1.9 KiB
Bash
Executable File

#!/usr/bin/env bash
# Copyright 2025 The etcd 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.
set -euo pipefail
source ./scripts/test_lib.sh
function bom_fix {
log_callout "generating bill-of-materials.json"
cp go.mod go.mod.tmp
cp go.sum go.sum.tmp
local _bom_modules=()
load_workspace_relative_modules_for_bom _bom_modules
# Intentionally run the command once first, so it fetches dependencies. The exit code on the first
# run in a just cloned repository is always dirty.
GOOS=linux run_go_tool github.com/appscodelabs/license-bill-of-materials \
--override-file ./bill-of-materials.override.json "${_bom_modules[@]}" &>/dev/null
# BOM file should be generated for linux. Otherwise running this command on other operating systems such as OSX
# results in certain dependencies being excluded from the BOM file, such as procfs.
# For more info, https://github.com/etcd-io/etcd/issues/19665
if GOOS=linux run_go_tool "github.com/appscodelabs/license-bill-of-materials" \
--override-file ./bill-of-materials.override.json \
"${_bom_modules[@]}" > ./bill-of-materials.json.tmp; then
cp ./bill-of-materials.json.tmp ./bill-of-materials.json
log_success "bom refreshed"
else
log_error "FAIL: bom refreshing failed"
mv go.mod.tmp go.mod
mv go.sum.tmp go.sum
return 2
fi
mv go.mod.tmp go.mod
mv go.sum.tmp go.sum
}
# only build when called directly, not sourced
if [[ "$0" =~ updatebom.sh$ ]]; then
bom_fix
fi