Skip to content

Commit

Permalink
add dcap quote support
Browse files Browse the repository at this point in the history
Signed-off-by: Jun Kimura <jun.kimura@datachain.jp>
  • Loading branch information
bluele committed Oct 19, 2024
1 parent 4df1e8d commit 91e037c
Show file tree
Hide file tree
Showing 43 changed files with 5,493 additions and 610 deletions.
593 changes: 468 additions & 125 deletions Cargo.lock

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ members = [
"modules/tendermint-lc",
"modules/mock-lc",
"modules/service",
"modules/dcap-qvl",
"proto",
"tests/integration",
"tools/nodes-runner",
Expand Down
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -216,7 +216,7 @@ TEST_ENCLAVE_CARGO_TEST=$(TEST_ENCLAVE_CARGO) test $(CARGO_TARGET)

.PHONY: test
test:
@cargo test $(CARGO_TARGET) --lib --workspace --exclude integration-test
@cargo test $(CARGO_TARGET) --workspace --exclude integration-test
@$(TEST_ENCLAVE_CARGO_TEST) -p ecall-handler
@$(TEST_ENCLAVE_CARGO_TEST) -p enclave-environment
@$(TEST_ENCLAVE_CARGO_TEST) -p host-api
Expand Down
108 changes: 54 additions & 54 deletions app/src/commands/attestation.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,22 +2,23 @@ use crate::{
enclave::EnclaveLoader,
opts::{EnclaveOpts, Opts},
};
use anyhow::{bail, Result};
use anyhow::{anyhow, bail, Result};
use clap::Parser;
use crypto::Address;
use enclave_api::{Enclave, EnclaveCommandAPI, EnclaveProtoAPI};
use host::store::transaction::CommitStore;
use log::info;
use remote_attestation::{ias, IASMode};
use remote_attestation::{dcap, ias, IASMode};

/// `attestation` subcommand
#[allow(clippy::upper_case_acronyms)]
#[derive(Debug, Parser)]
pub enum AttestationCmd {
#[clap(display_order = 1, about = "Remote Attestation with IAS")]
IAS(IASRemoteAttestation),
#[clap(display_order = 2, about = "Remote Attestation with DCAP")]
DCAP(DCAPRemoteAttestation),
#[cfg(feature = "sgx-sw")]
#[clap(display_order = 2, about = "Simulate Remote Attestation")]
#[clap(display_order = 3, about = "Simulate Remote Attestation")]
Simulate(SimulateRemoteAttestation),
}

Expand All @@ -29,26 +30,23 @@ impl AttestationCmd {
L: EnclaveLoader<S>,
{
let home = opts.get_home();
if !home.exists() {
bail!("home directory doesn't exist at {:?}", home);
}
match self {
AttestationCmd::IAS(cmd) => {
if !home.exists() {
bail!("home directory doesn't exist at {:?}", home);
}
run_ias_remote_attestation(
enclave_loader.load(opts, cmd.enclave.path.as_ref(), cmd.enclave.is_debug())?,
cmd,
)
}
AttestationCmd::IAS(cmd) => run_ias_remote_attestation(
enclave_loader.load(opts, cmd.enclave.path.as_ref(), cmd.enclave.is_debug())?,
cmd,
),
AttestationCmd::DCAP(cmd) => run_dcap_remote_attestation(
enclave_loader.load(opts, cmd.enclave.path.as_ref(), cmd.enclave.is_debug())?,
cmd,
),
#[cfg(feature = "sgx-sw")]
AttestationCmd::Simulate(cmd) => {
if !home.exists() {
bail!("home directory doesn't exist at {:?}", home);
}
run_simulate_remote_attestation(
enclave_loader.load(opts, cmd.enclave.path.as_ref(), cmd.enclave.is_debug())?,
cmd,
)
}
AttestationCmd::Simulate(cmd) => run_simulate_remote_attestation(
enclave_loader.load(opts, cmd.enclave.path.as_ref(), cmd.enclave.is_debug())?,
cmd,
),
}
}
}
Expand Down Expand Up @@ -76,8 +74,8 @@ fn run_ias_remote_attestation<E: EnclaveCommandAPI<S>, S: CommitStore>(
let spid = std::env::var("SPID")?;
let ias_key = std::env::var("IAS_KEY")?;
let target_enclave_key = Address::from_hex_string(&cmd.enclave_key)?;
match ias::run_ias_ra(
&enclave,
ias::run_ias_ra(
enclave.get_key_manager(),
target_enclave_key,
if cmd.is_dev {
IASMode::Development
Expand All @@ -86,20 +84,9 @@ fn run_ias_remote_attestation<E: EnclaveCommandAPI<S>, S: CommitStore>(
},
spid,
ias_key,
) {
Ok(res) => {
info!("AVR: {:?}", res.avr);
info!(
"report_data: {}",
res.get_avr()?.parse_quote()?.report_data()
);
enclave
.get_key_manager()
.save_avr(target_enclave_key, res)?;
Ok(())
}
Err(e) => bail!("failed to perform IAS Remote Attestation: {}", e),
}
)
.map_err(|e| anyhow!("failed to perform IAS Remote Attestation: {}", e))?;
Ok(())
}

#[cfg(feature = "sgx-sw")]
Expand Down Expand Up @@ -211,25 +198,38 @@ fn run_simulate_remote_attestation<E: EnclaveCommandAPI<S>, S: CommitStore>(
}

let target_enclave_key = Address::from_hex_string(&cmd.enclave_key)?;
match remote_attestation::ias_simulation::run_ias_ra_simulation(
&enclave,
remote_attestation::ias_simulation::run_ias_ra_simulation(
enclave.get_key_manager(),
target_enclave_key,
cmd.advisory_ids.clone(),
cmd.isv_enclave_quote_status.clone(),
signing_key,
signing_cert,
) {
Ok(res) => {
info!("AVR: {:?}", res.avr);
info!(
"report_data: {}",
res.get_avr()?.parse_quote()?.report_data()
);
enclave
.get_key_manager()
.save_avr(target_enclave_key, res)?;
Ok(())
}
Err(e) => bail!("failed to simulate Remote Attestation: {}", e),
}
)
.map_err(|e| anyhow!("failed to simulate Remote Attestation: {}", e))?;
Ok(())
}

#[derive(Clone, Debug, Parser, PartialEq)]
pub struct DCAPRemoteAttestation {
/// Options for enclave
#[clap(flatten)]
pub enclave: EnclaveOpts,
/// An enclave key attested by Remote Attestation
#[clap(
long = "enclave_key",
help = "An enclave key attested by Remote Attestation"
)]
pub enclave_key: String,
}

fn run_dcap_remote_attestation<E: EnclaveCommandAPI<S>, S: CommitStore>(
enclave: E,
cmd: &DCAPRemoteAttestation,
) -> Result<()> {
dcap::run_dcap_ra(
enclave.get_key_manager(),
Address::from_hex_string(&cmd.enclave_key)?,
)?;
Ok(())
}
11 changes: 6 additions & 5 deletions app/src/commands/enclave.rs
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,8 @@ pub struct GenerateKey {
hain"
)]
pub operator: Option<String>,
// TODO add target qe option
#[clap(long = "target_qe3", help = "Create a report for QE3 instead of QE")]
pub target_qe3: bool,
}

impl GenerateKey {
Expand All @@ -84,7 +85,7 @@ fn run_generate_key<E: EnclaveCommandAPI<S>, S: CommitStore>(
enclave: E,
input: &GenerateKey,
) -> Result<()> {
let (target_info, _) = remote_attestation::init_quote()?;
let (target_info, _) = remote_attestation::init_quote(input.target_qe3)?;
let res = enclave
.generate_enclave_key(GenerateEnclaveKeyInput {
target_info,
Expand Down Expand Up @@ -120,9 +121,9 @@ fn run_list_keys<E: EnclaveCommandAPI<S>, S: CommitStore>(
};
let mut list_json = Vec::new();
for eki in list {
match eki.signed_avr {
Some(signed_avr) => {
let avr = signed_avr.get_avr()?;
match eki.ias_report {
Some(ias_report) => {
let avr = ias_report.get_avr()?;
let report_data = avr.parse_quote()?.report_data();
list_json.push(json! {{
"address": eki.address.to_hex_string(),
Expand Down
Loading

0 comments on commit 91e037c

Please sign in to comment.