Skip to content

Example of verifying cryptographically signed and encrypted machine files using Python, Ed25519 and AES-256-GCM.

License

Notifications You must be signed in to change notification settings

davidknight-wayland/example-python-cryptographic-machine-files

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Example Python Cryptographic Machine Files

This is an example of how to verify and decrypt cryptographic machine files in Python, using Ed25519 signing and AES-256-GCM encryption. This example verifies the aes-256-gcm+ed25519 algorithm.

Running the example

First up, add an environment variable containing your Ed25519 public key:

export KEYGEN_PUBLIC_KEY='799efc7752286e6c3815b13358d98fc0f0b566764458adcb48f1be2c10a55906'

You can either run each line above within your terminal session before starting the app, or you can add the above contents to your ~/.bashrc file and then run source ~/.bashrc after saving the file.

Next, install dependencies with pip:

python3 -m pip install -r requirements.txt

Then run the script, passing in a path to a machine file, and a license key as arguments:

python3 main.py --license 'A_LICENSE_KEY' \
  --path /etc/keygen/machine.lic

Or run one of the pre-defined examples:

KEYGEN_PUBLIC_KEY='e8601e48b69383ba520245fd07971e983d06d22c4257cfd82304601479cee788' python3 main.py \
  --fingerprint '198e9fe586114844f6a4eaca5069b41a7ed43fb5a2df84892b69826d64573e39' \
  --license 'B10760-1B177D-656D1F-C03298-9AF89E-V3' \
  --path examples/machine.lic

The following will happen:

  1. The current device will be fingerprinted, using a SHA256-HMAC digest of the device's machineid. You may want to look into alternative fingerprinting, depending on your expected run environment.
  2. The machine file's authenticity will be verified using Ed25519, by verifing its signature using the public key.
  3. The machine file will be decrypted using the license key and fingerprint as the decryption key.

If everything checks out, the script will print the decrypted contents of the machine file — the machine object, with any included data. If it fails, check your inputs.

Questions?

Reach out at [email protected] if you have any questions or concerns!

About

Example of verifying cryptographically signed and encrypted machine files using Python, Ed25519 and AES-256-GCM.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%