~ubuntu-branches/ubuntu/trusty/dovecot/trusty-updates

« back to all changes in this revision

Viewing changes to src/lib/hmac-sha1.c

  • Committer: Package Import Robot
  • Author(s): James Page
  • Date: 2014-01-08 09:35:49 UTC
  • mfrom: (1.15.3) (96.1.1 trusty-proposed)
  • Revision ID: package-import@ubuntu.com-20140108093549-814nkqdcxfbvgktg
Tags: 1:2.2.9-1ubuntu1
* Merge from Debian unstable, remaining changes:
  + Add mail-stack-delivery package:
    - Update d/rules
    - d/control: convert existing dovecot-postfix package to a dummy
      package and add new mail-stack-delivery package.
    - Update maintainer scripts.
    - Rename d/dovecot-postfix.* to debian/mail-stack-delivery.*
    - d/mail-stack-delivery.preinst: Move previously installed backups and
      config files to a new package namespace.
    - d/mail-stack-delivery.prerm: Added to handle downgrades.
  + Use Snakeoil SSL certificates by default:
    - d/control: Depend on ssl-cert.
    - d/dovecot-core.postinst: Relax grep for SSL_* a bit.
  + Add autopkgtest to debian/tests/*.
  + Add ufw integration:
    - d/dovecot-core.ufw.profile: new ufw profile.
    - d/rules: install profile in dovecot-core.
    - d/control: dovecot-core - suggest ufw.
  + d/dovecot-core.dirs: Added usr/share/doc/dovecot-core
  + Add apport hook:
    - d/rules, d/source_dovecot.py
  + Add upstart job:
    - d/rules, d/dovecot-core.dovecot.upstart, d/control,
      d/dovecot-core.dirs, dovecot-imapd.{postrm, postinst, prerm},
      d/dovecot-pop3d.{postinst, postrm, prerm}.
      d/mail-stack-deliver.postinst: Convert init script to upstart.
  + Use the autotools-dev dh addon to update config.guess/config.sub for
    arm64.
* Dropped changes, included in Debian:
  - Update Dovecot name to reflect distribution in login greeting.
  - Update Drac plugin for >= 2.0.0 support.
* d/control: Drop dovecot-postfix package as its no longer required.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/*
2
 
 * HMAC-SHA1 (RFC-2104) implementation.
3
 
 *
4
 
 * Copyright (c) 2004 Andrey Panin <pazke@donpac.ru>
5
 
 * Copyright (c) 2011 Florian Zeitz <florob@babelmonkeys.de>
6
 
 *
7
 
 * This software is released under the MIT license.
8
 
 */
9
 
 
10
 
#include "lib.h"
11
 
#include "hmac-sha1.h"
12
 
#include "safe-memset.h"
13
 
 
14
 
void hmac_sha1_init(struct hmac_sha1_context *ctx,
15
 
                   const unsigned char *key, size_t key_len)
16
 
{
17
 
        int i;
18
 
        unsigned char sha1key[20];
19
 
        unsigned char k_ipad[64];
20
 
        unsigned char k_opad[64];
21
 
 
22
 
        if (key_len > 64) {
23
 
                sha1_get_digest(key, key_len, sha1key);
24
 
                key = sha1key;
25
 
                key_len = 20;
26
 
        }
27
 
 
28
 
        memcpy(k_ipad, key, key_len);
29
 
        memset(k_ipad + key_len, 0, 64 - key_len);
30
 
        memcpy(k_opad, k_ipad, 64);
31
 
 
32
 
        for (i = 0; i < 64; i++) {
33
 
                k_ipad[i] ^= 0x36;
34
 
                k_opad[i] ^= 0x5c;
35
 
        }
36
 
 
37
 
        sha1_init(&ctx->ctx);
38
 
        sha1_loop(&ctx->ctx, k_ipad, 64);
39
 
        sha1_init(&ctx->ctxo);
40
 
        sha1_loop(&ctx->ctxo, k_opad, 64);
41
 
 
42
 
        safe_memset(k_ipad, 0, 64);
43
 
        safe_memset(k_opad, 0, 64);
44
 
}
45
 
 
46
 
void hmac_sha1_final(struct hmac_sha1_context *ctx, unsigned char *digest)
47
 
{
48
 
        sha1_result(&ctx->ctx, digest);
49
 
 
50
 
        sha1_loop(&ctx->ctxo, digest, 20);
51
 
        sha1_result(&ctx->ctxo, digest);
52
 
}