Updated README.md and VERSION files
23
HIRS_Provisioner.NET/README.md
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
<h1><center>HIRS Provisioner.NET<BR\></center></h1>
|
||||||
|
|
||||||
|
The HIRS Provisioner.NET is an application that can leverage a machine and its TPM to:
|
||||||
|
|
||||||
|
* verify system attributes (as chosen in the ACA policy)
|
||||||
|
* request and store an Attestation Identity Certificate and/or a LDevID Certificate
|
||||||
|
|
||||||
|
The HIRS Provisioner.NET application, along with the HIRS ACA, will perform the following high level tasks
|
||||||
|
during the provision process. Please refer to appendix B for further details:
|
||||||
|
• The HIRS Provisioner retrieves the EK Certificate from the TPMs NVRAM.
|
||||||
|
• The HIRS Provisioner retrieves the Platform Certificate from the EFI partition, if present.
|
||||||
|
• The HIRS Provisioner retrieves the Reference Integrity Manifest (RIM) from the EFI partition, if present.
|
||||||
|
• The HIRS Provisioner retrieves the TPM Event Log.
|
||||||
|
• The HIRS Provisioner retrieves Component data from the device.
|
||||||
|
• An Attestation Identity Key is generated on the TPM, if one is not already present.
|
||||||
|
• The HIRS Provisioner forwards the collected data and sends it to the ACA.
|
||||||
|
• The HIRS ACA (Policy based) validates the Endorsement Credential.
|
||||||
|
• The HIRS ACA (Policy based) validates the Platform Credential(s).
|
||||||
|
• The HIRS ACA (Policy based) validates and new RIM(s)
|
||||||
|
• The performs credential validation according to its policy
|
||||||
|
• If validation is successful, the ACA issues an Attestation Identity Credential or LocalDevID (Policy based) to the device.
|
||||||
|
|
||||||
|
For installation, setep, and usage please refer to the [HIRS_Provisioner.NET Readme](https://github.com/nsacyber/HIRS/blob/master/HIRS_AttestationCAPortal/src/main/webapp/docs/HIRS%20.NET%20Provisioner%20Readme_2.2.pdf)
|
@ -8,7 +8,7 @@
|
|||||||
<PublishSingleFile>true</PublishSingleFile>
|
<PublishSingleFile>true</PublishSingleFile>
|
||||||
<ImplicitUsings>enable</ImplicitUsings>
|
<ImplicitUsings>enable</ImplicitUsings>
|
||||||
<Nullable>enable</Nullable>
|
<Nullable>enable</Nullable>
|
||||||
<PackageVersion>2.2.0</PackageVersion>
|
<PackageVersion>3.0.0</PackageVersion>
|
||||||
<Release></Release>
|
<Release></Release>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
# HIRS TPM 2.0 Provisioner
|
# HIRS TPM 2.0 Provisioner
|
||||||
|
|
||||||
|
Notice: The HIRS TPM 2.0 Provisioner is being deprecated.
|
||||||
|
Please refer to the [HIRS_Provisioner.Net](https://github.com/nsacyber/HIRS/tree/main/HIRS_Provisioner.NET) for currently supported HIRS provisioner.
|
||||||
|
|
||||||
### Overview
|
### Overview
|
||||||
|
|
||||||
This document describes the HIRS TPM 2.0 Provisioner, a program that can leverage a machine and its TPM to:
|
This document describes the HIRS TPM 2.0 Provisioner, a program that can leverage a machine and its TPM to:
|
||||||
|
168
README.md
@ -1,102 +1,154 @@
|
|||||||
<h1><center>Host Integrity at Runtime and Start-up (HIRS) <BR\></center></h1>
|
<h1><center>Host Integrity at Runtime and Start-up (HIRS) <BR\></center></h1>
|
||||||
|
|
||||||
[![Build Status](https://travis-ci.org/nsacyber/HIRS.svg?branch=master)](https://travis-ci.org/nsacyber/HIRS)
|
![HIRS Build Status](https://github.com/nsacyber/HIRS/actions/workflows/system_test.yml/badge.svg)
|
||||||
|
|
||||||
<h2>Attestation Certificate Authority (ACA) and TPM Provisioning with Trusted Computing-based Supply Chain Validation </h2>
|
<h2>Attestation Certificate Authority (ACA) and TPM Provisioning with Trusted Computing-based Supply Chain Validation </h2>
|
||||||
|
|
||||||
The Host Integrity at Runtime and Start-up Attestation Certificate Authority is a Proof of Concept - Prototype intended to spur interest and adoption of the [Trusted Platform Module (TPM)](https://trustedcomputinggroup.org/work-groups/trusted-platform-module/). It's intended for testing and development purposes only and is not intended for production. The ACA's functionality supports the provisioning of both the TPM 1.2 and [TPM 2.0](https://trustedcomputinggroup.org/wp-content/uploads/2019_TCG_TPM2_BriefOverview_DR02web.pdf) with an [Attestation Identity Credential (AIC)](https://www.trustedcomputinggroup.org/wp-content/uploads/IWG-Credential_Profiles_V1_R1_14.pdf). The ACA can be configured to enforce the Validation of Endorsement and Platform Credentials to illustrate a supply chain validation capability.
|
The Host Integrity at Runtime and Start-up Attestation Certificate Authority is a Proof of Concept - Prototype intended to spur interest and adoption of the [Trusted Platform Module (TPM)](https://trustedcomputinggroup.org/work-groups/trusted-platform-module/). It's intended for testing and development purposes only and is not intended for production. The ACA's functionality supports the provisioning of [TPM 2.0](https://trustedcomputinggroup.org/wp-content/uploads/2019_TCG_TPM2_BriefOverview_DR02web.pdf) with an [Attestation Identity Certificate (AIC)](https://www.trustedcomputinggroup.org/wp-content/uploads/IWG-Credential_Profiles_V1_R1_14.pdf). The ACA can be configured to enforce the Validation of Endorsement and Platform Credentials to illustrate a supply chain validation capability.
|
||||||
|
|
||||||
The ACA provides a “provisioner” application to be installed on all devices which will be requesting Attestation Credentials.
|
<p align="center">
|
||||||
The ACA is a web based server which processes Attestation Identity Requests.
|
<img src="images/TCG_AcceptanceTest.png" />
|
||||||
![TPM Provisioning](images/TPM_Provisioning.jpg)
|
</p>
|
||||||
|
|
||||||
Version 1.1 added support for the [Platform Certificate v1.1 Specification](https://trustedcomputinggroup.org/resource/tcg-platform-certificate-profile/). This allows entities that are part of the supply chain (System integrators and Value Added Resellers) the ability to create Delta Platform Certificate to compliment the Base Platform Certificate created by the Platform Manufacturer. See the [Article on Base and Delta Platform Certificates](https://github.com/nsacyber/HIRS/wiki/Base-and-Delta-Platform-Certificates) for details.
|
The HIRS ACA can be used to perform the Acceptance Test. The HIRS ACA is a web based server which processes Attestation Identity Requests.
|
||||||
|
The ACA provides a “provisioner” application to be installed on all devices which will be requesting Attestation Certificates.
|
||||||
|
|
||||||
Version 2.0 added support for the [PC Client Reference Integrity Manifest (RIM) Specification](https://trustedcomputinggroup.org/resource/tcg-pc-client-reference-integrity-manifest-specification/) to provide firmware validation capability to the HIRS ACA. This requires that the manufacturer of a device provide a digitally signed RIM "Bundle" for each device. The HIRS ACA has a new page for uploading and viewing RIM Bundles and a policy setting for requiring Firmware validation.
|
**Notice:** Github Discussions have been enabled for this repo. Please refer to the Dicussion entitled "[HIRS development changes](https://github.com/nsacyber/HIRS/discussions/498)" for development and support notifications.
|
||||||
|
|
||||||
To support the TCG RIM concept a new [tools folder](https://github.com/nsacyber/HIRS/tree/master/tools) has been added to the HIRS project which contains a [tcg_rim_tool command line application](https://github.com/nsacyber/HIRS/tree/master/tools/tcg_rim_tool). The tcg_rim_tool can be used to create NISTIR 8060 compatible SWID tags that adhere to the TCG PC Client RIM specification. It also supports the ability to digitally sign the Base RIM file as the HIRS ACA will require a valid signature in order to upload any RIM file. See the [tgc_rim_tool READ.md](https://github.com/nsacyber/HIRS/blob/master/tools/tcg_rim_tool/README.md) for more details.
|
|
||||||
|
|
||||||
**Notice:** Github Dicussions have been enabled for this repo. Please refer to the Dicussion entitled "[HIRS development changes](https://github.com/nsacyber/HIRS/discussions/498)" for development and support notifications.
|
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
* TPM Provisioner
|
### Attestation Certificate Authority (ACA)
|
||||||
* Requests an Attestation Identity Credential for the TPM from the ACA.
|
* Issues Attestation Identity Certificates or TPM based [Local Device ID (LDevID) certificates](https://github.com/nsacyber/HIRS/wiki/DevID-Certificates) to validated devices holding a TPM
|
||||||
* Takes ownership of TPM if not owned
|
|
||||||
* Uses REST calls to complete the transaction with the ACA
|
|
||||||
* Reads credentials from the TPM's NvRAM as part of the provisioning process.
|
|
||||||
* Reads the device's hardware, network, firmware, and OS info for platform validation
|
|
||||||
* Attestation Certificate Authority
|
|
||||||
* Issues Attestation Identity Credentials to validated devices holding a TPM
|
|
||||||
* Configures policies for enabling/disabling validation procedures
|
* Configures policies for enabling/disabling validation procedures
|
||||||
* Performs TCG-based Supply Chain Validation of connecting clients
|
* Performs TCG-based Supply Chain Validation of connecting clients
|
||||||
* Optionally validates Endorsement and Platform Credentials
|
* Optionally validates Endorsement, Platform Certificates, and Reference Integrity Manifests
|
||||||
* Endorsement Credential Certificate Chain Validation
|
* Endorsement Certificate Certificate Chain Validation
|
||||||
* Process EK Credentials per [TCG EK Credential Profile For TPM Family 2.0](https://trustedcomputinggroup.org/resource/tcg-ek-credential-profile-for-tpm-family-2-0/)
|
* Process EK Certificates per [TCG EK Credential Profile For TPM Family 2.0](https://trustedcomputinggroup.org/resource/tcg-ek-credential-profile-for-tpm-family-2-0/)
|
||||||
* Verifies the endorsement key used by the TPM was placed there by the original equipment manufacturer (OEM)
|
* Verifies the endorsement key used by the TPM was placed there by the original equipment manufacturer (OEM)
|
||||||
* Platform Credential Certificate Chain Validation
|
* Platform Certificate - Certificate Chain Validation
|
||||||
* Process Platform Credentials per [TCG Platform Attribute Credential Profile Specification Version 1.1 Revision 15](https://trustedcomputinggroup.org/wp-content/uploads/IWG_Platform_Certificate_Profile_v1p1_r15_pubrev.pdf)
|
* Process Platform Certificates per [TCG Platform Attribute Credential Profile Specification Version 1.1 Revision 15](https://trustedcomputinggroup.org/wp-content/uploads/IWG_Platform_Certificate_Profile_v1p1_r15_pubrev.pdf)
|
||||||
* Verifies the provenance of the system's hardware components, such as the motherboard and chassis, by comparing measured component information against the manufacturers, models, and serial numbers listed in the Platform Credential
|
* Updates for the [Platform Certificate Version 2.0](https://trustedcomputinggroup.org/wp-content/uploads/TCG-Platform-Certificate-Profile-Version-2.0-Revision-39.pdf) are in the current development cycle
|
||||||
* Attestation CA Dashboard
|
* Verifies the provenance of the system's hardware components, such as the motherboard and chassis, by comparing measured component information against the manufacturers, models, and serial numbers listed in the Platform Certificate
|
||||||
* Displays all Validation Reports, Credentials, and Trust Chains
|
* Firmware Integrity Validation
|
||||||
* Enables ACA policy configuration for validation of Endorsement and Platform Credentials
|
* Creates and verifies a nonce for the TPM Quote
|
||||||
* Enables Import/Export of Certificate (Trust) Chains, Endorsement Credentials, and Platform Credentials
|
* Process TMP Event Logs and checks digests against the TPM Quote
|
||||||
* Optionally allows uploaded credentials to be used in validation for machines that have been reprovisioned by trusted parties since leaving the OEM
|
* Verifies individual event digests against the OEM provided Reference Integrity Measurements
|
||||||
* Firmware Integrity Validation
|
* Checks that firmware and boot related file hashes match those provided by OEMs.
|
||||||
* Checks that firmware and boot related file hashes match those provided by OEMs.
|
* Validates the import of All RIM files imported to the ACA (insure all RIM files were signed by trusted sources)
|
||||||
* Validates the import of All RIM files imported to the ACA (insure all RIM files were signed by trusted sources)
|
* Verifies that the firmware hashes captured by the TPMs Platform Configuration Registers (PCRs) match the firmware hashes obtained from the OEM(s).
|
||||||
* Verifies that the firmware hashes captured by the TPMs Platform Configuration Registers (PCRs) match the firmware hashes obtained from the OEM(s).
|
* Verifies TCG/UEFI boot variables (e.g. BIOS setup data) have not been altered (e.g secure boot).
|
||||||
* Verifies TCG/UEFI boot variables (e.g. BIOS setup data) have not been altered (e.g secure boot).
|
* Attestation CA Dashboard
|
||||||
## Requirements
|
* Displays all Validation Reports, Certificates, and Trust Chains
|
||||||
|
* Enables ACA policy configuration for validation of Endorsement and Platform Certificates
|
||||||
|
* Enables Import/Export of Certificate (Trust) Chains, Endorsement Certificates, and Platform Certificates
|
||||||
|
* Optionally allows uploaded Certificates of trusted parties
|
||||||
|
|
||||||
The HIRS Attestation Certificate Authority (ACA) supports installation on CentOS 6 and 7 instances.
|
### TPM Provisioner
|
||||||
|
* Requests an Attestation Identity Certificate for the TPM from the ACA.
|
||||||
The HIRS Provisioner supports both types of TPMs, 1.2 and 2.0. TPM 1.2 support is available on CentOS 6 and 7. Due to the limitations on the libraries available on Centos 6, TPM 2.0 support is only available on Centos 7.
|
* Transfer's TCG Artifacts to the ACA (TPM Endorsement Certificates, Platform Certificates, Reference Integrity Manifests, Event Logs, etc.)
|
||||||
|
* Reads the device's hardware, network, firmware, and OS info for platform and component validation
|
||||||
|
* Provides a TPM Quote for Firmware Integrity Checking
|
||||||
|
|
||||||
## Installation Instructions
|
## Installation Instructions
|
||||||
|
|
||||||
For detailed instructions, see [Installation notes](https://github.com/nsacyber/HIRS/wiki/installation_notes).
|
For detailed instructions, see [Installation notes](https://github.com/nsacyber/HIRS/wiki/installation_notes).
|
||||||
|
|
||||||
Packages used for installation (e.g. HIRS_Provisioner*el7.noarch.rpm) can be found on the [release page](https://github.com/nsacyber/HIRS/releases).
|
Packages used for installation can be found on the [release page](https://github.com/nsacyber/HIRS/releases).
|
||||||
|
|
||||||
### Installing the ACA
|
### Installing the HIRS ACA
|
||||||
|
There are several options for installing the HIRS ACA
|
||||||
|
|
||||||
Simply run the command `yum install HIRS_AttestationCA*el6.noarch.rpm` or `yum install HIRS_AttestationCA*el7.noarch.rpm` based on your OS.
|
An ACA Docker image is automatically created for each release. To run the ACA container using docker
|
||||||
|
|
||||||
### Installing the Provisioner
|
```
|
||||||
|
docker run --name=aca -p 8443:8443 ghcr.io/nsacyber/hirs/aca:latest
|
||||||
|
```
|
||||||
|
To install the ACA on a Redhat or Rocky Linux download the latest rpm from the [release page](https://github.com/nsacyber/HIRS/releases)
|
||||||
|
then run the command
|
||||||
|
|
||||||
After enabling your TPM in BIOS/UEFI, determine if your machine has a TPM 1.2 or a TPM 2.0 by using the command: <br>
|
```
|
||||||
`dmesg | grep -i tpm_tis`.
|
dnf install HIRS_AttestationCA*.rpm.
|
||||||
|
```
|
||||||
|
|
||||||
To install a TPM 1.2 Provisioner, run:<br>
|
To install the ACA on a Ubuntu Linux download the latest rpm from the [release page](https://github.com/nsacyber/HIRS/releases)
|
||||||
`yum install tpm_module*.rpm`<br>
|
then run the command
|
||||||
`yum install HIRS_Provisioner*el6.noarch.rpm` or `yum install HIRS_Provisioner*el7.noarch.rpm` based on OS<br>
|
```
|
||||||
`hirs-provisioner -c`
|
dnf install HIRS_AttestationCA*.deb.
|
||||||
|
```
|
||||||
|
|
||||||
To install a TPM 2.0 Provisioner, run:<br>
|
### Installing the HIRS_Provisioner.NET
|
||||||
`yum install hirs-provisioner-tpm2*.rpm`
|
|
||||||
|
|
||||||
To configure the provisioner, edit the hirs-site.config file in `/etc/hirs/hirs-site.config`. Edit the file to specify the ACA's fully qualified domain name and port.
|
To install the HIRS_Provisioner.NET on a Redhat or Rocky Linux download the latest rpm package from the [release page](https://github.com/nsacyber/HIRS/releases) then run the command
|
||||||
|
|
||||||
|
```
|
||||||
|
sudo dnf install hirs-provisioner-tpm2*.rpm
|
||||||
|
```
|
||||||
|
|
||||||
|
To install the HIRS_Provisioner.NET on Ubuntu Linux download the latest deb package from the [release page](https://github.com/nsacyber/HIRS/releases) then run the command
|
||||||
|
|
||||||
|
```
|
||||||
|
sudo apt-get install hirs-provisioner-tpm2*.rpm
|
||||||
|
```
|
||||||
|
|
||||||
|
To install the HIRS_Provisioner.NET on Windows download the latest msi package from the [release page](https://github.com/nsacyber/HIRS/releases) then run the command
|
||||||
|
|
||||||
|
```
|
||||||
|
sudo apt-get install hirs-provisioner-tpm2*.rpm
|
||||||
|
```
|
||||||
|
|
||||||
|
Then follow the instructions for setting up the HIRS_provisioner.NET in the [HIRS_Provisioner.NET Readme](https://github.com/nsacyber/HIRS/blob/master/HIRS_AttestationCAPortal/src/main/webapp/docs/HIRS%20.NET%20Provisioner%20Readme_2.2.pdf).
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
To kick off a provision on the client, run the command `sudo tpm_aca_provision`.
|
On Linux: To kick off a provision on the client, open a terminal and run the command
|
||||||
|
|
||||||
To see the results and interact with the ACA, go to the ACA Portal at `https://ACAPortalAddress:ACAPortalPort/HIRS_AttestationCAPortal/portal/index`.
|
```
|
||||||
|
sudo tpm_aca_provision
|
||||||
|
```
|
||||||
|
|
||||||
|
On Windows: Open a powershell as administrator and enter the command
|
||||||
|
|
||||||
|
```
|
||||||
|
tpm_aca_provision
|
||||||
|
```
|
||||||
|
|
||||||
|
To see the results and interact with the ACA, using a browser go to the ACA Portal usng the URL:
|
||||||
|
|
||||||
|
```
|
||||||
|
https://localhost:8443/
|
||||||
|
```
|
||||||
|
|
||||||
|
For more information see the [Getting Started Guide](https://github.com/nsacyber/HIRS/wiki/Gettingstarted)
|
||||||
|
|
||||||
|
## Development History
|
||||||
|
|
||||||
|
Version 1.1 added support for the [Platform Certificate v1.1 Specification](https://trustedcomputinggroup.org/resource/tcg-platform-certificate-profile/). This allows entities that are part of the supply chain (System integrators and Value Added Resellers) the ability to create Delta Platform Certificate to compliment the Base Platform Certificate created by the Platform Manufacturer. See the [Article on Base and Delta Platform Certificates](https://github.com/nsacyber/HIRS/wiki/Base-and-Delta-Platform-Certificates) for details.
|
||||||
|
|
||||||
|
Version 2.0 added support for the [PC Client Reference Integrity Manifest (RIM) Specification](https://trustedcomputinggroup.org/resource/tcg-pc-client-reference-integrity-manifest-specification/) to provide firmware validation capability to the HIRS ACA. This requires that the manufacturer of a device provide a digitally signed RIM "Bundle" for each device. The HIRS ACA has a new page for uploading and viewing RIM Bundles and a policy setting for requiring Firmware validation.
|
||||||
|
|
||||||
|
Version 3.0 was completely refactored to build and run on multiple platforms. The Base OS used for development of the ACA was migrated to Rocky Linux with updates to current dependencies (e.g. Java, Tomcat, Mariadb, etc.) and development tools (e.g. Gradle). New features introduced in Version 3.0 include support for the PC Client RIM 1.1 specification including composite RIMs, time-stamps, and counter signatures and detailed linkages between TCG Event Logs, OEM issuer certificates, and Reference Integrity Manifests (RIMs) have been added to provide greater granularity of information. Support for TPM 1.2 (HIRS_Provisioner) and the Cplus version of the TPM provsioner (HIRS_ProvisionerTPM2) was dropped from Version 3.0 and replaced with the [HIRS_Provisioner.NET](https://github.com/nsacyber/HIRS/tree/master/HIRS_Provisioner.NET).
|
||||||
|
|
||||||
|
To support the TCG RIM concept a new [tools folder](https://github.com/nsacyber/HIRS/tree/master/tools) has been added to the HIRS project which contains a [tcg_rim_tool command line application](https://github.com/nsacyber/HIRS/tree/master/tools/tcg_rim_tool). The tcg_rim_tool can be used to create NISTIR 8060 compatible SWID tags that adhere to the TCG PC Client RIM specification. It also supports the ability to digitally sign the Base RIM file as the HIRS ACA will require a valid signature in order to upload any RIM file. See the [tgc_rim_tool READ.md](https://github.com/nsacyber/HIRS/blob/master/tools/tcg_rim_tool/README.md) for more details.
|
||||||
|
|
||||||
## Quick Links:
|
## Quick Links:
|
||||||
|
Background
|
||||||
* [TPM 2.0: A brief introduction](https://trustedcomputinggroup.org/wp-content/uploads/2019_TCG_TPM2_BriefOverview_DR02web.pdf)
|
* [TPM 2.0: A brief introduction](https://trustedcomputinggroup.org/wp-content/uploads/2019_TCG_TPM2_BriefOverview_DR02web.pdf)
|
||||||
* [Getting started with The ACA and Platform Credentials](https://github.com/nsacyber/HIRS/wiki/Gettingstarted)
|
* [Getting started with the ACA and Platform Certificates](https://github.com/nsacyber/HIRS/wiki/Gettingstarted)
|
||||||
|
|
||||||
|
HIRS Documentation
|
||||||
* [HIRS ACA and TPM provisioner Users Guide](https://github.com/nsacyber/HIRS/blob/master/HIRS_AttestationCAPortal/src/main/webapp/docs/HIRS_ACA_UsersGuide_2.1.pdf)
|
* [HIRS ACA and TPM provisioner Users Guide](https://github.com/nsacyber/HIRS/blob/master/HIRS_AttestationCAPortal/src/main/webapp/docs/HIRS_ACA_UsersGuide_2.1.pdf)
|
||||||
|
* [HIRS_Provisioner.NET Readme](https://github.com/nsacyber/HIRS/blob/master/HIRS_AttestationCAPortal/src/main/webapp/docs/HIRS%20.NET%20Provisioner%20Readme_2.2.pdf)
|
||||||
* [TCG RIM Tool Users Guide](https://github.com/nsacyber/HIRS/blob/master/HIRS_AttestationCAPortal/src/main/webapp/docs/TCG%20Rim%20Tool%20User%20Guide%202.1.pdf)
|
* [TCG RIM Tool Users Guide](https://github.com/nsacyber/HIRS/blob/master/HIRS_AttestationCAPortal/src/main/webapp/docs/TCG%20Rim%20Tool%20User%20Guide%202.1.pdf)
|
||||||
* [TCG Event Log Tool Users Guide](https://github.com/nsacyber/HIRS/blob/master/HIRS_AttestationCAPortal/src/main/webapp/docs/TCG%20Event%20Log%20Tool%20User%20Guide%202.1.pdf)
|
* [TCG Event Log Tool Users Guide](https://github.com/nsacyber/HIRS/blob/master/HIRS_AttestationCAPortal/src/main/webapp/docs/TCG%20Event%20Log%20Tool%20User%20Guide%202.1.pdf)
|
||||||
|
|
||||||
|
HIRS Notes
|
||||||
* [Installation notes](https://github.com/nsacyber/HIRS/wiki/installation_notes)
|
* [Installation notes](https://github.com/nsacyber/HIRS/wiki/installation_notes)
|
||||||
* [Project build instructions](https://github.com/nsacyber/HIRS/wiki/Hirs-build-guide)
|
* [Project build instructions](https://github.com/nsacyber/HIRS/wiki/Hirs-build-guide)
|
||||||
* [HIRS Attestation Certificate Authority FAQ](https://github.com/nsacyber/HIRS/wiki/FAQ)
|
* [HIRS Attestation Certificate Authority FAQ](https://github.com/nsacyber/HIRS/wiki/FAQ)
|
||||||
* [TPM Provisioner Debug](https://github.com/nsacyber/HIRS/wiki/provisioner_debug)
|
* [TPM Provisioner Debug](https://github.com/nsacyber/HIRS/wiki/provisioner_debug)
|
||||||
* [ACA Debug](https://github.com/nsacyber/HIRS/wiki/aca_debug)
|
* [ACA Debug](https://github.com/nsacyber/HIRS/wiki/aca_debug)
|
||||||
* Tools
|
|
||||||
|
Tools
|
||||||
* [Platform Certificate Creator](https://github.com/nsacyber/paccor)
|
* [Platform Certificate Creator](https://github.com/nsacyber/paccor)
|
||||||
* [Reference Integrity Manifest tool (tcg_rim_tool)](https://github.com/nsacyber/HIRS/releases)
|
* [Reference Integrity Manifest tool (tcg_rim_tool)](https://github.com/nsacyber/HIRS/releases)
|
||||||
* [Event Log tool (tcg_eventlog_tool)](https://github.com/nsacyber/HIRS/releases)
|
* [Event Log tool (tcg_eventlog_tool)](https://github.com/nsacyber/HIRS/releases)
|
||||||
|
BIN
images/ACA_ValidationReports.png
Normal file
After Width: | Height: | Size: 58 KiB |
BIN
images/AcceptanceTest_CIS.png
Normal file
After Width: | Height: | Size: 436 KiB |
BIN
images/EndorsementCertificate.png
Normal file
After Width: | Height: | Size: 54 KiB |
BIN
images/HIRS_ACA_MAIN_PAGE.png
Normal file
After Width: | Height: | Size: 131 KiB |
BIN
images/PlatformCertificate.png
Normal file
After Width: | Height: | Size: 54 KiB |
BIN
images/RIM_Certificate.png
Normal file
After Width: | Height: | Size: 59 KiB |
BIN
images/TCG_AcceptanceTest.png
Normal file
After Width: | Height: | Size: 98 KiB |
@ -1,9 +1,9 @@
|
|||||||
To support the [PC Client RIM Specification](https://trustedcomputinggroup.org/wp-content/uploads/TCG_PC_Client_RIM_r0p15_15june2020.pdf) which utilizes the TPM Event Log as a Support RIM type , it was useful to have a tool for inspecting the contents of the [TPM event log](https://github.com/nsacyber/HIRS/wiki/TPM-Event-Logs). A Linux command line tool named "elt" (event log tool) has been created to parse and print human readable output, provide hexidecimal events which can be used as test patterns, and to compare event logs for providing details on what events miscompared.
|
To support the [PC Client RIM Specification](https://trustedcomputinggroup.org/resource/tcg-pc-client-reference-integrity-manifest-specification/) which utilizes the TPM Event Log as a Support RIM type , it was useful to have a tool for inspecting the contents of the [TPM event log](https://github.com/nsacyber/HIRS/wiki/TPM-Event-Logs). A Linux command line tool named "elt" (event log tool) has been created to parse and print human readable output, provide hexidecimal events which can be used as test patterns, and to compare event logs for providing details on what events mis-compared.
|
||||||
|
|
||||||
Note that a TCG Event Log will only be populated on a given device if the device:
|
Note that a TCG Event Log will only be populated on a given device if the device:
|
||||||
1. Utilizes TCG compliant UEFI Firmware.
|
1. Utilizes TCG compliant UEFI Firmware.
|
||||||
2. Has a TPM 1.2 or 2.0 that has been activated prior to the current boot.
|
2. Has a TPM 2.0.
|
||||||
3. Has a TCG aware OS (Most flavors of Linux and Windows 10).
|
3. Has a TPM aware OS (Most flavors of Linux and Windows).
|
||||||
|
|
||||||
The default locations for the TCG Event Log are:
|
The default locations for the TCG Event Log are:
|
||||||
* Windows: C:\Windows\Logs\MeasuredBoot\
|
* Windows: C:\Windows\Logs\MeasuredBoot\
|
||||||
@ -15,8 +15,8 @@ The default locations for the TCG Event Log are:
|
|||||||
To build this tool navigate to the tcg_eventlog-tool directory and use the following command:
|
To build this tool navigate to the tcg_eventlog-tool directory and use the following command:
|
||||||
> ./gradlew clean build
|
> ./gradlew clean build
|
||||||
|
|
||||||
## Windows 10
|
## Windows
|
||||||
Several options exist for building on Windows 10:
|
Several options exist for building on Windows 11:
|
||||||
|
|
||||||
1. Windows command shell (CMD.exe):
|
1. Windows command shell (CMD.exe):
|
||||||
* Navigate to the tcg_eventlog_tool folder and run the widows gradle wrapper:
|
* Navigate to the tcg_eventlog_tool folder and run the widows gradle wrapper:
|
||||||
@ -28,16 +28,26 @@ Several options exist for building on Windows 10:
|
|||||||
In both cases the tcg_eventlog_tool-X.X.jar file should have been placed in the build\libs\tools\ (Windows) or build/libs/tools/ (Linux) folder.
|
In both cases the tcg_eventlog_tool-X.X.jar file should have been placed in the build\libs\tools\ (Windows) or build/libs/tools/ (Linux) folder.
|
||||||
|
|
||||||
# Packaging
|
# Packaging
|
||||||
Currenty only a install file for Linux RPM is supported.
|
Packages for this tool can be found on the [HIRS release page](https://github.com/nsacyber/HIRS/releases)
|
||||||
|
|
||||||
To create an RPM on a linux device use the following command in the same directory:
|
Currently only a packaging for Linux is supported.
|
||||||
> ./gradlew buildRPM
|
|
||||||
|
To create an RPM on a Redhat or Rocky linux device use the following command in the same directory:
|
||||||
|
> ./gradlew buildRpm
|
||||||
|
|
||||||
|
or for a Debian or Ubuntu Linux device:
|
||||||
|
> ./gradlew buildDeb
|
||||||
|
|
||||||
|
the package can be found under the build/distributions/ folder
|
||||||
|
|
||||||
# Installing
|
# Installing
|
||||||
Currenty only a install package for Linux is supported.
|
Currently only a install package for Linux is supported.
|
||||||
|
|
||||||
To install this tool use the following commmand from the same directory:
|
To install this tool on a Redhat or Rocky Linux distro use the following command from the same directory:
|
||||||
> sudo yum localinstall build/distributions/tcg_eventlog_tool*.rpm
|
> sudo dnf install build/distributions/tcg_eventlog_tool*.rpm
|
||||||
|
|
||||||
|
or for a Debian or Ubuntu Linux distro:
|
||||||
|
> sudo apt-get install build/distributions/tcg_eventlog_tool*.deb
|
||||||
|
|
||||||
# Usage
|
# Usage
|
||||||
## Linux
|
## Linux
|
||||||
|
@ -1 +1 @@
|
|||||||
1.0
|
3.0.0
|
||||||
|
@ -1,15 +1,45 @@
|
|||||||
To support the [TCG RIM concept](https://trustedcomputinggroup.org/wp-content/uploads/TCG_RIM_Model_v1-r13_2feb20.pdf) a new command line application alled the The tcg_rim_tool has been created.
|
To support the [TCG RIM concept](https://trustedcomputinggroup.org/resource/tcg-reference-integrity-manifest-rim-information-model/) a new command line application called the The tcg_rim_tool has been created.
|
||||||
The tcg_rim_tool can be used to create NISTIR 8060 compatible SWID tags that adhere to the [TCG PC Client RIM specification](https://trustedcomputinggroup.org/wp-content/uploads/TCG_PC_Client_RIM_r0p15_15june2020.pdf).
|
The tcg_rim_tool can be used to create NISTIR 8060 compatible SWID tags that adhere to the [TCG PC Client RIM specification](https://trustedcomputinggroup.org/resource/tcg-pc-client-reference-integrity-manifest-specification/).
|
||||||
It also supports the ability to digitally sign the Base RIM file as the HIRS ACA will require a valid signature in order to upload any RIM file.
|
It also supports the ability to digitally sign the Base RIM file as the HIRS ACA will require a valid signature in order to upload any RIM file.
|
||||||
|
|
||||||
# Building
|
# Building
|
||||||
To build this tool navigate to the tcg_eventlog-tool directory and use the following commmand:
|
## Linux
|
||||||
|
To build this tool navigate to the tcg_eventlog-tool directory and use the following command:
|
||||||
> ./gradlew clean build
|
> ./gradlew clean build
|
||||||
|
|
||||||
# Packaging
|
## Windows
|
||||||
|
Several options exist for building on Windows 11:
|
||||||
|
|
||||||
To package the tcg_rim_tool use the [package.sh](https://github.com/nsacyber/HIRS/blob/master/tools/tcg_rim_tool/package.sh) script to produce an RPM file for Linux distrobustions that support thw RPM package manager. The rpm file will be located in the rpmbuild/RPMS/x86_64/ directory if the package script was sucessful.
|
1. Windows command shell (CMD.exe):
|
||||||
Although packaging for other distributions is not currently avialble the tool can be built an run on other systems that support java and gradle, such as windows 10.
|
* Navigate to the tcg_eventlog_tool folder and run the widows gradle wrapper:
|
||||||
|
> gradlew.bat clean build
|
||||||
|
2. Windows powershell with Windows Subsystem for Linux enabled.
|
||||||
|
* Navigate to the tcg_eventlog_tool folder and run the Linux gradle wrapper:
|
||||||
|
> ./gradlew clean build
|
||||||
|
|
||||||
|
In both cases the tcg_rim_tool-X.X.jar file should have been placed in the build\libs\tools\ (Windows) or build/libs/tools/ (Linux) folder.
|
||||||
|
|
||||||
|
# Packaging
|
||||||
|
Packages for this tool can be found on the [HIRS release page](https://github.com/nsacyber/HIRS/release
|
||||||
|
|
||||||
|
Currently only a packaging for Linux is supported.
|
||||||
|
|
||||||
|
To create an RPM package on a Redhat or Rocky linux device use the following command in the same directory:
|
||||||
|
> ./gradlew buildRpm
|
||||||
|
|
||||||
|
or for a Debian or Ubuntu Linux distro:
|
||||||
|
> ./gradlew buildDeb
|
||||||
|
|
||||||
|
the package can be found under the build/distributions/ folder
|
||||||
|
|
||||||
|
# Installing
|
||||||
|
Currently only a install packages for Linux are supported.
|
||||||
|
|
||||||
|
To install this tool on a Redhat or Rocky Linux distro use the following command from the same directory:
|
||||||
|
> sudo dnf install build/distributions/tcg_eventlog_tool*.rpm
|
||||||
|
|
||||||
|
or for a Debian or Ubuntu Linux distro:
|
||||||
|
> sudo apt-get install build/distributions/tcg_eventlog_tool*.deb
|
||||||
|
|
||||||
# Usage
|
# Usage
|
||||||
|
|
||||||
|