gRPC client for Aserto Authorizer service instances
Project description
Aserto Authorizer gRPC client
This is an automatically generated client for interacting with Aserto's Authorizer service using the gRPC protocol.
Installation
Using Pip
pip install aserto-authorizer-grpc
Using Poetry
poetry add aserto-authorizer-grpc
Usage
from aserto_authorizer_grpc.aserto.api.v1 import (
IdentityContext,
IdentityType,
PolicyContext,
)
from aserto_authorizer_grpc.aserto.authorizer.authorizer.v1 import (
AuthorizerStub,
DecisionTreeOptions,
DecisionTreeResponse,
PathSeparator,
Proto,
)
from grpclib.client import Channel
async with Channel(host=host, port=port, ssl=True) as channel:
headers = {
"aserto-tenant-id": TENANT_ID,
"authorization": f"basic {ASERTO_API_KEY}"
}
client = AuthorizerStub(channel, metadata=headers)
response = await client.decision_tree(
policy_context=PolicyContext(
id=ASERTO_POLICY_ID,
path=ASERTO_POLICY_PATH_ROOT,
decisions=["visible", "enabled", "allowed"],
),
identity_context=IdentityContext(type=IdentityType.IDENTITY_TYPE_NONE),
resource_context=Proto.Struct().from_dict(value={})),
options=DecisionTreeOptions(
path_separator=PathSeparator.PATH_SEPARATOR_DOT,
),
)
assert response == DecisionTreeResponse(
path_root=ASERTO_POLICY_PATH_ROOT,
path=Proto.Struct(
fields={
"GET.your.policy.path": Proto.Value(
struct_value=Proto.Struct(
fields={
"visible": Proto.Value(bool_value=True),
"enabled": Proto.Value(bool_value=True),
"allowed": Proto.Value(bool_value=False),
},
),
),
},
),
)
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.