Class swarmauri_middleware_auth.AuthMiddleware.AuthMiddleware
swarmauri_middleware_auth.AuthMiddleware.AuthMiddleware
AuthMiddleware(
secret_key,
algorithm="HS256",
verify_exp=True,
verify_aud=False,
audience=None,
issuer=None,
**kwargs,
)
Bases: MiddlewareBase
, ComponentBase
Middleware for handling JWT authentication.
This middleware validates JWT tokens in incoming requests and ensures they are properly signed and not expired before allowing the request to proceed through the application stack.
ATTRIBUTE | DESCRIPTION |
---|---|
secret_key |
Secret key used to verify JWT tokens
|
algorithm |
Algorithm used for JWT verification (default: HS256)
|
verify_exp |
Whether to verify token expiration (default: True)
|
verify_aud |
Whether to verify audience claim (default: False)
|
audience |
Expected audience for token verification
|
issuer |
Expected issuer for token verification
|
Initialize the AuthMiddleware with JWT configuration.
PARAMETER | DESCRIPTION |
---|---|
secret_key
|
Secret key used to verify JWT tokens
TYPE:
|
algorithm
|
Algorithm used for JWT verification
TYPE:
|
verify_exp
|
Whether to verify token expiration
TYPE:
|
verify_aud
|
Whether to verify audience claim
TYPE:
|
audience
|
Expected audience for token verification
TYPE:
|
issuer
|
Expected issuer for token verification
TYPE:
|
Source code in swarmauri_middleware_auth/AuthMiddleware.py
43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 |
|
secret_key
instance-attribute
secret_key = secret_key
algorithm
instance-attribute
algorithm = algorithm
verify_exp
instance-attribute
verify_exp = verify_exp
verify_aud
instance-attribute
verify_aud = verify_aud
audience
instance-attribute
audience = audience
issuer
instance-attribute
issuer = issuer
type
class-attribute
instance-attribute
type = 'ComponentBase'
model_config
class-attribute
instance-attribute
model_config = ConfigDict(
extra="allow", arbitrary_types_allowed=True
)
id
class-attribute
instance-attribute
id = Field(default_factory=generate_id)
members
class-attribute
instance-attribute
members = None
owners
class-attribute
instance-attribute
owners = None
host
class-attribute
instance-attribute
host = None
default_logger
class-attribute
default_logger = None
logger
class-attribute
instance-attribute
logger = None
name
class-attribute
instance-attribute
name = None
version
class-attribute
instance-attribute
version = '0.1.0'
app
property
app
dispatch
async
dispatch(request, call_next)
Dispatches the request after JWT authentication.
This method extracts and validates JWT tokens from the Authorization header. It checks for proper format, signature, expiration, and other claims as configured.
PARAMETER | DESCRIPTION |
---|---|
request
|
The incoming request object to be processed.
TYPE:
|
call_next
|
A callable that invokes the next middleware in the chain.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
Any
|
The response object after all middlewares have processed the request. |
RAISES | DESCRIPTION |
---|---|
HTTPException
|
If authentication fails for any reason. |
Source code in swarmauri_middleware_auth/AuthMiddleware.py
72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 |
|
verify_token_manually
verify_token_manually(token)
Manually verify a token without raising exceptions.
This is a utility method that can be used for token verification outside of the middleware context.
PARAMETER | DESCRIPTION |
---|---|
token
|
The JWT token string to verify
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
Optional[Dict[str, Any]]
|
Dict containing the decoded payload if valid, None if invalid |
Source code in swarmauri_middleware_auth/AuthMiddleware.py
183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 |
|
register_model
classmethod
register_model()
Decorator to register a base model in the unified registry.
RETURNS | DESCRIPTION |
---|---|
Callable
|
A decorator function that registers the model class.
TYPE:
|
Source code in swarmauri_base/DynamicBase.py
562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 |
|
register_type
classmethod
register_type(resource_type=None, type_name=None)
Decorator to register a subtype under one or more base models in the unified registry.
PARAMETER | DESCRIPTION |
---|---|
resource_type
|
The base model(s) under which to register the subtype. If None, all direct base classes (except DynamicBase) are used.
TYPE:
|
type_name
|
An optional custom type name for the subtype.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
Callable
|
A decorator function that registers the subtype.
TYPE:
|
Source code in swarmauri_base/DynamicBase.py
587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 |
|
model_validate_toml
classmethod
model_validate_toml(toml_data)
Validate a model from a TOML string.
Source code in swarmauri_base/TomlMixin.py
12 13 14 15 16 17 18 19 20 21 22 23 24 |
|
model_dump_toml
model_dump_toml(
fields_to_exclude=None, api_key_placeholder=None
)
Return a TOML representation of the model.
Source code in swarmauri_base/TomlMixin.py
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
|
model_validate_yaml
classmethod
model_validate_yaml(yaml_data)
Validate a model from a YAML string.
Source code in swarmauri_base/YamlMixin.py
11 12 13 14 15 16 17 18 19 20 21 22 23 |
|
model_dump_yaml
model_dump_yaml(
fields_to_exclude=None, api_key_placeholder=None
)
Return a YAML representation of the model.
Source code in swarmauri_base/YamlMixin.py
25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 |
|
model_post_init
model_post_init(logger=None)
Assign a logger instance after model initialization.
Source code in swarmauri_base/LoggerMixin.py
23 24 25 26 27 28 |
|
on_scope
async
on_scope(scope)
Hook executed when the middleware receives a scope.
Source code in swarmauri_base/middlewares/MiddlewareBase.py
52 53 54 55 |
|
on_receive
async
on_receive(scope, message)
Hook executed for every message received from the client.
Source code in swarmauri_base/middlewares/MiddlewareBase.py
57 58 59 60 |
|
on_send
async
on_send(scope, message)
Hook executed before messages are sent to the client.
Source code in swarmauri_base/middlewares/MiddlewareBase.py
62 63 64 65 |
|
bind
bind(app)
Bind the downstream ASGI application to the middleware.
Source code in swarmauri_base/middlewares/MiddlewareBase.py
36 37 38 39 |
|
call_next
async
call_next(scope, receive, send)
Invoke the next ASGI application in the chain.
Source code in swarmauri_base/middlewares/MiddlewareBase.py
45 46 47 48 49 50 |
|