mirror of
https://github.com/s3fs-fuse/s3fs-fuse.git
synced 2025-01-03 13:07:24 +00:00
Do not NUL terminate base64 decoded output (#1752)
This is binary data and must use the explicit length.
This commit is contained in:
parent
dac6885fb0
commit
cd98afdd7b
@ -438,7 +438,7 @@ unsigned char* s3fs_decode64(const char* input, size_t* plength)
|
|||||||
if(!input || 0 == strlen(input) || !plength){
|
if(!input || 0 == strlen(input) || !plength){
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
result = new unsigned char[strlen(input) / 4 * 3 + 1];
|
result = new unsigned char[strlen(input) / 4 * 3];
|
||||||
|
|
||||||
unsigned char parts[4];
|
unsigned char parts[4];
|
||||||
size_t input_len = strlen(input);
|
size_t input_len = strlen(input);
|
||||||
@ -460,7 +460,6 @@ unsigned char* s3fs_decode64(const char* input, size_t* plength)
|
|||||||
}
|
}
|
||||||
result[wpos++] = ((parts[2] << 6) & 0xc0) | (parts[3] & 0x3f);
|
result[wpos++] = ((parts[2] << 6) & 0xc0) | (parts[3] & 0x3f);
|
||||||
}
|
}
|
||||||
result[wpos] = '\0';
|
|
||||||
*plength = wpos;
|
*plength = wpos;
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -64,23 +64,35 @@ void test_trim()
|
|||||||
|
|
||||||
void test_base64()
|
void test_base64()
|
||||||
{
|
{
|
||||||
|
unsigned char *buf;
|
||||||
size_t len;
|
size_t len;
|
||||||
|
|
||||||
ASSERT_STREQUALS(s3fs_base64(NULL, 0), NULL);
|
ASSERT_STREQUALS(s3fs_base64(NULL, 0), NULL);
|
||||||
ASSERT_STREQUALS(reinterpret_cast<const char *>(s3fs_decode64(NULL, &len)), NULL);
|
buf = s3fs_decode64(NULL, &len);
|
||||||
|
ASSERT_BUFEQUALS(reinterpret_cast<const char *>(buf), len, NULL, 0);
|
||||||
|
|
||||||
ASSERT_STREQUALS(s3fs_base64(reinterpret_cast<const unsigned char *>(""), 0), NULL);
|
ASSERT_STREQUALS(s3fs_base64(reinterpret_cast<const unsigned char *>(""), 0), NULL);
|
||||||
ASSERT_STREQUALS(reinterpret_cast<const char *>(s3fs_decode64("", &len)), NULL);
|
buf = s3fs_decode64("", &len);
|
||||||
|
ASSERT_BUFEQUALS(reinterpret_cast<const char *>(buf), len, NULL, 0);
|
||||||
|
|
||||||
ASSERT_STREQUALS(s3fs_base64(reinterpret_cast<const unsigned char *>("1"), 1), "MQ==");
|
ASSERT_STREQUALS(s3fs_base64(reinterpret_cast<const unsigned char *>("1"), 1), "MQ==");
|
||||||
ASSERT_STREQUALS(reinterpret_cast<const char *>(s3fs_decode64("MQ==", &len)), "1");
|
buf = s3fs_decode64("MQ==", &len);
|
||||||
|
ASSERT_BUFEQUALS(reinterpret_cast<const char *>(buf), len, "1", 1);
|
||||||
ASSERT_EQUALS(len, static_cast<size_t>(1));
|
ASSERT_EQUALS(len, static_cast<size_t>(1));
|
||||||
|
|
||||||
ASSERT_STREQUALS(s3fs_base64(reinterpret_cast<const unsigned char *>("12"), 2), "MTI=");
|
ASSERT_STREQUALS(s3fs_base64(reinterpret_cast<const unsigned char *>("12"), 2), "MTI=");
|
||||||
ASSERT_STREQUALS(reinterpret_cast<const char *>(s3fs_decode64("MTI=", &len)), "12");
|
buf = s3fs_decode64("MTI=", &len);
|
||||||
|
ASSERT_BUFEQUALS(reinterpret_cast<const char *>(buf), len, "12", 2);
|
||||||
ASSERT_EQUALS(len, static_cast<size_t>(2));
|
ASSERT_EQUALS(len, static_cast<size_t>(2));
|
||||||
|
|
||||||
ASSERT_STREQUALS(s3fs_base64(reinterpret_cast<const unsigned char *>("123"), 3), "MTIz");
|
ASSERT_STREQUALS(s3fs_base64(reinterpret_cast<const unsigned char *>("123"), 3), "MTIz");
|
||||||
ASSERT_STREQUALS(reinterpret_cast<const char *>(s3fs_decode64("MTIz", &len)), "123");
|
buf = s3fs_decode64("MTIz", &len);
|
||||||
|
ASSERT_BUFEQUALS(reinterpret_cast<const char *>(buf), len, "123", 3);
|
||||||
ASSERT_EQUALS(len, static_cast<size_t>(3));
|
ASSERT_EQUALS(len, static_cast<size_t>(3));
|
||||||
|
|
||||||
ASSERT_STREQUALS(s3fs_base64(reinterpret_cast<const unsigned char *>("1234"), 4), "MTIzNA==");
|
ASSERT_STREQUALS(s3fs_base64(reinterpret_cast<const unsigned char *>("1234"), 4), "MTIzNA==");
|
||||||
ASSERT_STREQUALS(reinterpret_cast<const char *>(s3fs_decode64("MTIzNA==", &len)), "1234");
|
buf = s3fs_decode64("MTIzNA==", &len);
|
||||||
|
ASSERT_BUFEQUALS(reinterpret_cast<const char *>(buf), len, "1234", 4);
|
||||||
ASSERT_EQUALS(len, static_cast<size_t>(4));
|
ASSERT_EQUALS(len, static_cast<size_t>(4));
|
||||||
|
|
||||||
// TODO: invalid input
|
// TODO: invalid input
|
||||||
|
@ -76,11 +76,23 @@ void assert_strequals(const char *x, const char *y, const char *file, int line)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void assert_bufequals(const char *x, size_t len1, const char *y, size_t len2, const char *file, int line)
|
||||||
|
{
|
||||||
|
if(x == NULL && y == NULL){
|
||||||
|
return;
|
||||||
|
// cppcheck-suppress nullPointerRedundantCheck
|
||||||
|
} else if(x == NULL || y == NULL || len1 != len2 || memcmp(x, y, len1) != 0){
|
||||||
|
std::cerr << (x ? std::string(x, len1) : "null") << " != " << (y ? std::string(y, len2) : "null") << " at " << file << ":" << line << std::endl;
|
||||||
|
std::exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#define ASSERT_TRUE(x) assert_equals((x), true, __FILE__, __LINE__)
|
#define ASSERT_TRUE(x) assert_equals((x), true, __FILE__, __LINE__)
|
||||||
#define ASSERT_FALSE(x) assert_equals((x), false, __FILE__, __LINE__)
|
#define ASSERT_FALSE(x) assert_equals((x), false, __FILE__, __LINE__)
|
||||||
#define ASSERT_EQUALS(x, y) assert_equals((x), (y), __FILE__, __LINE__)
|
#define ASSERT_EQUALS(x, y) assert_equals((x), (y), __FILE__, __LINE__)
|
||||||
#define ASSERT_NEQUALS(x, y) assert_nequals((x), (y), __FILE__, __LINE__)
|
#define ASSERT_NEQUALS(x, y) assert_nequals((x), (y), __FILE__, __LINE__)
|
||||||
#define ASSERT_STREQUALS(x, y) assert_strequals((x), (y), __FILE__, __LINE__)
|
#define ASSERT_STREQUALS(x, y) assert_strequals((x), (y), __FILE__, __LINE__)
|
||||||
|
#define ASSERT_BUFEQUALS(x, len1, y, len2) assert_bufequals((x), (len1), (y), (len2), __FILE__, __LINE__)
|
||||||
|
|
||||||
#endif // S3FS_TEST_UTIL_H_
|
#endif // S3FS_TEST_UTIL_H_
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user