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>
60 lines
1.6 KiB
Python
60 lines
1.6 KiB
Python
# Copyright 2011 Sybren A. Stüvel <sybren@stuvel.eu>
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# https://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
"""RSA module
|
|
|
|
Module for calculating large primes, and RSA encryption, decryption, signing
|
|
and verification. Includes generating public and private keys.
|
|
|
|
WARNING: this implementation does not use compression of the cleartext input to
|
|
prevent repetitions, or other common security improvements. Use with care.
|
|
|
|
"""
|
|
|
|
from rsa.key import newkeys, PrivateKey, PublicKey
|
|
from rsa.pkcs1 import (
|
|
encrypt,
|
|
decrypt,
|
|
sign,
|
|
verify,
|
|
DecryptionError,
|
|
VerificationError,
|
|
find_signature_hash,
|
|
sign_hash,
|
|
compute_hash,
|
|
)
|
|
|
|
__author__ = "Sybren Stuvel, Barry Mead and Yesudeep Mangalapilly"
|
|
__date__ = "2025-04-16"
|
|
__version__ = "4.9.1"
|
|
|
|
# Do doctest if we're run directly
|
|
if __name__ == "__main__":
|
|
import doctest
|
|
|
|
doctest.testmod()
|
|
|
|
__all__ = [
|
|
"newkeys",
|
|
"encrypt",
|
|
"decrypt",
|
|
"sign",
|
|
"verify",
|
|
"PublicKey",
|
|
"PrivateKey",
|
|
"DecryptionError",
|
|
"VerificationError",
|
|
"find_signature_hash",
|
|
"compute_hash",
|
|
"sign_hash",
|
|
]
|