1234567891011121314151617181920212223242526272829303132333435363738 |
- // _____ _
- // |_ _| |_ _ _ ___ ___ _ __ __ _
- // | | | ' \| '_/ -_) -_) ' \/ _` |_
- // |_| |_||_|_| \___\___|_|_|_\__,_(_)
- //
- // Threema iOS Client
- // Copyright (c) 2020 Threema GmbH
- //
- // This program is free software: you can redistribute it and/or modify
- // it under the terms of the GNU Affero General Public License, version 3,
- // as published by the Free Software Foundation.
- //
- // This program is distributed in the hope that it will be useful,
- // but WITHOUT ANY WARRANTY; without even the implied warranty of
- // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- // GNU Affero General Public License for more details.
- //
- // You should have received a copy of the GNU Affero General Public License
- // along with this program. If not, see <https://www.gnu.org/licenses/>.
- #import "NonceHasher.h"
- #import "MyIdentityStore.h"
- #import "CryptoUtils.h"
- @implementation NonceHasher
- + (NSData*)hashedNonce:(NSData*)nonce {
- /* Hash nonce with HMAC-SHA256 using the identity as the key if available.
- This serves to make it impossible to correlate the nonce DBs of users to determine whether they have been communicating. */
- NSData *identity = [[[MyIdentityStore sharedMyIdentityStore] identity] dataUsingEncoding:NSASCIIStringEncoding];
- if (identity == nil) {
- return nonce;
- } else {
- return [CryptoUtils hmacSha256ForData:nonce key:identity];
- }
- }
- @end
|