Security.h 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. /* vim: set expandtab ts=4 sw=4: */
  2. /*
  3. * You may redistribute this program and/or modify it under the terms of
  4. * the GNU General Public License as published by the Free Software Foundation,
  5. * either version 3 of the License, or (at your option) any later version.
  6. *
  7. * This program is distributed in the hope that it will be useful,
  8. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. * GNU General Public License for more details.
  11. *
  12. * You should have received a copy of the GNU General Public License
  13. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  14. */
  15. #ifndef Security_H
  16. #define Security_H
  17. #include "memory/Allocator.h"
  18. #include "exception/Except.h"
  19. #include "util/log/Log.h"
  20. #include "util/Linker.h"
  21. #ifdef win32
  22. Linker_require("util/Security_Windows.c")
  23. #else
  24. Linker_require("util/Security.c")
  25. #endif
  26. #include <stdint.h>
  27. struct Security_Permissions
  28. {
  29. int noOpenFiles;
  30. int seccompExists;
  31. int seccompEnforcing;
  32. uint64_t memoryLimitBytes;
  33. };
  34. /** @return Security_setUser_PERMISSION if the user does not have sufficient permissions. */
  35. #define Security_setUser_PERMISSION -1
  36. int Security_setUser(char* userName, struct Log* logger, struct Except* eh);
  37. void Security_dropPermissions(struct Allocator* tempAlloc, struct Log* logger, struct Except* eh);
  38. struct Security_Permissions* Security_checkPermissions(struct Allocator* alloc, struct Except* eh);
  39. #endif