mirror of
https://github.com/pgbackrest/pgbackrest.git
synced 2025-01-06 03:53:59 +02:00
Do not expose valid/validate functions from encode module.
These functions have never been used externally. Validation is always part of decoding so performing validation separately would be wasteful.
This commit is contained in:
parent
edab2a0b89
commit
f6c3262861
@ -316,48 +316,3 @@ decodeToBinSize(EncodeType type, const char *source)
|
|||||||
|
|
||||||
FUNCTION_TEST_RETURN(destinationSize);
|
FUNCTION_TEST_RETURN(destinationSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**********************************************************************************************************************************/
|
|
||||||
bool
|
|
||||||
decodeToBinValid(EncodeType type, const char *source)
|
|
||||||
{
|
|
||||||
FUNCTION_TEST_BEGIN();
|
|
||||||
FUNCTION_TEST_PARAM(ENUM, type);
|
|
||||||
FUNCTION_TEST_PARAM(STRINGZ, source);
|
|
||||||
FUNCTION_TEST_END();
|
|
||||||
|
|
||||||
bool valid = true;
|
|
||||||
|
|
||||||
TRY_BEGIN()
|
|
||||||
{
|
|
||||||
decodeToBinValidate(type, source);
|
|
||||||
}
|
|
||||||
CATCH(FormatError)
|
|
||||||
{
|
|
||||||
valid = false;
|
|
||||||
}
|
|
||||||
TRY_END();
|
|
||||||
|
|
||||||
FUNCTION_TEST_RETURN(valid);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**********************************************************************************************************************************/
|
|
||||||
void
|
|
||||||
decodeToBinValidate(EncodeType type, const char *source)
|
|
||||||
{
|
|
||||||
FUNCTION_TEST_BEGIN();
|
|
||||||
FUNCTION_TEST_PARAM(ENUM, type);
|
|
||||||
FUNCTION_TEST_PARAM(STRINGZ, source);
|
|
||||||
FUNCTION_TEST_END();
|
|
||||||
|
|
||||||
ASSERT_ENCODE_TYPE_VALID(type);
|
|
||||||
|
|
||||||
switch (type)
|
|
||||||
{
|
|
||||||
case encodeBase64:
|
|
||||||
decodeToBinValidateBase64(source);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
FUNCTION_TEST_RETURN_VOID();
|
|
||||||
}
|
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
/***********************************************************************************************************************************
|
/***********************************************************************************************************************************
|
||||||
Binary to String Encode/Decode
|
Binary to String Encode/Decode
|
||||||
|
|
||||||
These high-level functions are preferred to the low-level functions for each encoding type in the encode subdirectory.
|
|
||||||
***********************************************************************************************************************************/
|
***********************************************************************************************************************************/
|
||||||
#ifndef COMMON_ENCODE_H
|
#ifndef COMMON_ENCODE_H
|
||||||
#define COMMON_ENCODE_H
|
#define COMMON_ENCODE_H
|
||||||
@ -13,7 +11,7 @@ Encoding types
|
|||||||
***********************************************************************************************************************************/
|
***********************************************************************************************************************************/
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
encodeBase64
|
encodeBase64,
|
||||||
} EncodeType;
|
} EncodeType;
|
||||||
|
|
||||||
/***********************************************************************************************************************************
|
/***********************************************************************************************************************************
|
||||||
@ -31,10 +29,4 @@ void decodeToBin(EncodeType type, const char *source, unsigned char *destination
|
|||||||
// Size of the binary data returned by decodeToBin()
|
// Size of the binary data returned by decodeToBin()
|
||||||
size_t decodeToBinSize(EncodeType type, const char *source);
|
size_t decodeToBinSize(EncodeType type, const char *source);
|
||||||
|
|
||||||
// Check that the encoded string is valid
|
|
||||||
bool decodeToBinValid(EncodeType type, const char *source);
|
|
||||||
|
|
||||||
// Validate the encoded string
|
|
||||||
void decodeToBinValidate(EncodeType type, const char *source);
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -89,15 +89,13 @@ testRun(void)
|
|||||||
decodeToBin(encodeBase64, "cc$=", destinationDecode), FormatError, "base64 invalid character found at position 2");
|
decodeToBin(encodeBase64, "cc$=", destinationDecode), FormatError, "base64 invalid character found at position 2");
|
||||||
|
|
||||||
// -------------------------------------------------------------------------------------------------------------------------
|
// -------------------------------------------------------------------------------------------------------------------------
|
||||||
TEST_ERROR(decodeToBinValidate(encodeBase64, "c3"), FormatError, "base64 size 2 is not evenly divisible by 4");
|
TEST_ERROR(decodeToBin(encodeBase64, "c3", destinationDecode), FormatError, "base64 size 2 is not evenly divisible by 4");
|
||||||
TEST_ERROR(
|
TEST_ERROR(
|
||||||
decodeToBinValidate(encodeBase64, "c==="), FormatError, "base64 '=' character may only appear in last two positions");
|
decodeToBin(encodeBase64, "c===", destinationDecode), FormatError,
|
||||||
|
"base64 '=' character may only appear in last two positions");
|
||||||
TEST_ERROR(
|
TEST_ERROR(
|
||||||
decodeToBinValidate(encodeBase64, "cc=c"), FormatError, "base64 last character must be '=' if second to last is");
|
decodeToBin(encodeBase64, "cc=c", destinationDecode), FormatError,
|
||||||
|
"base64 last character must be '=' if second to last is");
|
||||||
// -------------------------------------------------------------------------------------------------------------------------
|
|
||||||
TEST_RESULT_BOOL(decodeToBinValid(encodeBase64, "CCCCCCCCCCC"), false, "base64 string not valid");
|
|
||||||
TEST_RESULT_BOOL(decodeToBinValid(encodeBase64, "CCCCCCCCCCCC"), true, "base64 string valid");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
FUNCTION_HARNESS_RESULT_VOID();
|
FUNCTION_HARNESS_RESULT_VOID();
|
||||||
|
Loading…
Reference in New Issue
Block a user