Merge remote-tracking branch 'Screwtapello/cleanup-session-name-validation'

This commit is contained in:
Maxime Coste 2022-04-11 19:50:54 +10:00
commit 0ddad3c030

View File

@ -605,8 +605,8 @@ const String& session_directory()
String session_path(StringView session) String session_path(StringView session)
{ {
if (contains(session, '/')) if (not all_of(session, is_identifier))
throw runtime_error{"session names cannot have slashes"}; throw runtime_error{format("invalid session name: '{}'", session)};
return format("{}/{}", session_directory(), session); return format("{}/{}", session_directory(), session);
} }
@ -614,7 +614,10 @@ static sockaddr_un session_addr(StringView session)
{ {
sockaddr_un addr; sockaddr_un addr;
addr.sun_family = AF_UNIX; addr.sun_family = AF_UNIX;
strcpy(addr.sun_path, session_path(session).c_str()); String path = session_path(session);
if (path.length() + 1 > sizeof addr.sun_path)
throw runtime_error{format("socket path too long: '{}'", path)};
strcpy(addr.sun_path, path.c_str());
return addr; return addr;
} }
@ -848,9 +851,6 @@ private:
Server::Server(String session_name, bool is_daemon) Server::Server(String session_name, bool is_daemon)
: m_session{std::move(session_name)}, m_is_daemon{is_daemon} : m_session{std::move(session_name)}, m_is_daemon{is_daemon}
{ {
if (not all_of(m_session, is_identifier))
throw runtime_error{format("invalid session name: '{}'", m_session)};
int listen_sock = socket(AF_UNIX, SOCK_STREAM, 0); int listen_sock = socket(AF_UNIX, SOCK_STREAM, 0);
fcntl(listen_sock, F_SETFD, FD_CLOEXEC); fcntl(listen_sock, F_SETFD, FD_CLOEXEC);
sockaddr_un addr = session_addr(m_session); sockaddr_un addr = session_addr(m_session);
@ -885,9 +885,6 @@ Server::Server(String session_name, bool is_daemon)
bool Server::rename_session(StringView name) bool Server::rename_session(StringView name)
{ {
if (not all_of(name, is_identifier))
throw runtime_error{format("invalid session name: '{}'", name)};
String old_socket_file = session_path(m_session); String old_socket_file = session_path(m_session);
String new_socket_file = session_path(name); String new_socket_file = session_path(name);