summaryrefslogtreecommitdiff
path: root/src/catlfish.erl
diff options
context:
space:
mode:
Diffstat (limited to 'src/catlfish.erl')
-rw-r--r--src/catlfish.erl28
1 files changed, 18 insertions, 10 deletions
diff --git a/src/catlfish.erl b/src/catlfish.erl
index e48f788..c6e16bb 100644
--- a/src/catlfish.erl
+++ b/src/catlfish.erl
@@ -126,17 +126,22 @@ add_to_db(Type, LeafCert, CertChain, EntryHash) ->
MTLHash = ht:leaf_hash(MTLText),
ExtraData =
case Type of
- normal -> CertChain;
- precert -> [LeafCert | CertChain]
+ normal -> encode_tls_vector(
+ list_to_binary(
+ [encode_tls_vector(C, 3) || C <- CertChain]),
+ 3);
+ precert ->
+ list_to_binary(
+ [encode_tls_vector(LeafCert, 3),
+ encode_tls_vector(
+ list_to_binary(
+ [encode_tls_vector(C, 3) || C <- CertChain]), 3)])
end,
LogEntry =
list_to_binary(
[encode_tls_vector(MTLText, 4),
encode_tls_vector(
- encode_tls_vector(
- list_to_binary(
- [encode_tls_vector(C, 3) || C <- ExtraData]),
- 3),
+ ExtraData,
4)]),
ok = plop:add(LogEntry, MTLHash, EntryHash),
{TSE, MTLHash}.
@@ -261,20 +266,23 @@ deserialise_extra_data(ExtraData) ->
chain_from_mtl_extradata(MTL, ExtraData) ->
TimestampedEntry = MTL#mtl.entry,
- Chain = deserialise_extra_data(ExtraData),
case TimestampedEntry#timestamped_entry.entry_type of
x509_entry ->
+ {CHN, <<>>} = decode_tls_vector(ExtraData, 3),
+ Chain = deserialise_extra_data(CHN),
SignedEntry = TimestampedEntry#timestamped_entry.signed_entry,
[SignedEntry#signed_x509_entry.asn1_cert | Chain];
precert_entry ->
- Chain
+ {EEC, Rest} = decode_tls_vector(ExtraData, 3),
+ {CHN, <<>>} = decode_tls_vector(Rest, 3),
+ Chain = deserialise_extra_data(CHN),
+ [EEC | Chain]
end.
mtl_and_extra_from_entry(Entry) ->
{MTLText, ExtraDataPacked} = unpack_entry(Entry),
- {ExtraData, <<>>} = decode_tls_vector(ExtraDataPacked, 3),
MTL = deserialise_mtl(MTLText),
- {MTL, ExtraData}.
+ {MTL, ExtraDataPacked}.
verify_mtl(MTL, LeafCert, CertChain) ->
Timestamp = MTL#mtl.entry#timestamped_entry.timestamp,