diff --git a/authzed/api/v1/experimental_service.proto b/authzed/api/v1/experimental_service.proto index efa6b32..d24e1c8 100644 --- a/authzed/api/v1/experimental_service.proto +++ b/authzed/api/v1/experimental_service.proto @@ -45,12 +45,12 @@ service ExperimentalService { } rpc BulkCheckPermission(BulkCheckPermissionRequest) - returns (BulkCheckPermissionResponse) { - option (google.api.http) = { - post: "/v1/experimental/permissions/bulkcheckpermission" - body: "*" - }; - } + returns (BulkCheckPermissionResponse) { + option (google.api.http) = { + post: "/v1/experimental/permissions/bulkcheckpermission" + body: "*" + }; + } } message BulkCheckPermissionRequest { @@ -87,7 +87,6 @@ message BulkCheckPermissionPair { } message BulkCheckPermissionResponseItem { - CheckPermissionResponse.Permissionship permissionship = 1 [ (validate.rules).enum = {defined_only: true, not_in: [0]} ]; PartialCaveatInfo partial_caveat_info = 2 [ (validate.rules).message.required = false ]; diff --git a/authzed/api/v1/permission_service.proto b/authzed/api/v1/permission_service.proto index e28b73e..fb13727 100644 --- a/authzed/api/v1/permission_service.proto +++ b/authzed/api/v1/permission_service.proto @@ -6,6 +6,7 @@ option java_package = "com.authzed.api.v1"; import "google/protobuf/struct.proto"; import "google/api/annotations.proto"; +import "google/rpc/status.proto"; import "validate/validate.proto"; import "authzed/api/v1/core.proto"; @@ -56,6 +57,16 @@ service PermissionsService { }; } + // CheckPermissionsBulk evaluates the given list of permission checks + // and returns the list of results. + rpc CheckPermissionsBulk(CheckPermissionsBulkRequest) + returns (CheckPermissionsBulkResponse) { + option (google.api.http) = { + post: "/v1/permissions/checkpermissionsbulk" + body: "*" + }; + } + // ExpandPermissionTree reveals the graph structure for a resource's // permission or relation. This RPC does not recurse infinitely deep and may // require multiple calls to fully unnest a deeply nested graph. @@ -349,6 +360,46 @@ message CheckPermissionResponse { PartialCaveatInfo partial_caveat_info = 3 [ (validate.rules).message.required = false ]; } + +message CheckPermissionsBulkRequest { + Consistency consistency = 1; + + repeated CheckPermissionsBulkRequestItem items = 2 [ (validate.rules).repeated .items.message.required = true ]; +} + +message CheckPermissionsBulkRequestItem { + ObjectReference resource = 1 [ (validate.rules).message.required = true ]; + + string permission = 2 [ (validate.rules).string = { + pattern : "^([a-z][a-z0-9_]{1,62}[a-z0-9])?$", + max_bytes : 64, + } ]; + + SubjectReference subject = 3 [ (validate.rules).message.required = true ]; + + google.protobuf.Struct context = 4 [ (validate.rules).message.required = false ]; +} + +message CheckPermissionsBulkResponse { + ZedToken checked_at = 1 [ (validate.rules).message.required = false ]; + + repeated CheckPermissionsBulkPair pairs = 2 [ (validate.rules).repeated .items.message.required = true ]; +} + +message CheckPermissionsBulkPair { + CheckPermissionsBulkRequestItem request = 1; + oneof response { + CheckPermissionsBulkResponseItem item = 2; + google.rpc.Status error = 3; + } +} + +message CheckPermissionsBulkResponseItem { + CheckPermissionResponse.Permissionship permissionship = 1 [ (validate.rules).enum = {defined_only: true, not_in: [0]} ]; + + PartialCaveatInfo partial_caveat_info = 2 [ (validate.rules).message.required = false ]; +} + // ExpandPermissionTreeRequest returns a tree representing the expansion of all // relationships found accessible from a permission or relation on a particular // resource.