2021-06-27 21:25:29 +00:00
|
|
|
/***
|
|
|
|
Copyright (C) 2021 J Reece Wilson (a/k/a "Reece"). All rights reserved.
|
|
|
|
|
|
|
|
File: Base32.cpp
|
|
|
|
Date: 2021-6-12
|
|
|
|
Author: Reece
|
|
|
|
***/
|
2021-09-30 14:57:41 +00:00
|
|
|
#include <Source/RuntimeInternal.hpp>
|
2021-06-27 21:25:29 +00:00
|
|
|
#include "Base32.hpp"
|
|
|
|
#include <tomcrypt.h>
|
|
|
|
|
|
|
|
namespace Aurora::Parse
|
|
|
|
{
|
2022-01-20 16:37:22 +00:00
|
|
|
AUKN_SYM bool Base32Decode(const AuString &in, AuByteBuffer &decoded)
|
2021-06-27 21:25:29 +00:00
|
|
|
{
|
2022-09-19 20:34:54 +00:00
|
|
|
int iRet;
|
2021-06-27 21:25:29 +00:00
|
|
|
unsigned long length = in.size();
|
2022-09-19 06:08:32 +00:00
|
|
|
|
|
|
|
auto writeView = decoded.GetOrAllocateLinearWriteable(length);
|
|
|
|
if (!writeView)
|
2021-06-27 21:25:29 +00:00
|
|
|
{
|
2022-03-30 14:18:56 +00:00
|
|
|
SysPushErrorMem();
|
2022-09-19 20:34:54 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
iRet = ::base32_decode(AuReinterpretCast<const char *>(decoded.writePtr),
|
|
|
|
(unsigned long)length,
|
|
|
|
AuReinterpretCast<unsigned char *>(&decoded[0]),
|
|
|
|
&length,
|
2022-10-04 12:25:56 +00:00
|
|
|
BASE32_RFC4648);
|
2022-09-19 20:34:54 +00:00
|
|
|
if (iRet != CRYPT_OK)
|
|
|
|
{
|
|
|
|
return false;
|
2021-06-27 21:25:29 +00:00
|
|
|
}
|
2022-03-30 14:18:56 +00:00
|
|
|
|
2022-09-19 06:08:32 +00:00
|
|
|
decoded.writePtr += length;
|
2022-09-19 20:34:54 +00:00
|
|
|
return true;
|
2021-06-27 21:25:29 +00:00
|
|
|
}
|
|
|
|
|
2022-09-29 07:58:20 +00:00
|
|
|
AUKN_SYM bool Base32Encode(const Memory::MemoryViewRead &input, AuString &encoded)
|
2021-06-27 21:25:29 +00:00
|
|
|
{
|
2022-09-29 07:58:20 +00:00
|
|
|
unsigned long outLength = ((input.length * 8 + 4) / 5) + 5;
|
2022-03-30 14:18:56 +00:00
|
|
|
|
2022-06-03 19:28:08 +00:00
|
|
|
if (!AuTryResize(encoded, outLength))
|
2021-06-27 21:25:29 +00:00
|
|
|
{
|
2022-03-30 14:18:56 +00:00
|
|
|
SysPushErrorMem();
|
2022-04-10 15:40:49 +00:00
|
|
|
return false;
|
2021-06-27 21:25:29 +00:00
|
|
|
}
|
2022-03-30 14:18:56 +00:00
|
|
|
|
2022-09-29 07:58:20 +00:00
|
|
|
auto iRet = ::base32_encode(AuReinterpretCast<const unsigned char *>(input.ptr),
|
|
|
|
(unsigned long)input.length,
|
2022-09-19 20:34:54 +00:00
|
|
|
&encoded[0],
|
|
|
|
&outLength,
|
|
|
|
BASE32_RFC4648);
|
|
|
|
|
|
|
|
if (!AuTryResize(encoded, outLength))
|
2021-06-27 21:25:29 +00:00
|
|
|
{
|
2022-03-30 14:18:56 +00:00
|
|
|
SysPushErrorMem();
|
2022-04-10 15:40:49 +00:00
|
|
|
return false;
|
2021-06-27 21:25:29 +00:00
|
|
|
}
|
2022-03-30 14:18:56 +00:00
|
|
|
|
2022-09-19 20:34:54 +00:00
|
|
|
return iRet == CRYPT_OK;
|
2021-06-27 21:25:29 +00:00
|
|
|
}
|
|
|
|
}
|