security_opts.py 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. from typing import TYPE_CHECKING
  2. if TYPE_CHECKING:
  3. from render import Render
  4. try:
  5. from .error import RenderError
  6. from .validations import valid_security_opt_or_raise
  7. except ImportError:
  8. from error import RenderError
  9. from validations import valid_security_opt_or_raise
  10. class SecurityOpt:
  11. def __init__(self, opt: str, value: str | bool | None = None, arg: str | None = None):
  12. self._opt: str = valid_security_opt_or_raise(opt)
  13. self._value = str(value).lower() if isinstance(value, bool) else value
  14. self._arg: str | None = arg
  15. def render(self):
  16. result = self._opt
  17. if self._value is not None:
  18. result = f"{result}={self._value}"
  19. if self._arg is not None:
  20. result = f"{result}:{self._arg}"
  21. return result
  22. class SecurityOpts:
  23. def __init__(self, render_instance: "Render"):
  24. self._render_instance = render_instance
  25. self._opts: dict[str, SecurityOpt] = dict()
  26. self.add_opt("no-new-privileges", True)
  27. def add_opt(self, key: str, value: str | bool | None, arg: str | None = None):
  28. if key in self._opts:
  29. raise RenderError(f"Security Option [{key}] already added")
  30. self._opts[key] = SecurityOpt(key, value, arg)
  31. def remove_opt(self, key: str):
  32. if key not in self._opts:
  33. raise RenderError(f"Security Option [{key}] not found")
  34. del self._opts[key]
  35. def has_opts(self):
  36. return len(self._opts) > 0
  37. def render(self):
  38. result = []
  39. for opt in sorted(self._opts.values(), key=lambda o: o._opt):
  40. result.append(opt.render())
  41. return result