C-6: ConnectorRuntime enforces capability_mask per operation.
READ-only ACs cannot invoke MUTATE operations (wipe, lock, retire).
C-7: AC validated against database (exists, active, not expired)
before connector invocation.
C-9: Delegated AC capability bounded by delegator's capability.
C-10: Command counter uses atomic SQL increment with limit check.
M-23: expire_stale() uses same atomic SQL pattern.
H-1: Sensitive credential fields hidden from repr/logs via repr=False.
H-2: Stub backend requires ALLOW_STUB_CREDENTIALS=true to activate.
H-3: Kerberos backend raises CredentialResolutionError instead of
returning stub ticket.
H-4: Chronicle INTENT emitted before execution, RESULT after.
H-5: device_id validated as UUID before Graph API URL interpolation.
H-8: ConnectorRuntime enforces governance for all connector invocations.
Signed-off-by: Tyler King <tking@guildhouse.dev>
72 lines
1.8 KiB
Cython
72 lines
1.8 KiB
Cython
@cython.no_gc_clear
|
|
cdef class UVIdle(UVHandle):
|
|
cdef _init(self, Loop loop, Handle h):
|
|
cdef int err
|
|
|
|
self._start_init(loop)
|
|
|
|
self._handle = <uv.uv_handle_t*>PyMem_RawMalloc(sizeof(uv.uv_idle_t))
|
|
if self._handle is NULL:
|
|
self._abort_init()
|
|
raise MemoryError()
|
|
|
|
err = uv.uv_idle_init(self._loop.uvloop, <uv.uv_idle_t*>self._handle)
|
|
if err < 0:
|
|
self._abort_init()
|
|
raise convert_error(err)
|
|
|
|
self._finish_init()
|
|
|
|
self.h = h
|
|
self.running = 0
|
|
|
|
cdef inline stop(self):
|
|
cdef int err
|
|
|
|
if not self._is_alive():
|
|
self.running = 0
|
|
return
|
|
|
|
if self.running == 1:
|
|
err = uv.uv_idle_stop(<uv.uv_idle_t*>self._handle)
|
|
self.running = 0
|
|
if err < 0:
|
|
exc = convert_error(err)
|
|
self._fatal_error(exc, True)
|
|
return
|
|
|
|
cdef inline start(self):
|
|
cdef int err
|
|
|
|
self._ensure_alive()
|
|
|
|
if self.running == 0:
|
|
err = uv.uv_idle_start(<uv.uv_idle_t*>self._handle,
|
|
cb_idle_callback)
|
|
if err < 0:
|
|
exc = convert_error(err)
|
|
self._fatal_error(exc, True)
|
|
return
|
|
self.running = 1
|
|
|
|
@staticmethod
|
|
cdef UVIdle new(Loop loop, Handle h):
|
|
cdef UVIdle handle
|
|
handle = UVIdle.__new__(UVIdle)
|
|
handle._init(loop, h)
|
|
return handle
|
|
|
|
|
|
cdef void cb_idle_callback(
|
|
uv.uv_idle_t* handle,
|
|
) noexcept with gil:
|
|
if __ensure_handle_data(<uv.uv_handle_t*>handle, "UVIdle callback") == 0:
|
|
return
|
|
|
|
cdef:
|
|
UVIdle idle = <UVIdle> handle.data
|
|
Handle h = idle.h
|
|
try:
|
|
h._run()
|
|
except BaseException as ex:
|
|
idle._error(ex, False)
|