diff options
| author | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2016-09-24 08:57:49 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2016-09-24 08:57:49 -0400 | 
| commit | 2541b135bf481575a150960889a636a0c1688e1d (patch) | |
| tree | 4eaeefd6e03e514634f2d77427eafec008ffd470 | |
| parent | 886cf982d3018f7451f0548dadbc05bd2d583bb6 (diff) | |
| parent | 33685a5a3a98c6ded64d0cc25e37d0180ceb0a6a (diff) | |
Merge pull request #4207 from fbuihuu/fix-journal-hmac-calculation
Fix journal hmac calculation.
| -rw-r--r-- | src/journal/journal-file.c | 21 | 
1 files changed, 13 insertions, 8 deletions
| diff --git a/src/journal/journal-file.c b/src/journal/journal-file.c index 7504326bff..349ef74e81 100644 --- a/src/journal/journal-file.c +++ b/src/journal/journal-file.c @@ -333,8 +333,13 @@ JournalFile* journal_file_close(JournalFile *f) {  #ifdef HAVE_GCRYPT          /* Write the final tag */ -        if (f->seal && f->writable) -                journal_file_append_tag(f); +        if (f->seal && f->writable) { +                int r; + +                r = journal_file_append_tag(f); +                if (r < 0) +                        log_error_errno(r, "Failed to append tag when closing journal: %m"); +        }  #endif          if (f->post_change_timer) { @@ -1369,6 +1374,12 @@ static int journal_file_append_data(          if (r < 0)                  return r; +#ifdef HAVE_GCRYPT +        r = journal_file_hmac_put_object(f, OBJECT_DATA, o, p); +        if (r < 0) +                return r; +#endif +          /* The linking might have altered the window, so let's           * refresh our pointer */          r = journal_file_move_to_object(f, OBJECT_DATA, p, &o); @@ -1393,12 +1404,6 @@ static int journal_file_append_data(                  fo->field.head_data_offset = le64toh(p);          } -#ifdef HAVE_GCRYPT -        r = journal_file_hmac_put_object(f, OBJECT_DATA, o, p); -        if (r < 0) -                return r; -#endif -          if (ret)                  *ret = o; | 
