mirror of
https://github.com/nsacyber/HIRS.git
synced 2025-01-19 03:06:41 +00:00
Validation bug (#263)
* Updated code to correctly match up the PCR to the baseline PCR. Also updated values of error messages and reduced firmware error message.
This commit is contained in:
parent
7ab7408b59
commit
49e4ce4db4
@ -7,7 +7,6 @@ import java.security.NoSuchAlgorithmException;
|
||||
import java.security.cert.CertificateException;
|
||||
|
||||
import hirs.data.persist.TPMMeasurementRecord;
|
||||
import hirs.data.persist.baseline.TPMBaseline;
|
||||
import hirs.data.persist.SwidResource;
|
||||
import hirs.validation.SupplyChainCredentialValidator;
|
||||
import org.apache.logging.log4j.LogManager;
|
||||
@ -119,6 +118,7 @@ public class SupplyChainValidationServiceImpl implements SupplyChainValidationSe
|
||||
supplyChainAppraiser);
|
||||
boolean acceptExpiredCerts = policy.isExpiredCertificateValidationEnabled();
|
||||
PlatformCredential baseCredential = null;
|
||||
String componentFailures = "";
|
||||
List<SupplyChainValidation> validations = new LinkedList<>();
|
||||
Map<PlatformCredential, SupplyChainValidation> deltaMapping = new HashMap<>();
|
||||
SupplyChainValidation platformScv = null;
|
||||
@ -221,6 +221,7 @@ public class SupplyChainValidationServiceImpl implements SupplyChainValidationSe
|
||||
String.format("%s%n%s", platformScv.getMessage(),
|
||||
attributeScv.getMessage())));
|
||||
}
|
||||
componentFailures = attributeScv.getMessage();
|
||||
}
|
||||
|
||||
pc.setDevice(device);
|
||||
@ -235,12 +236,10 @@ public class SupplyChainValidationServiceImpl implements SupplyChainValidationSe
|
||||
// compare tpm quote with what is pulled from RIM associated file
|
||||
IssuedAttestationCertificate attCert = IssuedAttestationCertificate
|
||||
.select(this.certificateManager)
|
||||
.byDeviceId(device.getId())
|
||||
.getCertificate();
|
||||
.byDeviceId(device.getId()).getCertificate();
|
||||
PlatformCredential pc = PlatformCredential
|
||||
.select(this.certificateManager)
|
||||
.byDeviceId(device.getId())
|
||||
.getCertificate();
|
||||
.byDeviceId(device.getId()).getCertificate();
|
||||
|
||||
validations.add(validateFirmware(pc, attCert));
|
||||
}
|
||||
@ -249,7 +248,7 @@ public class SupplyChainValidationServiceImpl implements SupplyChainValidationSe
|
||||
SupplyChainValidationSummary summary
|
||||
= new SupplyChainValidationSummary(device, validations);
|
||||
if (baseCredential != null) {
|
||||
baseCredential.setComponentFailures(summary.getMessage());
|
||||
baseCredential.setComponentFailures(componentFailures);
|
||||
this.certificateManager.update(baseCredential);
|
||||
}
|
||||
try {
|
||||
@ -325,29 +324,17 @@ public class SupplyChainValidationServiceImpl implements SupplyChainValidationSe
|
||||
private SupplyChainValidation validateFirmware(final PlatformCredential pc,
|
||||
final IssuedAttestationCertificate attCert) {
|
||||
|
||||
TPMBaseline tpmBline;
|
||||
ReferenceManifest rim = null;
|
||||
String[] baseline = new String[Integer.SIZE];
|
||||
Level level = Level.ERROR;
|
||||
AppraisalStatus fwStatus;
|
||||
|
||||
if (attCert != null) {
|
||||
LOGGER.error(attCert.getPcrValues());
|
||||
String[] pcrsSet = attCert.getPcrValues().split("\\+");
|
||||
String[] pcrs1 = pcrsSet[0].split("\\n");
|
||||
String[] pcrs256 = pcrsSet[1].split("\\n");
|
||||
for (int i = 0; i < pcrs1.length; i++) {
|
||||
if (pcrs1[i].contains(":")) {
|
||||
pcrs1[i].split(":");
|
||||
}
|
||||
}
|
||||
|
||||
for (int i = 0; i < pcrs256.length; i++) {
|
||||
if (pcrs256[i].contains(":")) {
|
||||
pcrs256[i].split(":");
|
||||
}
|
||||
}
|
||||
|
||||
ReferenceManifest rim = ReferenceManifest.select(
|
||||
rim = ReferenceManifest.select(
|
||||
this.referenceManifestManager)
|
||||
.byManufacturer(pc.getManufacturer())
|
||||
.getRIM();
|
||||
@ -360,34 +347,31 @@ public class SupplyChainValidationServiceImpl implements SupplyChainValidationSe
|
||||
StringBuilder sb = new StringBuilder();
|
||||
fwStatus = new AppraisalStatus(PASS,
|
||||
SupplyChainCredentialValidator.FIRMWARE_VALID);
|
||||
String failureMsg = "Firmware validation failed: PCR %d does not"
|
||||
+ " match%n%tBaseline [%s] <> Device [%s]%n";
|
||||
String failureMsg = "Firmware validation failed: PCR %s does not"
|
||||
+ " match%n";
|
||||
|
||||
List<SwidResource> swids = rim.parseResource();
|
||||
for (SwidResource swid : swids) {
|
||||
baseline = swid.getPcrValues()
|
||||
.toArray(new String[swid.getPcrValues().size()]);
|
||||
}
|
||||
/**
|
||||
* baseline is null. The purpose of the if check was to
|
||||
* determine to process doing pcrs1 or pcrs256. So I have to
|
||||
* rethink this.
|
||||
*
|
||||
* this goes back to not knowing if I should do one or the other
|
||||
* and how to make that a setting of some kind.
|
||||
*/
|
||||
if (baseline[0].length() == pcrs1[0].length()) {
|
||||
|
||||
String pcrNum;
|
||||
String pcrValue;
|
||||
if (baseline[0].length() == TPMMeasurementRecord.SHA_BYTE_LENGTH) {
|
||||
for (int i = 0; i <= TPMMeasurementRecord.MAX_PCR_ID; i++) {
|
||||
if (!baseline[i].equals(pcrs1[i])) {
|
||||
sb.append(String.format(failureMsg, i, baseline[i], pcrs1[i]));
|
||||
break;
|
||||
pcrNum = pcrs1[i + 1].split(":")[0].trim();
|
||||
pcrValue = pcrs1[i + 1].split(":")[1].trim();
|
||||
if (!baseline[i].equals(pcrValue)) {
|
||||
sb.append(String.format(failureMsg, pcrNum));
|
||||
}
|
||||
}
|
||||
} else if (baseline[0].length() == pcrs256[0].length()) {
|
||||
} else if (baseline[0].length() == TPMMeasurementRecord.SHA_256_BYTE_LENGTH) {
|
||||
for (int i = 0; i <= TPMMeasurementRecord.MAX_PCR_ID; i++) {
|
||||
if (!baseline[i].equals(pcrs256[i])) {
|
||||
sb.append(String.format(failureMsg, i, baseline[i], pcrs256[i]));
|
||||
break;
|
||||
pcrNum = pcrs256[i + 1].split(":")[0].trim();
|
||||
pcrValue = pcrs256[i + 1].split(":")[1].trim();
|
||||
if (!baseline[i].equals(pcrValue)) {
|
||||
sb.append(String.format(failureMsg, pcrNum));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -10,6 +10,11 @@ import javax.persistence.MappedSuperclass;
|
||||
@MappedSuperclass
|
||||
public abstract class ArchivableEntity extends AbstractEntity {
|
||||
|
||||
/**
|
||||
* Defining the size of a message field for error display.
|
||||
*/
|
||||
public static final int MAX_MESSAGE_LENGTH = 520;
|
||||
|
||||
@Column(name = "archived_time")
|
||||
private Date archivedTime;
|
||||
|
||||
|
@ -53,7 +53,7 @@ public class SupplyChainValidation extends ArchivableEntity {
|
||||
joinColumns = { @JoinColumn(name = "validation_id", nullable = false) })
|
||||
private final List<Certificate> certificatesUsed;
|
||||
|
||||
@Column
|
||||
@Column(length = MAX_MESSAGE_LENGTH)
|
||||
private final String message;
|
||||
|
||||
/**
|
||||
|
@ -248,7 +248,6 @@ public class SupplyChainValidationSummary extends ArchivableEntity {
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
}
|
||||
// if failures, but no error, indicate failure result.
|
||||
if (hasAnyFailures) {
|
||||
|
@ -34,6 +34,16 @@ public final class TPMMeasurementRecord extends ExaminableRecord {
|
||||
*/
|
||||
public static final int MAX_PCR_ID = 23;
|
||||
|
||||
/**
|
||||
* String length of a SHA 1 PCR value.
|
||||
*/
|
||||
public static final int SHA_BYTE_LENGTH = 40;
|
||||
|
||||
/**
|
||||
* String length of a 256 SHA PCR value.
|
||||
*/
|
||||
public static final int SHA_256_BYTE_LENGTH = 64;
|
||||
|
||||
private static final Logger LOGGER =
|
||||
LogManager.getLogger(TPMMeasurementRecord.class);
|
||||
|
||||
|
@ -240,7 +240,7 @@ public class PlatformCredential extends DeviceAssociatedCertificate {
|
||||
@Column
|
||||
private String platformClass = null;
|
||||
|
||||
@Column
|
||||
@Column(length = MAX_MESSAGE_LENGTH)
|
||||
private String componentFailures = Strings.EMPTY;
|
||||
|
||||
@Transient
|
||||
|
Loading…
Reference in New Issue
Block a user