| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128 |
- #!/usr/bin/env bash
- #
- #
- # Copyright (c) 2022 Project CHIP 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.
- #
- #
- # Description:
- # This is a utility script that creates PAA, PAI and DAC certificates for NXP factory data.
- #
- if [ -z "$1" ]; then
- echo "Usage: ./generate_cert.sh chip-cert-path"
- exit 1
- fi
- CHIP_CERT_TOOL="$1"
- function exit_err() {
- echo "${1}"
- exit 1
- }
- if [ -z "$DATE" ]; then
- DATE="2023-01-19"
- fi
- if [ -z "$TIME" ]; then
- TIME="10:17:00"
- fi
- if [ -z "$LIFETIME" ]; then
- LIFETIME="7305"
- fi
- if [ -z "$VID" ]; then
- VID="1037"
- fi
- if [ -z "$PID" ]; then
- PID="A220"
- fi
- PAA_DATE="$DATE $TIME"
- PAA_LIFETIME="$LIFETIME"
- # Generate a new PAA only if PAA cert and key paths were not both specified.
- if [[ -n "$PAA_CERT" && -n "$PAA_KEY" ]]; then
- echo "A PAA was provided. Will not generate a new one."
- GENERATE_PAA=false
- else
- GENERATE_PAA=true
- PAA_CERT="Chip-PAA-NXP-Cert.pem"
- PAA_CERT_DER="Chip-PAA-NXP-Cert.der"
- PAA_KEY="Chip-PAA-NXP-Key.pem"
- fi
- PAI_DATE="$PAA_DATE"
- PAI_LIFETIME="$LIFETIME"
- PAI_VID="$VID"
- PAI_PID="$PID"
- PAI_CERT="Chip-PAI-NXP-"$PAI_VID"-"$PAI_PID"-Cert.pem"
- PAI_CERT_DER="Chip-PAI-NXP-"$PAI_VID"-"$PAI_PID"-Cert.der"
- PAI_KEY="Chip-PAI-NXP-"$PAI_VID"-"$PAI_PID"-Key.pem"
- DAC_DATE="$PAA_DATE"
- DAC_LIFETIME="$LIFETIME"
- DAC_VID="$PAI_VID"
- DAC_PID="$PAI_PID"
- DAC_CERT="Chip-DAC-NXP-"$DAC_VID"-"$DAC_PID"-Cert.pem"
- DAC_CERT_DER="Chip-DAC-NXP-"$DAC_VID"-"$DAC_PID"-Cert.der"
- DAC_KEY="Chip-DAC-NXP-"$DAC_VID"-"$DAC_PID"-Key.pem"
- DAC_KEY_DER="Chip-DAC-NXP-"$DAC_VID"-"$DAC_PID"-Key.der"
- # Remove certificates if present
- if [ "$GENERATE_PAA" = true ]; then
- rm -rf "$PAA_CERT" "$PAA_KEY" "$PAA_CERT_DER" >/dev/null 2>&1
- fi
- rm -rf "$PAI_CERT" "$PAI_KEY" "$DAC_CERT" "$DAC_KEY" "$PAI_CERT_DER" "$DAC_CERT_DER" "$DAC_KEY_DER" >/dev/null 2>&1
- # Generate certificates
- echo "Generate certificates"
- # PAA (root authoritity)
- if [ "$GENERATE_PAA" = true ]; then
- "$CHIP_CERT_TOOL" gen-att-cert --type a --subject-cn "Matter Development PAA NXP" --valid-from "$PAA_DATE" --lifetime "$PAA_LIFETIME" --out-key "$PAA_KEY" --out "$PAA_CERT" && echo "Generated PAA" || exit_err "Failed to generate PAA"
- fi
- # PAI (vendor)
- "$CHIP_CERT_TOOL" gen-att-cert --type i --subject-cn "Matter Development PAI NXP" --subject-vid "$PAI_VID" --valid-from "$PAI_DATE" --lifetime "$PAI_LIFETIME" --ca-key "$PAA_KEY" --ca-cert "$PAA_CERT" --out-key "$PAI_KEY" --out "$PAI_CERT" && echo "Generated PAI" || exit_err "Failed to generate PAI"
- # DAC (product)
- "$CHIP_CERT_TOOL" gen-att-cert --type d --subject-cn "Matter Development DAC NXP" --subject-vid "$DAC_VID" --subject-pid "$DAC_PID" --valid-from "$DAC_DATE" --lifetime "$DAC_LIFETIME" --ca-key "$PAI_KEY" --ca-cert "$PAI_CERT" --out-key "$DAC_KEY" --out "$DAC_CERT" && echo "Generated DAC" || exit_err "Failed to generate DAC"
- # Convert certificates and keys to der format (binary x509)
- echo "Convert certificates and keys to DER format"
- # PAA
- if [ "$GENERATE_PAA" = true ]; then
- "$CHIP_CERT_TOOL" convert-cert -d "$PAA_CERT" "$PAA_CERT_DER" && echo "Converted PAA" || exit_err "Failed to convert PAA"
- fi
- # PAI
- "$CHIP_CERT_TOOL" convert-cert -d "$PAI_CERT" "$PAI_CERT_DER" && echo "Converted PAI" || exit_err "Failed to convert PAI"
- # DAC Cer
- "$CHIP_CERT_TOOL" convert-cert -d "$DAC_CERT" "$DAC_CERT_DER" && echo "Converted DAC Cert" || exit_err "Failed to convert DAC Cert"
- # DAC Key
- "$CHIP_CERT_TOOL" convert-key -d "$DAC_KEY" "$DAC_KEY_DER" && echo "Converted DAC Key" || exit_err "Failed to convert DAC Key"
- if [ -n "$FACTORY_DATA_DEST" ]; then
- echo "Moving certificates to $FACTORY_DATA_DEST"
- mv Chip-* "$FACTORY_DATA_DEST"
- fi
|