2020-10-16 12:13:02 +00:00
|
|
|
---
|
|
|
|
title: Overview
|
|
|
|
description: …
|
|
|
|
---
|
|
|
|
|
|
|
|
> All documentations are under active work and subject to change soon!
|
|
|
|
|
|
|
|
### APIs
|
|
|
|
|
2020-10-26 12:03:51 +00:00
|
|
|
---
|
|
|
|
|
2020-10-16 12:13:02 +00:00
|
|
|
ZITADEL provides three API's for different use cases. These API's are built with GRPC and then generate a REST service.
|
2020-10-26 12:54:29 +00:00
|
|
|
Each service's proto definition is located in the source control on GitHub.
|
2020-10-16 12:13:02 +00:00
|
|
|
As we generate the REST services and Swagger file out of the proto definition we recommend that you rely on the proto file.
|
|
|
|
We annotate the corresponding REST methods on each possible call as well as the AuthN and AuthZ requirements.
|
|
|
|
|
|
|
|
See below for an example with the call **GetMyUser**.
|
|
|
|
|
|
|
|
```Go
|
|
|
|
//User
|
|
|
|
rpc GetMyUser(google.protobuf.Empty) returns (UserView) {
|
|
|
|
option (google.api.http) = {
|
|
|
|
get: "/users/me"
|
|
|
|
};
|
|
|
|
|
|
|
|
option (caos.zitadel.utils.v1.auth_option) = {
|
|
|
|
permission: "authenticated"
|
|
|
|
};
|
|
|
|
}
|
|
|
|
```
|
2020-10-26 12:03:51 +00:00
|
|
|
---
|
|
|
|
|
2020-10-26 12:54:29 +00:00
|
|
|
As you can see the `GetMyUser` function is also available as a REST service under the path `/users/me`.
|
|
|
|
|
2020-10-16 12:13:02 +00:00
|
|
|
In the table below you can see the URI of those calls.
|
|
|
|
|
|
|
|
| Service | URI |
|
|
|
|
|:--------|:-----------------------------------------------------------------------------------------------------------------------------------------------|
|
|
|
|
| REST | [https://api.zitadel.ch/auth/v1/users/me](https://api.zitadel.ch/auth/v1/users/me) |
|
|
|
|
| GRPC | [https://api.zitadel.ch/caos.zitadel.auth.api.v1.AuthService/GetMyUser](https://api.zitadel.ch/caos.zitadel.auth.api.v1.AuthService/GetMyUser) |
|