/* 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 "util/Bits.h"
#include "util/Endian.h"
#include "crypto/AddressCalc.h"
#include "rust/cjdns_sys/Rffi.h"
#include
#include
/* These two constants are in big endian so they can be compared
* immediately with a uint8_t[] containing an address.
*/
#define ADDRESS_PREFIX_U64 (Endian_hostToBigEndian64( \
((uint64_t) AddressCalc_ADDRESS_PREFIX) << (64 - AddressCalc_ADDRESS_PREFIX_BITS)))
#define ADDRESS_PREFIX_MASK (Endian_hostToBigEndian64( \
UINT64_MAX << (64 - AddressCalc_ADDRESS_PREFIX_BITS)))
bool AddressCalc_validAddress(const uint8_t address[16])
{
uint64_t significant_bits;
Bits_memcpy (&significant_bits, address, sizeof(uint64_t));
return (significant_bits & ADDRESS_PREFIX_MASK) == ADDRESS_PREFIX_U64;
}
void AddressCalc_makeValidAddress(uint8_t address[16])
{
uint64_t significant_bits;
Bits_memcpy (&significant_bits, address, sizeof(uint64_t));
significant_bits &= ~ADDRESS_PREFIX_MASK; // zero out the prefix
significant_bits |= ADDRESS_PREFIX_U64; // put the new prefix
Bits_memcpy (address, &significant_bits, sizeof(uint64_t));
}
bool AddressCalc_addressForPublicKey(uint8_t addressOut[16], const uint8_t key[32])
{
uint8_t hash[64];
Rffi_crypto_hash_sha512(hash, key, 32);
Rffi_crypto_hash_sha512(hash, hash, sizeof hash);
if (addressOut) {
Bits_memcpy(addressOut, hash, 16);
}
return AddressCalc_validAddress(addressOut);
}