Skip to content

Commit

Permalink
Tools: specify pymonocypher version in more places
Browse files Browse the repository at this point in the history
and confirm version when running tools
  • Loading branch information
tridge committed May 18, 2024
1 parent ffec56c commit bf4acde
Show file tree
Hide file tree
Showing 5 changed files with 23 additions and 11 deletions.
7 changes: 6 additions & 1 deletion Tools/ardupilotwaf/chibios.py
Original file line number Diff line number Diff line change
Expand Up @@ -261,8 +261,13 @@ def sign_firmware(image, private_keyfile):
try:
import monocypher
except ImportError:
Logs.error("Please install monocypher with: python3 -m pip install pymonocypher")
Logs.error("Please install monocypher with: python3 -m pip install pymonocypher==3.1.3.2")
return None

if monocypher.__version__ != "3.1.3.2":
Logs.error("must use monocypher 3.1.3.2, please run: python3 -m pip install pymonocypher==3.1.3.2")
return None

try:
key = open(private_keyfile, 'r').read()
except Exception as ex:
Expand Down
10 changes: 8 additions & 2 deletions Tools/scripts/signing/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ firmware doesn't match any of the public keys in the bootloader.
To generate a public/private key pair, run the following command:

```
python3 -m pip install pymonocypher
python3 -m pip install pymonocypher==3.1.3.2
Tools/scripts/signing/generate_keys.py NAME
```

Expand Down Expand Up @@ -131,7 +131,13 @@ This opens a secure command session using your private_key.dat file to allow the
securecommand getpublickeys will return the number of public keys...you will need this next
securecommand removepublickeys 0 X where X is the number of public keys...this removes them
```
Re-run the 'getpublickeys' command again to verify that all keys have been removed.

For example, if you have a standard firmware with the 3 ArduPilot
public keys and one of your own public keys then X will be 4 in the
above command.

Re-run the 'getpublickeys' command again to verify that all keys have
been removed.

Now exit MAVProxy and build a firmware using the normal bootloader but still using the --signed-fw option:

Expand Down
5 changes: 4 additions & 1 deletion Tools/scripts/signing/generate_keys.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,12 @@
try:
import monocypher
except ImportError:
print("Please install monocypher with: python3 -m pip install pymonocypher")
print("Please install monocypher with: python3 -m pip install pymonocypher==3.1.3.2")
sys.exit(1)

if monocypher.__version__ != "3.1.3.2":
Logs.error("must use monocypher 3.1.3.2, please run: python3 -m pip install pymonocypher==3.1.3.2")
sys.exit(1)

if len(sys.argv) != 2:
print("Usage: generate_keys.py BASENAME")
Expand Down
6 changes: 0 additions & 6 deletions Tools/scripts/signing/make_secure_bl.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,6 @@
import os
import base64

try:
import monocypher
except ImportError:
print("Please install monocypher with: python3 -m pip install pymonocypher")
sys.exit(1)

# get command line arguments
from argparse import ArgumentParser
parser = ArgumentParser(description='make_secure_bl')
Expand Down
6 changes: 5 additions & 1 deletion Tools/scripts/signing/make_secure_fw.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,9 +10,13 @@
try:
import monocypher
except ImportError:
print("Please install monocypher with: python3 -m pip install pymonocypher")
print("Please install monocypher with: python3 -m pip install pymonocypher==3.1.3.2")
sys.exit(1)

if monocypher.__version__ != "3.1.3.2":
Logs.error("must use monocypher 3.1.3.2, please run: python3 -m pip install pymonocypher==3.1.3.2")
return None

key_len = 32
sig_len = 64
sig_version = 30437
Expand Down

0 comments on commit bf4acde

Please sign in to comment.