FFmpeg
Main Page
Related Pages
Modules
Namespaces
Data Structures
Files
Examples
File List
Globals
All
Data Structures
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Macros
Groups
Pages
libavutil
hmac.h
Go to the documentation of this file.
1
/*
2
* Copyright (C) 2012 Martin Storsjo
3
*
4
* This file is part of FFmpeg.
5
*
6
* FFmpeg is free software; you can redistribute it and/or
7
* modify it under the terms of the GNU Lesser General Public
8
* License as published by the Free Software Foundation; either
9
* version 2.1 of the License, or (at your option) any later version.
10
*
11
* FFmpeg is distributed in the hope that it will be useful,
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14
* Lesser General Public License for more details.
15
*
16
* You should have received a copy of the GNU Lesser General Public
17
* License along with FFmpeg; if not, write to the Free Software
18
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19
*/
20
21
#ifndef AVUTIL_HMAC_H
22
#define AVUTIL_HMAC_H
23
24
#include <stdint.h>
25
26
/**
27
* @defgroup lavu_hmac HMAC
28
* @ingroup lavu_crypto
29
* @{
30
*/
31
32
enum
AVHMACType
{
33
AV_HMAC_MD5
,
34
AV_HMAC_SHA1
,
35
AV_HMAC_SHA224
= 10,
36
AV_HMAC_SHA256
,
37
AV_HMAC_SHA384
,
38
AV_HMAC_SHA512
,
39
};
40
41
typedef
struct
AVHMAC
AVHMAC
;
42
43
/**
44
* Allocate an AVHMAC context.
45
* @param type The hash function used for the HMAC.
46
*/
47
AVHMAC
*
av_hmac_alloc
(
enum
AVHMACType
type
);
48
49
/**
50
* Free an AVHMAC context.
51
* @param ctx The context to free, may be NULL
52
*/
53
void
av_hmac_free
(
AVHMAC
*ctx);
54
55
/**
56
* Initialize an AVHMAC context with an authentication key.
57
* @param ctx The HMAC context
58
* @param key The authentication key
59
* @param keylen The length of the key, in bytes
60
*/
61
void
av_hmac_init
(
AVHMAC
*ctx,
const
uint8_t
*
key
,
unsigned
int
keylen
);
62
63
/**
64
* Hash data with the HMAC.
65
* @param ctx The HMAC context
66
* @param data The data to hash
67
* @param len The length of the data, in bytes
68
*/
69
void
av_hmac_update
(
AVHMAC
*ctx,
const
uint8_t
*
data
,
unsigned
int
len
);
70
71
/**
72
* Finish hashing and output the HMAC digest.
73
* @param ctx The HMAC context
74
* @param out The output buffer to write the digest into
75
* @param outlen The length of the out buffer, in bytes
76
* @return The number of bytes written to out, or a negative error code.
77
*/
78
int
av_hmac_final
(
AVHMAC
*ctx,
uint8_t
*
out
,
unsigned
int
outlen);
79
80
/**
81
* Hash an array of data with a key.
82
* @param ctx The HMAC context
83
* @param data The data to hash
84
* @param len The length of the data, in bytes
85
* @param key The authentication key
86
* @param keylen The length of the key, in bytes
87
* @param out The output buffer to write the digest into
88
* @param outlen The length of the out buffer, in bytes
89
* @return The number of bytes written to out, or a negative error code.
90
*/
91
int
av_hmac_calc
(
AVHMAC
*ctx,
const
uint8_t
*
data
,
unsigned
int
len
,
92
const
uint8_t
*
key
,
unsigned
int
keylen
,
93
uint8_t
*
out
,
unsigned
int
outlen);
94
95
/**
96
* @}
97
*/
98
99
#endif
/* AVUTIL_HMAC_H */
Generated on Fri Dec 5 2014 04:42:16 for FFmpeg by
1.8.2