// _____ _ // |_ _| |_ _ _ ___ ___ _ __ __ _ // | | | ' \| '_/ -_) -_) ' \/ _` |_ // |_| |_||_|_| \___\___|_|_|_\__,_(_) // // 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 . #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