API Clients
Library
Official
The Authzed team officially supports and maintains client libraries for a variety of languages. Officially maintained client libraries can be found on the authzed GitHub organization.
Official clients typically leverage their language's gRPC libraries to provide a client abstraction for each version of the API. For example, in Go, constructing a client is no different from creating any other gRPC connection and can use any gRPC DialOption to configure advanced functionality such as proxying, retries, and more.
Third Party
Any developer can generate their own clients from the published Protobuf Definitions. Regardless of language, we recommend using the buf toolchain to manage the generation workflow.
We recommend GitHub users to tag their repositories with authzed-client
and spicedb-client
to help withdiscovery.
If you are interested in additional language or building your own, feel free to jump into Discord to share and collaborate with other developers.
Command Line
zed
zed is the official command-line tool for managing Authzed and SpiceDB.
Once configured with credentials, zed usage looks like:
$ zed schema read
definition user {}
definition document {
relation writer: user
relation reader: user
permission edit = writer
permission view = reader + edit
}
$ zed permission check document:firstdoc writer user:emilia
false
$ zed relationship create document:firstdoc writer user:emilia
CAESAggB
$ zed permission check document:firstdoc writer user:emilia
true
grpcurl
grpcurl is a generic gRPC client that should feel familiar to users of curl. It uses JSON representations of Protocol Buffers to specify messages.
We recommend this client over grpc_cli for generic gRPC interactions.
Example usage:
noglob grpcurl -rpc-header "authorization: Bearer myapikey" -d '{"schema": "definition user {}"}' grpc.authzed.com:50051 "authzed.api.v1.SchemaService/WriteSchema"
grpc_cli
grpc_cli is the official generic gRPC client and is sometimes installed with gRPC itself. Despite that, it is relatively immature and not deemed stable by the gRPC team.
Because of this and the user experience being worse than grpcurl, we do not recommend it.
curl
Users running SpiceDB with HTTP enabled, are able to use curl with a JSON API.
Example usage:
curl -H "Authorization: Bearer myapikey" -X POST localhost:443/v1/schema/read