21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
#import "OFHashAlreadyCalculatedException.h"
#import "OFInvalidArgumentException.h"
@implementation OFHMAC
@synthesize hashClass = _hashClass;
@synthesize allowsSwappableMemory = _allowsSwappableMemory;
+ (instancetype)HMACWithHashClass: (Class <OFCryptoHash>)class
allowsSwappableMemory: (bool)allowsSwappableMemory
{
return [[[self alloc] initWithHashClass: class
allowsSwappableMemory: allowsSwappableMemory]
autorelease];
}
- (instancetype)init
{
OF_INVALID_INIT_METHOD
}
- (instancetype)initWithHashClass: (Class <OFCryptoHash>)class
allowsSwappableMemory: (bool)allowsSwappableMemory
{
self = [super init];
_hashClass = class;
_allowsSwappableMemory = allowsSwappableMemory;
|
|
|
|
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
#import "OFHashAlreadyCalculatedException.h"
#import "OFInvalidArgumentException.h"
@implementation OFHMAC
@synthesize hashClass = _hashClass;
@synthesize allowsSwappableMemory = _allowsSwappableMemory;
+ (instancetype)HMACWithHashClass: (Class <OFCryptographicHash>)class
allowsSwappableMemory: (bool)allowsSwappableMemory
{
return [[[self alloc] initWithHashClass: class
allowsSwappableMemory: allowsSwappableMemory]
autorelease];
}
- (instancetype)init
{
OF_INVALID_INIT_METHOD
}
- (instancetype)initWithHashClass: (Class <OFCryptographicHash>)class
allowsSwappableMemory: (bool)allowsSwappableMemory
{
self = [super init];
_hashClass = class;
_allowsSwappableMemory = allowsSwappableMemory;
|
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
[_innerHash release];
[_outerHashCopy release];
[_innerHashCopy release];
_outerHash = _innerHash = _outerHashCopy = _innerHashCopy = nil;
@try {
if (length > blockSize) {
id <OFCryptoHash> hash = [_hashClass
cryptoHashWithAllowsSwappableMemory:
_allowsSwappableMemory];
[hash updateWithBuffer: key length: length];
length = hash.digestSize;
if OF_UNLIKELY (length > blockSize)
length = blockSize;
|
|
|
|
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
[_innerHash release];
[_outerHashCopy release];
[_innerHashCopy release];
_outerHash = _innerHash = _outerHashCopy = _innerHashCopy = nil;
@try {
if (length > blockSize) {
id <OFCryptographicHash> hash = [_hashClass
hashWithAllowsSwappableMemory:
_allowsSwappableMemory];
[hash updateWithBuffer: key length: length];
length = hash.digestSize;
if OF_UNLIKELY (length > blockSize)
length = blockSize;
|
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
|
memset(innerKeyPadItems + length, 0, blockSize - length);
for (size_t i = 0; i < blockSize; i++) {
outerKeyPadItems[i] ^= 0x5C;
innerKeyPadItems[i] ^= 0x36;
}
_outerHash = [[_hashClass cryptoHashWithAllowsSwappableMemory:
_allowsSwappableMemory] retain];
_innerHash = [[_hashClass cryptoHashWithAllowsSwappableMemory:
_allowsSwappableMemory] retain];
[_outerHash updateWithBuffer: outerKeyPadItems
length: blockSize];
[_innerHash updateWithBuffer: innerKeyPadItems
length: blockSize];
} @catch (id e) {
|
|
|
|
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
|
memset(innerKeyPadItems + length, 0, blockSize - length);
for (size_t i = 0; i < blockSize; i++) {
outerKeyPadItems[i] ^= 0x5C;
innerKeyPadItems[i] ^= 0x36;
}
_outerHash = [[_hashClass hashWithAllowsSwappableMemory:
_allowsSwappableMemory] retain];
_innerHash = [[_hashClass hashWithAllowsSwappableMemory:
_allowsSwappableMemory] retain];
[_outerHash updateWithBuffer: outerKeyPadItems
length: blockSize];
[_innerHash updateWithBuffer: innerKeyPadItems
length: blockSize];
} @catch (id e) {
|