aboutsummaryrefslogtreecommitdiffstats
path: root/src/include/usr/imgcrypt.h
diff options
context:
space:
mode:
authorMichael Brown <mcb30@ipxe.org>2024-08-29 14:00:34 +0100
committerMichael Brown <mcb30@ipxe.org>2024-08-29 15:11:30 +0100
commit72316b820d4bdbf3d75a0ae7e13f1c3bc8e6ac29 (patch)
tree111872793eecfcd754e93491c8d352bfb4e0e627 /src/include/usr/imgcrypt.h
parent486b15b3c11692af4325cd7d0220cdb72ec27586 (diff)
downloadipxe-72316b820d4bdbf3d75a0ae7e13f1c3bc8e6ac29.tar.gz
[image] Add the "imgdecrypt" command
Add the "imgdecrypt" command that can be used to decrypt a detached encrypted data image using a cipher key obtained from a separate CMS envelope image. For example: # Create non-detached encrypted CMS messages # openssl cms -encrypt -binary -aes-256-gcm -recip client.crt \ -in vmlinuz -outform DER -out vmlinuz.cms openssl cms -encrypt -binary -aes-256-gcm -recip client.crt \ -in initrd.img -outform DER -out initrd.img.cms # Detach data from envelopes (using iPXE's contrib/crypto/cmsdetach) # cmsdetach vmlinuz.cms -d vmlinuz.dat -e vmlinuz.env cmsdetach initrd.img.cms -d initrd.img.dat -e initrd.img.env and then within iPXE: #!ipxe imgfetch http://192.168.0.1/vmlinuz.dat imgfetch http://192.168.0.1/initrd.img.dat imgdecrypt vmlinuz.dat http://192.168.0.1/vmlinuz.env imgdecrypt initrd.img.dat http://192.168.0.1/initrd.img.env boot vmlinuz Signed-off-by: Michael Brown <mcb30@ipxe.org>
Diffstat (limited to 'src/include/usr/imgcrypt.h')
-rw-r--r--src/include/usr/imgcrypt.h17
1 files changed, 17 insertions, 0 deletions
diff --git a/src/include/usr/imgcrypt.h b/src/include/usr/imgcrypt.h
new file mode 100644
index 000000000..c9408c75f
--- /dev/null
+++ b/src/include/usr/imgcrypt.h
@@ -0,0 +1,17 @@
+#ifndef _USR_IMGCRYPT_H
+#define _USR_IMGCRYPT_H
+
+/** @file
+ *
+ * Image encryption management
+ *
+ */
+
+FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
+
+#include <ipxe/image.h>
+
+extern int imgdecrypt ( struct image *image, struct image *envelope,
+ const char *name );
+
+#endif /* _USR_IMGCRYPT_H */