generate_cert.sh 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. #!/usr/bin/env bash
  2. #
  3. #
  4. # Copyright (c) 2022 Project CHIP Authors
  5. #
  6. # Licensed under the Apache License, Version 2.0 (the "License");
  7. # you may not use this file except in compliance with the License.
  8. # You may obtain a copy of the License at
  9. #
  10. # http://www.apache.org/licenses/LICENSE-2.0
  11. #
  12. # Unless required by applicable law or agreed to in writing, software
  13. # distributed under the License is distributed on an "AS IS" BASIS,
  14. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. # See the License for the specific language governing permissions and
  16. # limitations under the License.
  17. #
  18. #
  19. # Description:
  20. # This is a utility script that creates PAA, PAI and DAC certificates for NXP factory data.
  21. #
  22. if [ -z "$1" ]; then
  23. echo "Usage: ./generate_cert.sh chip-cert-path"
  24. exit 1
  25. fi
  26. CHIP_CERT_TOOL="$1"
  27. function exit_err() {
  28. echo "${1}"
  29. exit 1
  30. }
  31. if [ -z "$DATE" ]; then
  32. DATE="2023-01-19"
  33. fi
  34. if [ -z "$TIME" ]; then
  35. TIME="10:17:00"
  36. fi
  37. if [ -z "$LIFETIME" ]; then
  38. LIFETIME="7305"
  39. fi
  40. if [ -z "$VID" ]; then
  41. VID="1037"
  42. fi
  43. if [ -z "$PID" ]; then
  44. PID="A220"
  45. fi
  46. PAA_DATE="$DATE $TIME"
  47. PAA_LIFETIME="$LIFETIME"
  48. # Generate a new PAA only if PAA cert and key paths were not both specified.
  49. if [[ -n "$PAA_CERT" && -n "$PAA_KEY" ]]; then
  50. echo "A PAA was provided. Will not generate a new one."
  51. GENERATE_PAA=false
  52. else
  53. GENERATE_PAA=true
  54. PAA_CERT="Chip-PAA-NXP-Cert.pem"
  55. PAA_CERT_DER="Chip-PAA-NXP-Cert.der"
  56. PAA_KEY="Chip-PAA-NXP-Key.pem"
  57. fi
  58. PAI_DATE="$PAA_DATE"
  59. PAI_LIFETIME="$LIFETIME"
  60. PAI_VID="$VID"
  61. PAI_PID="$PID"
  62. PAI_CERT="Chip-PAI-NXP-"$PAI_VID"-"$PAI_PID"-Cert.pem"
  63. PAI_CERT_DER="Chip-PAI-NXP-"$PAI_VID"-"$PAI_PID"-Cert.der"
  64. PAI_KEY="Chip-PAI-NXP-"$PAI_VID"-"$PAI_PID"-Key.pem"
  65. DAC_DATE="$PAA_DATE"
  66. DAC_LIFETIME="$LIFETIME"
  67. DAC_VID="$PAI_VID"
  68. DAC_PID="$PAI_PID"
  69. DAC_CERT="Chip-DAC-NXP-"$DAC_VID"-"$DAC_PID"-Cert.pem"
  70. DAC_CERT_DER="Chip-DAC-NXP-"$DAC_VID"-"$DAC_PID"-Cert.der"
  71. DAC_KEY="Chip-DAC-NXP-"$DAC_VID"-"$DAC_PID"-Key.pem"
  72. DAC_KEY_DER="Chip-DAC-NXP-"$DAC_VID"-"$DAC_PID"-Key.der"
  73. # Remove certificates if present
  74. if [ "$GENERATE_PAA" = true ]; then
  75. rm -rf "$PAA_CERT" "$PAA_KEY" "$PAA_CERT_DER" >/dev/null 2>&1
  76. fi
  77. rm -rf "$PAI_CERT" "$PAI_KEY" "$DAC_CERT" "$DAC_KEY" "$PAI_CERT_DER" "$DAC_CERT_DER" "$DAC_KEY_DER" >/dev/null 2>&1
  78. # Generate certificates
  79. echo "Generate certificates"
  80. # PAA (root authoritity)
  81. if [ "$GENERATE_PAA" = true ]; then
  82. "$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"
  83. fi
  84. # PAI (vendor)
  85. "$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"
  86. # DAC (product)
  87. "$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"
  88. # Convert certificates and keys to der format (binary x509)
  89. echo "Convert certificates and keys to DER format"
  90. # PAA
  91. if [ "$GENERATE_PAA" = true ]; then
  92. "$CHIP_CERT_TOOL" convert-cert -d "$PAA_CERT" "$PAA_CERT_DER" && echo "Converted PAA" || exit_err "Failed to convert PAA"
  93. fi
  94. # PAI
  95. "$CHIP_CERT_TOOL" convert-cert -d "$PAI_CERT" "$PAI_CERT_DER" && echo "Converted PAI" || exit_err "Failed to convert PAI"
  96. # DAC Cer
  97. "$CHIP_CERT_TOOL" convert-cert -d "$DAC_CERT" "$DAC_CERT_DER" && echo "Converted DAC Cert" || exit_err "Failed to convert DAC Cert"
  98. # DAC Key
  99. "$CHIP_CERT_TOOL" convert-key -d "$DAC_KEY" "$DAC_KEY_DER" && echo "Converted DAC Key" || exit_err "Failed to convert DAC Key"
  100. if [ -n "$FACTORY_DATA_DEST" ]; then
  101. echo "Moving certificates to $FACTORY_DATA_DEST"
  102. mv Chip-* "$FACTORY_DATA_DEST"
  103. fi