/* vim: set expandtab ts=4 sw=4: */
/*
* You may redistribute this program and/or modify it under the terms of
* the GNU General Public License as published by the Free Software Foundation,
* either version 3 of the License, or (at your option) any later version.
*
* 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
#include "crypto_hash_sha512.h"
#include "util/Bits.h"
#include
int AddressCalc_addressForPublicKey(uint8_t addressOut[16], const uint8_t key[32])
{
uint8_t hash[crypto_hash_sha512_BYTES];
crypto_hash_sha512(hash, key, 32);
crypto_hash_sha512(hash, hash, crypto_hash_sha512_BYTES);
Bits_memcpyConst(addressOut, hash, 16);
return hash[0] == 0xFC;
}
int AddressCalc_validKey(const uint8_t key[32])
{
uint8_t hash[crypto_hash_sha512_BYTES];
crypto_hash_sha512(hash, key, 32);
crypto_hash_sha512(hash, hash, crypto_hash_sha512_BYTES);
return hash[0] == 0xFC;
}
int AddressCalc_validAddress(const uint8_t address[16])
{
return address[0] == 0xFC;
}