On 5/14/2019 1:14 PM, Lakshmi wrote:
The motive behind this patch series is to measure the public key
of the IMA signature signer in the IMA log.
I have some questions about the rationale for the design ...
> The IMA signature of the file, logged using ima-sig template, contains
the key identifier of the key that was used to generate the signature.
But outside the client machine this key id is not sufficient to
uniquely determine which key the signature corresponds to.
Why is this not sufficient?
In my implementation, I create a lookup table at the attestation service
that maps the 4-byte IMA log key identifier to the signing public key.
Are you concerned about collisions? Something else?
Providing the public key of the signer in the IMA log would
allow, for example, an attestation service to securely verify
if the key used to generate the IMA signature is a valid and
trusted one, and that the key has not been revoked or expired.
Are you suggesting that the client supply the verification public key
and that the verifier trust it? Wouldn't that make the log self signed?
How would the verifier determine that the key from the IMA log is valid
/ trusted / not revoked from the log itself?
An attestation service would just need to maintain a list of
valid public keys and using the data from the IMA log can attest
the system files loaded on the client machine.
If the verifier has the list of valid keys, why must they also come with
the IMA log?
To achieve the above the patch series does the following:
- Adds a new method in asymmetric_key_subtype to query
the public key of the given key
- Adds a new IMA template namely "ima-sigkey" to store\read
the public key of the IMA signature signer. This template
extends the existing template "ima-sig"
A minor question here.
Are you proposing that the IMA log contain a single ima-sigkey entry per
public key followed by ima-sig entries?
Or are you proposing that ima-sig be replaced by ima-sigkey, and that
each event would contain both the signature and the public key?
If the latter, this could add 25M to a server's 100K log. Would that
increase in size concern anyone? Could it be a concern on the other
end, an IoT device with limited memory?