mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-25 10:22:33 +00:00 
			
		
		
		
	 45cf40653a
			
		
	
	
		45cf40653a
		
	
	
	
	
		
			
			Apologies for the enormous commit, but I don't see a way to split this up nicely. In the vast majority of cases it's a simple change. A few extra places can use TRY instead of manual error checking though. :^)
		
			
				
	
	
		
			50 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2021, Brian Gianforcaro <bgianf@serenityos.org>
 | |
|  * Copyright (c) 2021, Mustafa Quraish <mustafa@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <AK/Memory.h>
 | |
| #include <LibCore/SecretString.h>
 | |
| 
 | |
| namespace Core {
 | |
| 
 | |
| SecretString SecretString::take_ownership(char*& cstring, size_t length)
 | |
| {
 | |
|     auto buffer = ByteBuffer::copy(cstring, length).release_value_but_fixme_should_propagate_errors();
 | |
| 
 | |
|     secure_zero(cstring, length);
 | |
|     free(cstring);
 | |
|     cstring = nullptr;
 | |
| 
 | |
|     return SecretString(move(buffer));
 | |
| }
 | |
| 
 | |
| SecretString SecretString::take_ownership(ByteBuffer&& buffer)
 | |
| {
 | |
|     return SecretString(move(buffer));
 | |
| }
 | |
| 
 | |
| SecretString::SecretString(ByteBuffer&& buffer)
 | |
|     : m_secure_buffer(move(buffer))
 | |
| {
 | |
|     // SecretString is currently only used to provide the character data to invocations to crypt(),
 | |
|     // which requires a NUL-terminated string. To ensure this operation avoids a buffer overrun,
 | |
|     // append a NUL terminator here if there isn't already one.
 | |
|     if (m_secure_buffer.is_empty() || (m_secure_buffer[m_secure_buffer.size() - 1] != 0)) {
 | |
|         u8 nul = '\0';
 | |
|         m_secure_buffer.append(&nul, 1);
 | |
|     }
 | |
| }
 | |
| 
 | |
| SecretString::~SecretString()
 | |
| {
 | |
|     // Note: We use secure_zero to avoid the zeroing from being optimized out by the compiler,
 | |
|     // which is possible if memset was to be used here.
 | |
|     if (!m_secure_buffer.is_empty()) {
 | |
|         secure_zero(m_secure_buffer.data(), m_secure_buffer.capacity());
 | |
|     }
 | |
| }
 | |
| 
 | |
| }
 |