Skip to content

Commit

Permalink
Add experimental relationship count API
Browse files Browse the repository at this point in the history
This will eventually be backed by a counting/stats service, but for now will call count(*)
  • Loading branch information
josephschorr committed May 9, 2024
1 parent 80f6ef8 commit 5d85ef7
Show file tree
Hide file tree
Showing 2 changed files with 86 additions and 1 deletion.
22 changes: 22 additions & 0 deletions authzed/api/v1/error_reason.proto
Original file line number Diff line number Diff line change
Expand Up @@ -364,4 +364,26 @@ enum ErrorReason {
// "metadata": {}
// }
ERROR_REASON_EMPTY_PRECONDITION = 25;

// The request failed because the filter was already registered.
//
// Example of an ErrorInfo:
//
// {
// "reason": "ERROR_REASON_FILTER_ALREADY_REGISTERED",
// "domain": "authzed.com",
// "metadata": { ... filter fields ... }
// }
ERROR_REASON_FILTER_ALREADY_REGISTERED = 26;

// The request failed because the filter was not registered.
//
// Example of an ErrorInfo:
//
// {
// "reason": "ERROR_REASON_FILTER_NOT_REGISTERED",
// "domain": "authzed.com",
// "metadata": { ... filter fields ... }
// }
ERROR_REASON_FILTER_NOT_REGISTERED = 27;
}
65 changes: 64 additions & 1 deletion authzed/api/v1/experimental_service.proto
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@ import "authzed/api/v1/permission_service.proto";
// ExperimentalService exposes a number of APIs that are currently being
// prototyped and tested for future inclusion in the stable API.
service ExperimentalService {

// BulkImportRelationships is a faster path to writing a large number of
// relationships at once. It is both batched and streaming. For maximum
// performance, the caller should attempt to write relationships in as close
Expand Down Expand Up @@ -99,8 +98,72 @@ service ExperimentalService {
body: "*"
};
}

// EXPERIMENTAL: RegisterRelationshipCounter registers a new filter for counting relationships. A filter must be registered before
// a count can be requested.
rpc ExperimentalRegisterRelationshipCounter(ExperimentalRegisterRelationshipCounterRequest)
returns (ExperimentalRegisterRelationshipCounterResponse) {
option (google.api.http) = {
post: "/v1/experimental/registerrelationshipcounter"
body: "*"
};
}

// EXPERIMENTAL: CountRelationships returns the count of relationships for *pre-registered* filter.
rpc ExperimentalCountRelationships(ExperimentalCountRelationshipsRequest)
returns (ExperimentalCountRelationshipsResponse) {
option (google.api.http) = {
post: "/v1/experimental/countrelationships"
body: "*"
};
}

// EXPERIMENTAL: UnregisterRelationshipCounter unregisters an existing filter for counting relationships.
rpc ExperimentalUnregisterRelationshipCounter(ExperimentalUnregisterRelationshipCounterRequest)
returns (ExperimentalUnregisterRelationshipCounterResponse) {
option (google.api.http) = {
post: "/v1/experimental/unregisterrelationshipcounter"
body: "*"
};
}
}

message ExperimentalRegisterRelationshipCounterRequest {
// relationship_filter defines the filter to be applied to the relationships
// to be counted.
RelationshipFilter relationship_filter = 1
[ (validate.rules).message.required = true ];
}

message ExperimentalRegisterRelationshipCounterResponse {}

message ExperimentalCountRelationshipsRequest {
// consistency defines the consistency level for the count operation. If the
// requested consistency is fully consistent or represents a zedtoken that is
// not stored in the system, the count will be performed synchronously, which
// can be *quite slow* for large datasets.
Consistency consistency = 1;

// relationship_filter defines the filter to be applied to the relationships
// to be counted.
RelationshipFilter relationship_filter = 2
[ (validate.rules).message.required = true ];
}

message ExperimentalCountRelationshipsResponse {
// read_at is the ZedToken at which the relationship count was performed
ZedToken read_at = 1 [ (validate.rules).message.required = true ];

uint64 relationship_count = 2;
}

message ExperimentalUnregisterRelationshipCounterRequest {
RelationshipFilter relationship_filter = 1
[ (validate.rules).message.required = true ];
}

message ExperimentalUnregisterRelationshipCounterResponse {}

// NOTE: Deprecated now that BulkCheckPermission has been promoted to the stable API as "CheckBulkPermission".
message BulkCheckPermissionRequest {
Consistency consistency = 1;
Expand Down

0 comments on commit 5d85ef7

Please sign in to comment.