mirror of
https://github.com/systemd/systemd.git
synced 2024-11-01 17:51:22 +03:00
sd-journal: Don't compare hashes from different journal files
In sd_journal_enumerate_fields(), we check if we've already handled a field by checking if we can find it in any of the already processed journal files. We do this by calling journal_file_find_field_object_with_hash(), which compares the size, payload and hash of the given field against all fields in a journal file, trying to find a match. However, since we now use per file hash functions, hashes for the same fields will differ between different journal files, meaning we'll never find an actual match. To fix the issue(), let's use journal_file_find_field_object() when one or more of the files we're comparing is using per file keyed hashes. journal_file_find_field_object() only takes the field payload and size as arguments and calculates the hash itself using the hash function from the journal file we're searching in.
This commit is contained in:
parent
2709d02906
commit
27bf0ab76e
@ -3154,7 +3154,11 @@ _public_ int sd_journal_enumerate_fields(sd_journal *j, const char **field) {
|
||||
if (JOURNAL_HEADER_CONTAINS(of->header, n_fields) && le64toh(of->header->n_fields) <= 0)
|
||||
continue;
|
||||
|
||||
r = journal_file_find_field_object_with_hash(of, o->field.payload, sz, le64toh(o->field.hash), NULL, NULL);
|
||||
if (!JOURNAL_HEADER_KEYED_HASH(f->header) && !JOURNAL_HEADER_KEYED_HASH(of->header))
|
||||
r = journal_file_find_field_object_with_hash(of, o->field.payload, sz,
|
||||
le64toh(o->field.hash), NULL, NULL);
|
||||
else
|
||||
r = journal_file_find_field_object(of, o->field.payload, sz, NULL, NULL);
|
||||
if (r < 0)
|
||||
return r;
|
||||
if (r > 0) {
|
||||
|
Loading…
Reference in New Issue
Block a user