加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
digest-list-tools.1 18.73 KB
一键复制 编辑 原始数据 按行查看 历史
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581
.\" Text automatically generated by txt2man
.TH untitled "07 July 2020" "" ""
.RS
# digest-list-tools
.PP
## Description
.PP
Integrity Measurement Architecture (IMA) is a software in the Linux kernel for
measuring files accessed with the \fBexecve\fP(), \fBmmap\fP() and \fBopen\fP() system calls.
Measurements can be reported to a remote verifier or compared to reference
values, for appraisal.
.PP
The IMA Digest Lists extension stores in the kernel memory reference values
of OS software, and adds a new entry to the measurement list only if calculated
file digests are not found among those values. This new type of IMA measurement
list which only contains digest lists and unknown files uses a different PCR,
which can be specified in the kernel command line with the option
\(cqima_digest_list_pcr=#PCR'.
.PP
The main purpose of this extension is to overcome one of the main challenges
when OS files are measured: final PCR values when the OS is running cannot be
predicted, as files can be accessed in a different order due to parallel
execution.
.PP
With the Digest Lists extension, this problem does not arise as only the
measurement of the preloaded digest lists will be used to update the PCR.
In the good case, the PCR is not further extended if file digests are found in
one of the lists. In the bad case, the PCR is extended with the digest of
unknown files.
.PP
The IMA Digest Lists extension can be also used to grant access to files when
appraisal is enabled. There are two possible usages. Access can be granted if
the digest of file content is found in a digest list: this is less secure as
metadata are not taken into account. Access can be granted if the digest of
metadata is found in a digest list; this is more secure as the current value of
extended attributes and inode attributes protected by EVM must match with those
set when the digest list was created (e.g. by the vendor).
.PP
More information about the extension can be found at the URL:
.PP
https://github.com/euleros/linux/wiki/IMA-Digest-Lists-Extension
.RE
.RE
.PP
.RS
## Software Architecture
.PP
digest-list-tools provides a set of tools necessary to configure the IMA Digest
Lists extension:
.IP \(bu 3
gen_digest_lists:
Generates digest lists from different sources, e.g. the RPM database, a RPM
package or a directory;
.IP \(bu 3
manage_digest_lists:
Manages digest lists and converts digest lists of arbitrary formats to the
format supported by the kernel;
.IP \(bu 3
verify_digest_lists:
Verifies the integrity of digest lists;
.IP \(bu 3
setup_ima_digest_lists:
Generates digest lists, and optionally updates the initial ram disk, including
the digest lists just created;
.IP \(bu 3
setup_ima_digest_list_demo:
Script with a predefined workflow to create digest lists.
.PP
Both manage_digest_lists and gen_digest_lists have a modular design: they can
support additional parsers/generators. Third-party libraries should be placed in
the $libdir/digestlist directory.
.RE
.PP
.RS
### Lifecycle
.PP
.nf
.fam C
gen_digest_lists:
+----------------------+
| Source (e.g. RPM DB) | (1) provide source
+----------------------+
|
|
+------------+ +-------------+ (3) generate digest list and sign
| Generator 1| \.\.\. | Generator N | ---------------------------------|
+------------+ +-------------+ |
+-----------------------------------+ +-------------+ |
| Base library (I/O, xattr, crypto) | <---- | Signing Key | |
+-----------------------------------+ +-------------+ |
(2) provide signing key |
+------+--------------+
| Sig | Digest list |
| | (fmt N) |
+------+--------------+
manage_digest_lists: |
(4) parse digest list (fmt N) |
+----------+ +----------+ |
| Parser 1 | \.\.\. | Parser N | <--------------------------------|
+----------+ +----------+
+-----------------------------------+
| Compact list API (generator) | (5) convert to compact list
+-----------------------------------+
+-----------------------------------+
| Base library (I/O) |
+-----------------------------------+
.fam T
.fi
### Digest List Types
.PP
Digest list types have been defined to restrict the usage of digest list data
for different purposes.
.IP \(bu 3
COMPACT_KEY:
This type of digest list contains the public key used to verify the signatures
of the other digest lists.
.IP \(bu 3
COMPACT_PARSER:
This type of digest list contains the digests of the parser executable and its
shared libraries (including the ones that support new digest list formats).
IMA will not allow user space processes to upload converted digest lists
unless they have this digest type.
.IP \(bu 3
COMPACT_FILE:
This type of digest list contains digests of regular files.
.IP \(bu 3
COMPACT_METADATA:
This type of digest list contains digests of file metadata calculated in the
same way as for EVM portable signatures.
.RE
.PP
.RS
### Digest List Modifiers
.PP
Digest list modifiers are used to provide additional attributes to digest list
types.
.IP \(bu 3
COMPACT_MOD_IMMUTABLE:
This modifier restricts the usage of the file if appraisal is in enforcing
mode. Files whose digest has this modifier can be opened only for read.
.RE
.PP
.RS
### Digest List Directory
.PP
All digest lists are stored by default in the /etc/ima/digest_lists directory.
The format of the file is as follows:
.PP
<#position>-\<digest list type>_list-\<format>-\<filename>
.PP
For example, a typical content of the digest list directory is:
.PP
```
/etc/ima/digest_lists/0-metadata_list-rpm-libxslt-1.1.29-4.fc27-x86_64
/etc/ima/digest_lists/0-metadata_list-rpm-sqlite-libs-3.20.1-2.fc27-x86_64
/etc/ima/digest_lists/0-metadata_list-rpm-xkeyboard-config-2.22-1.fc27-noarch
```
.RE
.PP
.RS
## Installation
### Use Case - Measurement and Appraisal of Executable Code
.PP
This setup procedure can be used to enable appraisal of binaries, shared
libraries and scripts with digest lists.
.PP
#### Prerequisite for Measurement
.IP \(bu 3
check the algorithm of digests in the RPM database by executing:
```
rpm \fB-q\fP systemd \fB--queryformat\fP "%{RPMTAG_FILEDIGESTALGO}\n"
```
the association between ID and digest algorithms can be retrieved at:
https://tools.ietf.org/html/rfc4880#section-9.4
.IP \(bu 3
add to the kernel command line:
```
ima_hash=<hash algo>
```
.PP
#### Prerequisite for Appraisal
.IP \(bu 3
generate a signing key and a certificate including the public key;
certs/signing_key.pem in the kernel source can be used
.IP \(bu 3
convert the certificate to DER format and copy it to /etc/keys:
```
openssl x509 \fB-in\fP certs/signing_key.pem \fB-out\fP /etc/keys/x509_evm.der \
\fB-outform\fP der
```
.IP \(bu 3
add an IMA signature to x509_evm.der with the private part of the same key
.IP \(bu 3
remove 'root=<device>' option from the kernel command line and add the
following line to /etc/dracut.conf:
```
kernel_cmdline+="root=<device>"
```
.IP \(bu 3
add the following line to /etc/dracut.conf, to include the public key to
verify the digest lists:
```
install_items+="/etc/keys/x509_ima.der /etc/keys/x509_evm.der"
```
.RE
.PP
.RS
#### Bootloader Configuration
.PP
It is recommended to create the following entries and add the string below to
the kernel comand line:
.IP 1) 4
MEASUREMENT
```
ima_digest_list_pcr=11 ima_policy="tcb|initrd"
```
.IP 2) 4
APPRAISAL ENFORCE
```
ima_digest_list_pcr=11 ima_policy="tcb|initrd|appraise_tcb|appraise_initrd" \
ima_appraise=digest ima_appraise=enforce-evm
```
.PP
#### IMA Policy
.PP
The following policy must be written to /etc/ima/ima-policy:
.PP
```
measure func=MMAP_CHECK mask=MAY_EXEC
measure func=BPRM_CHECK mask=MAY_EXEC
measure func=MODULE_CHECK
measure func=FIRMWARE_CHECK
measure func=POLICY_CHECK
appraise func=MODULE_CHECK appraise_type=imasig
appraise func=FIRMWARE_CHECK appraise_type=imasig
appraise func=KEXEC_KERNEL_CHECK appraise_type=imasig
appraise func=POLICY_CHECK appraise_type=imasig
appraise func=BPRM_CHECK appraise_type=imasig
appraise func=MMAP_CHECK
```
.PP
The imasig requirement cannot be applied to the MMAP_CHECK hook, as some
processes (e.g. firewalld) map as executable files in tmpfs.
.RE
.PP
.RS
#### Setup
.PP
In a system with the RPM package manager, digest lists can be generated with the
command:
.PP
```
# gen_digest_lists \fB-t\fP metadata \fB-f\fP rpm+db \fB-i\fP l: \fB-o\fP add \fB-p\fP \fB-1\fP \fB-m\fP immutable \
\fB-i\fP f:compact \fB-i\fP F:/lib/firmware \fB-i\fP F:/lib/modules \fB-d\fP /etc/ima/digest_lists \
\fB-i\fP i: \fB-i\fP x: \fB-i\fP e:
```
.PP
The command above selects only packaged files with execute bit set and all the
files in the /lib/firmware and /lib/modules directories. It adds both IMA and
EVM digests to the digest lists for all packages in the RPM database.
.PP
Without an execution policy hardcoded in the kernel, it is necessary to create a
complete digest list for systemd, as configuration files will be still measured
and appraised until the custom policy is loaded by systemd itself:
.PP
```
# gen_digest_lists \fB-t\fP metadata \fB-f\fP rpm+db \fB-i\fP l: \fB-o\fP add \fB-p\fP \fB-1\fP \fB-m\fP immutable \
\fB-i\fP f:compact \fB-i\fP F:/lib/firmware \fB-i\fP F:/lib/modules \fB-d\fP /etc/ima/digest_lists \
\fB-i\fP i: \fB-i\fP x: \fB-i\fP p:systemd
```
.PP
With a custom kernel, it is necessary to additionally execute:
.PP
```
# gen_digest_lists \fB-t\fP metadata \fB-f\fP compact \fB-i\fP l: \fB-o\fP add \fB-p\fP \fB-1\fP \fB-m\fP immutable \
\fB-i\fP I:/lib/modules/`uname \fB-r\fP` \fB-d\fP /etc/ima/digest_lists \fB-i\fP i: \fB-i\fP x:
```
.PP
Other files not known by the package manager can be also added to a digest list:
```
# gen_digest_lists \fB-t\fP metadata \fB-f\fP unknown \fB-i\fP l: \fB-o\fP add \fB-p\fP \fB-1\fP \fB-m\fP immutable \
\fB-i\fP D:/etc/ima/digest_lists \fB-i\fP I:<desired directory> \fB-d\fP /etc/ima/digest_lists \
\fB-i\fP i: \fB-i\fP x: \fB-i\fP e:
```
.PP
After digest lists are created, they must be signed with evmctl:
.PP
```
# evmctl sign \fB-o\fP \fB-a\fP sha256 \fB--imahash\fP \fB--key\fP <private key> \fB-r\fP \
/etc/ima/digest_lists
```
.PP
Regenerate the initial ram disk and include the custom IMA policy:
.PP
```
# dracut \fB-f\fP \fB-exattr\fP \fB-I\fP /etc/ima/ima-policy
```
.PP
In order to execute the command above, that includes extended attributes in the
initial ram disk, it is necessary to apply the patches available at:
.TP
.B
https://github.com/euleros/cpio/tree/xattr-v1
https://github.com/euleros/dracut/tree/digest-lists
.RE
.PP
.RS
Digest lists will be automatically included in the initial ram disk by the new
dracut module 'digestlist', part of this software. Its configuration file is in
/etc/dracut.conf.d.
.RE
.PP
.RS
#### Boot Process
.PP
Digest lists are loaded as early as possible during the boot process, so that
digests can be found before file are accessed. The kernel reads and parses the
digest lists in the /etc/ima/digest_lists directory.
.RE
.PP
.RS
#### Software Update
.PP
If new RPMs are installed on the system, new digest lists must be created with
the same commands introduced above. The new digest lists are not automatically
loaded at boot until the initial ram disk is regenerated. A systemd service will
be developed to load new digest lists without regenerating the initial ram disk.
.RE
.PP
.RS
### Use Case - Immutable and Mutable Files (with HMAC Key)
.PP
The steps described below represent only a configuration example. The list of
files that should be included in the digest lists and the type (immutable or
mutable) depend on user requirements. The setup process is organized in two
different steps. First, the system is booted in rescue mode so that digest of
mutable files can be reliably calculated (there is no process accessing them).
.PP
During the first step, the administrator launches the
setup_ima_digest_lists_demo script to create digest lists for the system.
It might be done by the software vendor if the content of all files that will
be measured/appraised is known in advance. Otherwise, the administrator becomes
responsible for the initial values of the files that will be accessed by the
system, by signing the digest lists. At this stage, the HMAC key is not yet
available. It will be created and sealed once the digest lists are generated.
.PP
For the second step, the administrator runs the system in the final
configuration, so that the HMAC key can be unsealed, but still selects the
rescue mode. During this step, the administrator launches again the
setup_ima_digest_lists_demo script to add a HMAC to every file verified with
the digest lists.
.PP
#### Prerequisite for measurement:
.IP \(bu 3
add 'iversion' mount option in /etc/fstab (if the filesystem supports it)
.IP \(bu 3
check the algorithm of digests in the RPM database by executing:
```
rpm \fB-q\fP systemd \fB--queryformat\fP "%{RPMTAG_FILEDIGESTALGO}\n"
```
the association between ID and digest algorithms can be retrieved at:
https://tools.ietf.org/html/rfc4880#section-9.4
.IP \(bu 3
add to the kernel command line:
```
ima_hash=<hash algo>
```
.PP
#### Prerequisite for appraisal:
.IP \(bu 3
generate a signing key and a certificate including the public key;
certs/signing_key.pem in the kernel source can be used
.IP \(bu 3
convert the certificate to DER format and copy it to /etc/keys:
```
openssl x509 \fB-in\fP certs/signing_key.pem \fB-out\fP /etc/keys/x509_ima.der \
\fB-outform\fP der
```
.IP \(bu 3
generate EVM keys; follow instructions at
https://sourceforge.net/p/linux-ima/wiki/Home/, section 'Creating trusted and
EVM encrypted keys'
.IP \(bu 3
remove 'root=<device>' option from the kernel command line and add the
following line to /etc/dracut.conf:
```
kernel_cmdline+="root=<device>"
```
.IP \(bu 3
copy the following dracut modules from the GIT repository at
https://github.com/dracutdevs/dracut to /usr/lib/dracut/modules.d:
```
96securityfs 97masterkey 98integrity
```
.IP \(bu 3
include dracut modules in the ram disk by adding to /etc/dracut.conf:
```
add_dracutmodules+=" securityfs masterkey integrity"
```
.IP \(bu 3
add the following lines to /etc/dracut.conf, to include the public key to
verify the digest lists, and the EVM keys:
```
install_items+="/etc/keys/x509_ima.der"
install_items+="/etc/keys/kmk-trusted.blob /etc/keys/evm-trusted.blob"
```
(in the last line, replace kmk-trusted with kmk-user if a user key was used as
masterkey)
.IP \(bu 3
add the following line to /etc/dracut.conf, to include SELinux labels in the
initial ram disk:
```
install_items+="/etc/selinux/targeted/contexts/files/file_contexts"
install_items+=/etc/selinux/targeted/contexts/files/file_contexts.subs_dist"
```
.RE
.PP
.RS
#### Bootloader Configuration
.PP
It is recommended to create the following entries and add the string below
to the kernel comand line:
.IP 1) 4
SETUP
```
systemd.unit=setup-ima-digest-lists.service
```
.IP 2) 4
MEASUREMENT
```
ima_digest_list_pcr=11 ima_policy="tcb|initrd"
```
.IP 3) 4
APPRAISAL ENFORCE SETUP
```
ima_digest_list_pcr=11 ima_policy="tcb|initrd|appraise_tcb|appraise_initrd| \
appraise_tmpfs" ima_appraise=digest ima_appraise=enforce-evm evm=random
systemd.unit=setup-ima-digest-lists.service
```
.IP 4) 4
APPRAISAL ENFORCE
```
ima_digest_list_pcr=11 ima_policy="tcb|initrd|appraise_tcb|appraise_initrd| \
appraise_tmpfs" ima_appraise=digest ima_appraise=enforce-evm evm=random
```
.IP 5) 4
APPRAISAL PERMISSIVE
```
ima_digest_list_pcr=11 ima_policy="tcb|initrd|appraise_tcb|appraise_initrd| \
appraise_tmpfs" ima_appraise=digest ima_appraise=log-evm evm=random
```
.RE
.PP
.RS
#### Setup - First Phase
.PP
##### With RPM Package Manager
.PP
digest-list-tools includes a script called setup_ima_digest_lists_demo to
simplify the creation of digest lists. It will create the following digest
lists:
.IP \(bu 3
digest lists from package manager
.IP \(bu 3
digest list of unknown files in the initial ram disk (some are generated by
dracut)
.IP \(bu 3
digest list of IMA policy
.IP \(bu 3
digest list of unknown files in the root filesystem so that appraisal can be
enabled (important: digest of metadata will be created from the current value
of extended attributes; they must be checked by the administrator before the
digest list is generated and signed)
.IP 1) 4
Execute:
.PP
```
# setup_ima_digest_lists_demo initial [signing key] [X.509 certificate]
```
.PP
The procedure is interactive and the script asks the user to confirm/edit the
list of files whose digest will be included in the digest list.
.IP 2) 4
Reboot
.PP
Reboot the system to load the new digest lists during the boot process.
.RE
.PP
.RS
##### Without RPM Package Manager
.PP
An alternative way to create a digest list is to directly take file digests from
the filesystem without using the package manager. To do that, it is sufficient
to edit setup_ima_digest_lists_demo and to comment the line that begins with
\(cqsetup_ima_digest_lists distro'.
.RE
.PP
.RS
#### Setup - Second Phase
.PP
After the first phase of the setup, /etc/ima/digest_lists contains all the
digest lists necessary to boot the system with appraisal enabled and enforced.
The remaining step is to add a HMAC to every file added to the digest lists.
.IP 1) 4
Execute:
.PP
```
# setup_ima_digest_lists_demo final
```
.PP
### Software Update
.PP
#### Generation
.PP
Digest lists can be generated with the gen_digest_lists tool. A description of
this command can be obtained by executing the command:
.PP
```
$ man gen_digest_lists
```
.PP
### Integrity Verification
.PP
The measurement list, after loading the digest lists, will look like:
.PP
```
11 <digest> ima-ng <digest> boot_aggregate
11 <digest> ima-ng <digest> /etc/keys/x509_ima.der
11 <digest> ima-ng <digest> [\.\.\.]/0-parser_list-compact-manage_digest_lists
11 <digest> ima-ng <digest> [\.\.\.]/0-key_list-signing_key.der
11 <digest> ima-ng <digest> [\.\.\.]/1-parser_list-compact-libparser-ima.so
11 <digest> ima-ng <digest> [\.\.\.]/2-parser_list-compact-libparser-rpm.so
11 <digest> ima-ng <digest> [\.\.\.]/0-file_list-rpm-libxslt-1.1.29-4.fc27-x86_64
\.\.\.
<measurement entries for modified mutable files>
```
.PP
An attestation server can use the verify_digest_lists tool to verify the
integrity of digest lists. For example, it can execute:
.PP
```
$ verify_digest_lists
```
.RE
.PP
.RS
## Author
Written by Roberto Sassu, <roberto.sassu at huawei.com>.
.RE
.PP
.RS
## Copying
Copyright (C) 2018-2020 Huawei Technologies Duesseldorf GmbH. Free use of this
software is granted under the terms of the GNU Public License 2.0 (GPLv2).
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化