Kernel: Harden Socket::pseudo_path(..) implementations against OOM

Use the try variants of AK::StringBuilder append APIs to harden these
functions against OOM.
This commit is contained in:
Brian Gianforcaro 2022-01-09 00:59:12 -08:00 committed by Andreas Kling
parent ea66750640
commit ccbc3f8975
Notes: sideshowbarker 2024-07-17 21:20:58 +09:00
2 changed files with 13 additions and 13 deletions

View File

@ -474,24 +474,24 @@ ErrorOr<NonnullOwnPtr<KString>> IPv4Socket::pseudo_path(const OpenFileDescriptio
return KString::try_create("socket"sv); return KString::try_create("socket"sv);
StringBuilder builder; StringBuilder builder;
builder.append("socket:"); TRY(builder.try_append("socket:"));
builder.appendff("{}:{}", m_local_address.to_string(), m_local_port); TRY(builder.try_appendff("{}:{}", m_local_address.to_string(), m_local_port));
if (m_role == Role::Accepted || m_role == Role::Connected) if (m_role == Role::Accepted || m_role == Role::Connected)
builder.appendff(" / {}:{}", m_peer_address.to_string(), m_peer_port); TRY(builder.try_appendff(" / {}:{}", m_peer_address.to_string(), m_peer_port));
switch (m_role) { switch (m_role) {
case Role::Listener: case Role::Listener:
builder.append(" (listening)"); TRY(builder.try_append(" (listening)"));
break; break;
case Role::Accepted: case Role::Accepted:
builder.append(" (accepted)"); TRY(builder.try_append(" (accepted)"));
break; break;
case Role::Connected: case Role::Connected:
builder.append(" (connected)"); TRY(builder.try_append(" (connected)"));
break; break;
case Role::Connecting: case Role::Connecting:
builder.append(" (connecting)"); TRY(builder.try_append(" (connecting)"));
break; break;
default: default:
VERIFY_NOT_REACHED(); VERIFY_NOT_REACHED();

View File

@ -358,21 +358,21 @@ StringView LocalSocket::socket_path() const
ErrorOr<NonnullOwnPtr<KString>> LocalSocket::pseudo_path(const OpenFileDescription& description) const ErrorOr<NonnullOwnPtr<KString>> LocalSocket::pseudo_path(const OpenFileDescription& description) const
{ {
StringBuilder builder; StringBuilder builder;
builder.append("socket:"); TRY(builder.try_append("socket:"));
builder.append(socket_path()); TRY(builder.try_append(socket_path()));
switch (role(description)) { switch (role(description)) {
case Role::Listener: case Role::Listener:
builder.append(" (listening)"); TRY(builder.try_append(" (listening)"));
break; break;
case Role::Accepted: case Role::Accepted:
builder.appendff(" (accepted from pid {})", origin_pid()); TRY(builder.try_appendff(" (accepted from pid {})", origin_pid()));
break; break;
case Role::Connected: case Role::Connected:
builder.appendff(" (connected to pid {})", acceptor_pid()); TRY(builder.try_appendff(" (connected to pid {})", acceptor_pid()));
break; break;
case Role::Connecting: case Role::Connecting:
builder.append(" (connecting)"); TRY(builder.try_append(" (connecting)"));
break; break;
default: default:
break; break;