/* * Copyright (c) 2022, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include namespace Kernel { class Credentials final : public AtomicRefCounted { public: static ErrorOr> create(UserID uid, GroupID gid, UserID euid, GroupID egid, UserID suid, GroupID sgid, ReadonlySpan extra_gids, SessionID sid, ProcessGroupID pgid); ~Credentials(); bool is_superuser() const { return euid() == 0; } UserID euid() const { return m_euid; } GroupID egid() const { return m_egid; } UserID uid() const { return m_uid; } GroupID gid() const { return m_gid; } UserID suid() const { return m_suid; } GroupID sgid() const { return m_sgid; } ReadonlySpan extra_gids() const { return m_extra_gids.span(); } SessionID sid() const { return m_sid; }; ProcessGroupID pgid() const { return m_pgid; } bool in_group(GroupID) const; private: Credentials(UserID uid, GroupID gid, UserID euid, GroupID egid, UserID suid, GroupID sgid, FixedArray extra_gids, SessionID sid, ProcessGroupID pgid); UserID m_uid; GroupID m_gid; UserID m_euid; GroupID m_egid; UserID m_suid; GroupID m_sgid; FixedArray m_extra_gids; SessionID m_sid; ProcessGroupID m_pgid; }; }