Compare commits
No commits in common. "master" and "v0.6.0" have entirely different histories.
2
.gitignore
vendored
2
.gitignore
vendored
@ -1,5 +1,3 @@
|
|||||||
# SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
dtrfs.tar
|
dtrfs.tar
|
||||||
build
|
build
|
||||||
tmp
|
tmp
|
||||||
|
24
LICENSE
24
LICENSE
@ -1,24 +0,0 @@
|
|||||||
This is free and unencumbered software released into the public domain.
|
|
||||||
|
|
||||||
Anyone is free to copy, modify, publish, use, compile, sell, or
|
|
||||||
distribute this software, either in source code form or as a compiled
|
|
||||||
binary, for any purpose, commercial or non-commercial, and by any
|
|
||||||
means.
|
|
||||||
|
|
||||||
In jurisdictions that recognize copyright laws, the author or authors
|
|
||||||
of this software dedicate any and all copyright interest in the
|
|
||||||
software to the public domain. We make this dedication for the benefit
|
|
||||||
of the public at large and to the detriment of our heirs and
|
|
||||||
successors. We intend this dedication to be an overt act of
|
|
||||||
relinquishment in perpetuity of all present and future rights to this
|
|
||||||
software under copyright law.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
|
||||||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
|
||||||
ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
|
||||||
OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
|
|
||||||
For more information, please refer to <https://unlicense.org/>
|
|
@ -1,7 +1,3 @@
|
|||||||
<!--
|
|
||||||
SPDX-License-Identifier: Unlicense
|
|
||||||
-->
|
|
||||||
|
|
||||||
## OS template
|
## OS template
|
||||||
|
|
||||||
You will need a working OS template to work with this project.
|
You will need a working OS template to work with this project.
|
||||||
|
2
dtrfs_api/Cargo.lock
generated
2
dtrfs_api/Cargo.lock
generated
@ -1,5 +1,3 @@
|
|||||||
# SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
# This file is automatically @generated by Cargo.
|
# This file is automatically @generated by Cargo.
|
||||||
# It is not intended for manual editing.
|
# It is not intended for manual editing.
|
||||||
version = 4
|
version = 4
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
# SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
[package]
|
[package]
|
||||||
name = "dtrfs_api"
|
name = "dtrfs_api"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
# SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
reorder_impl_items = true
|
reorder_impl_items = true
|
||||||
use_small_heuristics = "Max"
|
use_small_heuristics = "Max"
|
||||||
merge_imports = true
|
merge_imports = true
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
// SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
mod os;
|
mod os;
|
||||||
mod snp;
|
mod snp;
|
||||||
|
|
||||||
@ -86,7 +84,6 @@ async fn get_report() -> HttpResponse {
|
|||||||
|
|
||||||
#[derive(Deserialize)]
|
#[derive(Deserialize)]
|
||||||
struct InstallForm {
|
struct InstallForm {
|
||||||
hostname: String,
|
|
||||||
url: String,
|
url: String,
|
||||||
sha: String,
|
sha: String,
|
||||||
keyfile: String,
|
keyfile: String,
|
||||||
@ -98,7 +95,7 @@ async fn post_install_form(req: HttpRequest, form: web::Form<InstallForm>) -> Ht
|
|||||||
if let Err(e) = verify(&req) {
|
if let Err(e) = verify(&req) {
|
||||||
return HttpResponse::BadRequest().body(format!("Signature verification failed: {}", e));
|
return HttpResponse::BadRequest().body(format!("Signature verification failed: {}", e));
|
||||||
};
|
};
|
||||||
match os::encrypt_and_install_os(&form.url, &form.sha, &form.keyfile, &form.hostname) {
|
match os::encrypt_and_install_os(&form.url, &form.sha, &form.keyfile) {
|
||||||
Ok(s) => HttpResponse::Ok().body(s),
|
Ok(s) => HttpResponse::Ok().body(s),
|
||||||
Err(e) => HttpResponse::InternalServerError().body(format!("{e:?}")),
|
Err(e) => HttpResponse::InternalServerError().body(format!("{e:?}")),
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
// SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
use crate::snp::get_derived_key;
|
use crate::snp::get_derived_key;
|
||||||
use anyhow::{anyhow, Result};
|
use anyhow::{anyhow, Result};
|
||||||
use base64::prelude::{Engine, BASE64_URL_SAFE};
|
use base64::prelude::{Engine, BASE64_URL_SAFE};
|
||||||
@ -17,7 +15,6 @@ pub fn encrypt_and_install_os(
|
|||||||
install_url: &str,
|
install_url: &str,
|
||||||
install_sha: &str,
|
install_sha: &str,
|
||||||
keyfile: &str,
|
keyfile: &str,
|
||||||
vm_hostname: &str,
|
|
||||||
) -> Result<String> {
|
) -> Result<String> {
|
||||||
let binary_keyfile = BASE64_URL_SAFE.decode(keyfile)?;
|
let binary_keyfile = BASE64_URL_SAFE.decode(keyfile)?;
|
||||||
std::fs::write(BACKUP_KEYFILE_PATH, binary_keyfile)?;
|
std::fs::write(BACKUP_KEYFILE_PATH, binary_keyfile)?;
|
||||||
@ -27,7 +24,6 @@ pub fn encrypt_and_install_os(
|
|||||||
.env("INSTALL_SHA", install_sha)
|
.env("INSTALL_SHA", install_sha)
|
||||||
.env("SNP_KEY_FILE", SNP_KEYFILE_PATH)
|
.env("SNP_KEY_FILE", SNP_KEYFILE_PATH)
|
||||||
.env("ROOT_KEYFILE", BACKUP_KEYFILE_PATH)
|
.env("ROOT_KEYFILE", BACKUP_KEYFILE_PATH)
|
||||||
.env("VM_HOSTNAME", vm_hostname)
|
|
||||||
.output()?;
|
.output()?;
|
||||||
|
|
||||||
if !install_result.status.success() {
|
if !install_result.status.success() {
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
// SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
use anyhow::{Context, Result};
|
use anyhow::{Context, Result};
|
||||||
use sev::firmware::guest::{AttestationReport, DerivedKey, Firmware, GuestFieldSelect};
|
use sev::firmware::guest::{AttestationReport, DerivedKey, Firmware, GuestFieldSelect};
|
||||||
use base64::prelude::{Engine, BASE64_URL_SAFE};
|
use base64::prelude::{Engine, BASE64_URL_SAFE};
|
||||||
|
@ -3,8 +3,6 @@ asn1_encoder
|
|||||||
async_tx
|
async_tx
|
||||||
async_xor
|
async_xor
|
||||||
atkbd
|
atkbd
|
||||||
bridge
|
|
||||||
br_netfilter
|
|
||||||
cbc
|
cbc
|
||||||
cdrom
|
cdrom
|
||||||
crc16
|
crc16
|
||||||
@ -14,7 +12,6 @@ crc32_pclmul
|
|||||||
crct10dif_pclmul
|
crct10dif_pclmul
|
||||||
cryptd
|
cryptd
|
||||||
crypto_simd
|
crypto_simd
|
||||||
curve25519_x86_64
|
|
||||||
dm_bufio
|
dm_bufio
|
||||||
dm_crypt
|
dm_crypt
|
||||||
dm-integrity
|
dm-integrity
|
||||||
@ -30,53 +27,23 @@ i2c_i801
|
|||||||
i2c_mux
|
i2c_mux
|
||||||
i2c_smbus
|
i2c_smbus
|
||||||
i8042
|
i8042
|
||||||
inet_diag
|
|
||||||
intel_agp
|
intel_agp
|
||||||
intel_gtt
|
intel_gtt
|
||||||
intel_pmc_bxt
|
intel_pmc_bxt
|
||||||
intel_rapl_common
|
intel_rapl_common
|
||||||
intel_rapl_msr
|
intel_rapl_msr
|
||||||
ip6table_filter
|
|
||||||
ip6table_mangle
|
|
||||||
ip6table_nat
|
|
||||||
ip6_tables
|
|
||||||
ip6_udp_tunnel
|
|
||||||
ip_set
|
|
||||||
ip_set_hash_net
|
|
||||||
iptable_filter
|
|
||||||
iptable_mangle
|
|
||||||
iptable_nat
|
|
||||||
iptable_raw
|
|
||||||
ip_tables
|
ip_tables
|
||||||
ipt_REJECT
|
|
||||||
iTCO_vendor_support
|
iTCO_vendor_support
|
||||||
iTCO_wdt
|
iTCO_wdt
|
||||||
jbd2
|
jbd2
|
||||||
libaesgcm
|
|
||||||
libchacha20poly1305
|
|
||||||
libcrc32c
|
|
||||||
libcurve25519_generic
|
|
||||||
libps2
|
libps2
|
||||||
llc
|
|
||||||
loop
|
loop
|
||||||
lpc_ich
|
lpc_ich
|
||||||
mac_hid
|
mac_hid
|
||||||
mbcache
|
mbcache
|
||||||
mousedev
|
mousedev
|
||||||
net_failover
|
net_failover
|
||||||
nf_conntrack
|
|
||||||
nf_conntrack_netlink
|
|
||||||
nf_defrag_ipv4
|
|
||||||
nf_defrag_ipv6
|
|
||||||
nf_nat
|
|
||||||
nfnetlink
|
nfnetlink
|
||||||
nfnetlink_acct
|
|
||||||
nfnetlink_log
|
|
||||||
nf_reject_ipv4
|
|
||||||
nf_tables
|
|
||||||
nft_chain_nat
|
|
||||||
nft_compat
|
|
||||||
overlay
|
|
||||||
parport
|
parport
|
||||||
parport_pc
|
parport_pc
|
||||||
pcspkr
|
pcspkr
|
||||||
@ -94,13 +61,9 @@ sha256
|
|||||||
sha256_ssse3
|
sha256_ssse3
|
||||||
sha512_ssse3
|
sha512_ssse3
|
||||||
sr_mod
|
sr_mod
|
||||||
stp
|
|
||||||
tcp_diag
|
|
||||||
tee
|
tee
|
||||||
trusted
|
trusted
|
||||||
tsm
|
tsm
|
||||||
udp_tunnel
|
|
||||||
veth
|
|
||||||
virtio_blk
|
virtio_blk
|
||||||
virtio_net
|
virtio_net
|
||||||
vivaldi_fmap
|
vivaldi_fmap
|
||||||
@ -109,23 +72,5 @@ vmw_vsock_virtio_transport_common
|
|||||||
vmw_vsock_vmci_transport
|
vmw_vsock_vmci_transport
|
||||||
vsock
|
vsock
|
||||||
vsock_loopback
|
vsock_loopback
|
||||||
vxlan
|
|
||||||
wireguard
|
|
||||||
xfrm_algo
|
|
||||||
xfrm_user
|
|
||||||
xor
|
xor
|
||||||
x_tables
|
x_tables
|
||||||
xt_addrtype
|
|
||||||
xt_comment
|
|
||||||
xt_conntrack
|
|
||||||
xt_limit
|
|
||||||
xt_mark
|
|
||||||
xt_MASQUERADE
|
|
||||||
xt_multiport
|
|
||||||
xt_nat
|
|
||||||
xt_nfacct
|
|
||||||
xt_NFLOG
|
|
||||||
xt_physdev
|
|
||||||
xt_REDIRECT
|
|
||||||
xt_set
|
|
||||||
xt_tcpudp
|
|
||||||
|
@ -1,7 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
cd -- "$( dirname -- "${BASH_SOURCE[0]}" )"
|
cd -- "$( dirname -- "${BASH_SOURCE[0]}" )"
|
||||||
source creator_exports.sh
|
source creator_exports.sh
|
||||||
source creator_functions.sh
|
source creator_functions.sh
|
||||||
@ -24,7 +21,6 @@ install_binary $(which blkid)
|
|||||||
install_binary $(which fdisk)
|
install_binary $(which fdisk)
|
||||||
install_binary $(which sysctl)
|
install_binary $(which sysctl)
|
||||||
install_binary $(which mkfs.ext4)
|
install_binary $(which mkfs.ext4)
|
||||||
install_binary $(which ssh-keygen)
|
|
||||||
install_binary $(which fsarchiver)
|
install_binary $(which fsarchiver)
|
||||||
install_kmod
|
install_kmod
|
||||||
install_busybox
|
install_busybox
|
||||||
|
@ -1,7 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
script_dir=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
|
script_dir=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
|
||||||
|
|
||||||
# root of the initrd, that will be used to create the cpio archive
|
# root of the initrd, that will be used to create the cpio archive
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
echo_cyan() {
|
echo_cyan() {
|
||||||
echo -e "\033[0;36m$1\033[0m"
|
echo -e "\033[0;36m$1\033[0m"
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
source /usr/lib/dtrfs/init_functions.sh
|
source /usr/lib/dtrfs/init_functions.sh
|
||||||
|
|
||||||
install_url="/tmp/detee_install_url"
|
install_url="/tmp/detee_install_url"
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
load_modules() {
|
load_modules() {
|
||||||
cat /load_modules.sh | bash
|
cat /load_modules.sh | bash
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
# This script is called by dtrfs_api to install an OS.
|
# This script is called by dtrfs_api to install an OS.
|
||||||
|
|
||||||
[[ -z "$INSTALL_URL" ]] && {
|
[[ -z "$INSTALL_URL" ]] && {
|
||||||
@ -9,16 +7,11 @@
|
|||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
|
||||||
[[ -z "$INSTALL_SHA" ]] && {
|
[[ -z "$INSTALL_URL" ]] && {
|
||||||
echo "Did not find INSTALL_SHA env variable".
|
echo "Did not find INSTALL_SHA env variable".
|
||||||
exit 2
|
exit 2
|
||||||
}
|
}
|
||||||
|
|
||||||
[[ -z "$VM_HOSTNAME" ]] && {
|
|
||||||
echo "Did not find VM_HOSTNAME env variable".
|
|
||||||
exit 2
|
|
||||||
}
|
|
||||||
|
|
||||||
[[ -f "$ROOT_KEYFILE" ]] || {
|
[[ -f "$ROOT_KEYFILE" ]] || {
|
||||||
echo "Did not find keyfile at the following location: $ROOT_KEYFILE"
|
echo "Did not find keyfile at the following location: $ROOT_KEYFILE"
|
||||||
exit 3
|
exit 3
|
||||||
@ -62,15 +55,16 @@ fsarchiver restdir /mnt/template.fsa /
|
|||||||
rm /mnt/template.fsa
|
rm /mnt/template.fsa
|
||||||
# TODO: decide for UX if maybe we should allow user to inject fstab
|
# TODO: decide for UX if maybe we should allow user to inject fstab
|
||||||
echo "" > /mnt/etc/fstab
|
echo "" > /mnt/etc/fstab
|
||||||
echo "=== Setting up guest hostname as $VM_HOSTNAME"
|
hostname=$(cat /proc/cmdline | grep -oE 'detee_name=[0-9a-z\_\.\-]+' | cut -d '=' -f2)
|
||||||
echo $VM_HOSTNAME > /mnt/etc/hostname
|
echo "=== Setting up guest hostname as $hostname"
|
||||||
|
[[ -n "$hostname" ]] && echo $hostname > /mnt/etc/hostname
|
||||||
|
|
||||||
echo "=== Generating SSH public keys"
|
echo "=== Generating SSH public keys"
|
||||||
echo "root:x:0:0:root:/root:/bin/sh" > /etc/passwd
|
echo "root:x:0:0:root:/root:/bin/sh" > /etc/passwd
|
||||||
[[ -f "/mnt/etc/ssh/ssh_host_rsa_key" ]] ||
|
[[ -f "/mnt/etc/ssh/ssh_host_rsa_key" ]] ||
|
||||||
ssh-keygen -t rsa -f /mnt/etc/ssh/ssh_host_rsa_key -N '' > /dev/null
|
/mnt/usr/bin/ssh-keygen -t rsa -f /mnt/etc/ssh/ssh_host_rsa_key -N '' > /dev/null
|
||||||
[[ -f "/mnt/etc/ssh/ssh_host_ecdsa_key" ]] ||
|
[[ -f "/mnt/etc/ssh/ssh_host_ecdsa_key" ]] ||
|
||||||
ssh-keygen -t ecdsa -f /mnt/etc/ssh/ssh_host_ecdsa_key -N '' > /dev/null
|
/mnt/usr/bin/ssh-keygen -t ecdsa -f /mnt/etc/ssh/ssh_host_ecdsa_key -N '' > /dev/null
|
||||||
[[ -f "/mnt/etc/ssh/ssh_host_ed25519_key" ]] ||
|
[[ -f "/mnt/etc/ssh/ssh_host_ed25519_key" ]] ||
|
||||||
ssh-keygen -t ed25519 -f /mnt/etc/ssh/ssh_host_ed25519_key -N '' > /dev/null
|
/mnt/usr/bin/ssh-keygen -t ed25519 -f /mnt/etc/ssh/ssh_host_ed25519_key -N '' > /dev/null
|
||||||
echo "=== Done! Download keys from /server_pubkeys"
|
echo "=== Done! Download keys from /server_pubkeys"
|
||||||
|
@ -1,7 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
cd -- "$( dirname -- "${BASH_SOURCE[0]}" )"
|
cd -- "$( dirname -- "${BASH_SOURCE[0]}" )"
|
||||||
|
|
||||||
dir="/tmp/dtrfs"
|
dir="/tmp/dtrfs"
|
||||||
|
@ -1,27 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# SPDX-License-Identifier: Unlicense
|
|
||||||
|
|
||||||
kernel_path="/boot/vmlinuz-linux"
|
|
||||||
|
|
||||||
dtrfs_path="$1"
|
|
||||||
dtrfs_name=$(basename $dtrfs_path)
|
|
||||||
dtrfs_sha=$(sha256sum $dtrfs_path | awk '{ print $1 }')
|
|
||||||
kernel_name="vmlinuz-linux-$(uname -r)"
|
|
||||||
kernel_sha=$(sha256sum $kernel_path | awk '{ print $1 }')
|
|
||||||
|
|
||||||
scp $dtrfs_path registry.detee.ltd:/var/www/html/${dtrfs_name}
|
|
||||||
ssh registry.detee.ltd ln -s $dtrfs_name /var/www/html/${dtrfs_sha}
|
|
||||||
|
|
||||||
scp $kernel_path registry.detee.ltd:/var/www/html/${kernel_name}
|
|
||||||
ssh registry.detee.ltd ln -s $kernel_name /var/www/html/${kernel_sha}
|
|
||||||
|
|
||||||
echo "Also add this to detee-cli/src/snp/mod.rs"
|
|
||||||
echo "
|
|
||||||
name: \"dtrfs-$(uname -r)\".to_string(),
|
|
||||||
vendor: \"ghe0\".to_string(),
|
|
||||||
dtrfs_url: \"http://registry.detee.ltd/${dtrfs_name}\".to_string(),
|
|
||||||
dtrfs_sha: \"${dtrfs_sha}\".to_string(),
|
|
||||||
kernel_url: \"http://registry.detee.ltd/${kernel_name}\".to_string(),
|
|
||||||
kernel_sha: \"${kernel_sha}\".to_string()
|
|
||||||
"
|
|
Loading…
Reference in New Issue
Block a user