Version v0.2.80 - Fixed compile warnings - increased buffer sizes and added length validation
This commit is contained in:
32
otp.c
32
otp.c
@@ -1619,7 +1619,6 @@ int decrypt_text_silent(const char* pad_identifier, const char* encrypted_messag
|
||||
// For piped decrypt mode - silent operation with minimal output
|
||||
(void)pad_identifier; // Suppress unused parameter warning
|
||||
|
||||
char line[MAX_LINE_LENGTH];
|
||||
char stored_chksum[MAX_HASH_LENGTH];
|
||||
char current_chksum[MAX_HASH_LENGTH];
|
||||
uint64_t pad_offset;
|
||||
@@ -2733,7 +2732,7 @@ int detect_otp_thumb_drive(char* otp_drive_path, size_t path_size) {
|
||||
while ((mount_entry = readdir(mount_dir)) != NULL) {
|
||||
if (mount_entry->d_name[0] == '.') continue;
|
||||
|
||||
char mount_path[512];
|
||||
char mount_path[1024]; // Increased buffer size
|
||||
snprintf(mount_path, sizeof(mount_path), "%s/%s", mount_dirs[mount_idx], mount_entry->d_name);
|
||||
|
||||
// For /media, we need to go one level deeper (user directories)
|
||||
@@ -2749,18 +2748,23 @@ int detect_otp_thumb_drive(char* otp_drive_path, size_t path_size) {
|
||||
// Check if drive name starts with "OTP"
|
||||
if (strncmp(user_entry->d_name, "OTP", 3) != 0) continue;
|
||||
|
||||
char user_mount_path[512];
|
||||
snprintf(user_mount_path, sizeof(user_mount_path), "%s/%s", mount_path, user_entry->d_name);
|
||||
char user_mount_path[1024]; // Increased buffer size
|
||||
// Verify buffer has enough space before concatenation
|
||||
size_t mount_len = strlen(mount_path);
|
||||
size_t entry_len = strlen(user_entry->d_name);
|
||||
if (mount_len + entry_len + 2 < sizeof(user_mount_path)) {
|
||||
snprintf(user_mount_path, sizeof(user_mount_path), "%s/%s", mount_path, user_entry->d_name);
|
||||
|
||||
// Check if this is a readable directory
|
||||
DIR* drive_dir = opendir(user_mount_path);
|
||||
if (drive_dir) {
|
||||
closedir(drive_dir);
|
||||
strncpy(otp_drive_path, user_mount_path, path_size - 1);
|
||||
otp_drive_path[path_size - 1] = '\0';
|
||||
closedir(user_dir);
|
||||
closedir(mount_dir);
|
||||
return 1; // Found OTP drive
|
||||
// Check if this is a readable directory
|
||||
DIR* drive_dir = opendir(user_mount_path);
|
||||
if (drive_dir) {
|
||||
closedir(drive_dir);
|
||||
strncpy(otp_drive_path, user_mount_path, path_size - 1);
|
||||
otp_drive_path[path_size - 1] = '\0';
|
||||
closedir(user_dir);
|
||||
closedir(mount_dir);
|
||||
return 1; // Found OTP drive
|
||||
}
|
||||
}
|
||||
}
|
||||
closedir(user_dir);
|
||||
@@ -3393,7 +3397,7 @@ int handle_pads_menu(void) {
|
||||
pads[pad_count].chksum[64] = '\0';
|
||||
|
||||
// Get pad file size and usage info
|
||||
char full_path[512];
|
||||
char full_path[1024]; // Increased buffer size
|
||||
snprintf(full_path, sizeof(full_path), "%s/%s", current_pads_dir, entry->d_name);
|
||||
struct stat st;
|
||||
if (stat(full_path, &st) == 0) {
|
||||
|
||||
Reference in New Issue
Block a user