ZITADEL - Identity infrastructure, simplified for you.
Go to file
Livio Amstutz 504fe5b761
cherry pick changes from main (#3371)
* feat: remove exif data from uploaded images (#3221)

* feat: remove exif tags from images

* feat: remove exif data

* feat: remove exif

* fix: add preferredLoginName to user grant response (#3271)

* chore: log webauthn parse error (#3272)

* log error

* log error

* feat: Help link in privacy policy

* fix: convert correct detail data on organization (#3279)

* fix: handle empty editor users

* fix: add some missing translations (#3291)

* fix: org policy translations

* fix: metadata event types translation

* fix: translations

* fix: filter resource owner correctly on project grant members (#3281)

* fix: filter resource owner correctly on project grant members

* fix: filter resource owner correctly on project grant members

* fix: add orgIDs to zitadel permissions request

Co-authored-by: fabi <fabienne.gerschwiler@gmail.com>

* fix: get IAM memberships correctly in MyZitadelPermissions (#3309)

* fix: correct login names on auth and notification users (#3349)

* fix: correct login names on auth and notification users

* fix: migration

* fix: handle resource owner in action flows (#3361)

* fix merge

* fix: exchange exif library (#3366)

* fix: exchange exif library

* ignore tiffs

* requested fixes

* feat: Help link in privacy policy

Co-authored-by: Fabi <38692350+fgerschwiler@users.noreply.github.com>
Co-authored-by: fabi <fabienne.gerschwiler@gmail.com>
2022-03-24 14:00:24 +01:00
.codecov chore(codecov): make codecov configurable in repo (#40) 2020-04-08 07:37:24 +02:00
.github chore(ci): release pipeline for v2 (#3197) 2022-02-14 14:35:16 +00:00
build feat: add system api proto (#3294) 2022-03-22 07:47:18 +00:00
cmd feat: projections auto create their tables (#3324) 2022-03-23 09:02:39 +01:00
console cherry pick changes from main (#3371) 2022-03-24 14:00:24 +01:00
docs cherry pick changes from main (#3371) 2022-03-24 14:00:24 +01:00
guides chore(ci): release pipeline for v2 (#3197) 2022-02-14 14:35:16 +00:00
internal cherry pick changes from main (#3371) 2022-03-24 14:00:24 +01:00
openapi feat: run on a single port (#3163) 2022-02-14 17:22:30 +01:00
pkg/grpc feat: Default configs sms provider (#3187) 2022-02-21 12:22:20 +00:00
proto/zitadel cherry pick changes from main (#3371) 2022-03-24 14:00:24 +01:00
statik fix(zitadel-image): refactor dockerfiles and gh action (#2027) 2021-07-27 14:34:56 +02:00
tools chore: align go.mod version for pipeline (#1922) 2021-06-22 15:18:22 +02:00
.dockerignore chore(ci): release pipeline for v2 (#3197) 2022-02-14 14:35:16 +00:00
.gitignore chore(ci): release pipeline for v2 (#3197) 2022-02-14 14:35:16 +00:00
.goreleaser.yaml feat: run on a single port (#3163) 2022-02-14 17:22:30 +01:00
.releaserc.js chore(ci): release pipeline for v2 (#3197) 2022-02-14 14:35:16 +00:00
changelog.config.js feat: Merge master (#1260) 2021-02-08 16:48:41 +01:00
CODE_OF_CONDUCT.md chore(coc): recommend code of conduct (#1782) 2021-05-28 07:38:50 +02:00
CONTRIBUTING.md fix(eventstore): sub queries (#1805) 2021-07-06 13:55:57 +02:00
go.mod cherry pick changes from main (#3371) 2022-03-24 14:00:24 +01:00
go.sum cherry pick changes from main (#3371) 2022-03-24 14:00:24 +01:00
LICENSE chore: Update LICENSE (#1087) 2020-12-14 09:40:09 +01:00
main.go feat(cli): init cli (#3186) 2022-02-09 15:01:19 +01:00
README.md docs(readme): Updates readme (#2994) 2022-01-12 15:07:54 +01:00
SECURITY.md refactor: Version 1 2021-04-20 14:04:02 +02:00

Zitadel Logo Zitadel Logo

semantic-release Release license release Go Report Card codecov discord
OpenID Connect Certified

What Is ZITADEL

ZITADEL is a "Cloud Native Identity and Access Management" solution built for the cloud era. ZITADEL uses a modern software stack consisting of Golang, Angular and CockroachDB as sole storage and follows an event sourced pattern.

We built ZITADEL not only with the vision of becoming a great open source project but also as a superb platform to support developers building their applications, without need to handle secure user login and account management themselves.

How Does It Work

We built ZITADEL around the idea that the IAM should be easy to deploy and scale. That's why we tried to reduce external systems as much as possible. For example, ZITADEL is event sourced but it does not rely on a pub/sub system to function. Instead we built all the functionality right into one binary. ZITADEL only needs Kubernetes for orchestration and CockroachDB as storage.

Run ZITADEL anywhere

Self-hosted

You can run an automatically operated ZITADEL instance on a CNCF compliant Kubernetes cluster of your choice:

Software-as-a-Service

  • ZITADEL Cloud: ZITADEL.ch is our shared cloud service hosted in Switzerland. Get started and try the free tier, including already unlimited users and all necessary security features.
  • ZITADEL Dedicated: We operate and support a dedicated instance of ZITADEL for you. Get in touch!

Start using ZITADEL

Quickstarts

See our Documentation to get started with ZITADEL quickly. Let us know, if you are missing a language or framework in the Q&A.

Client libraries

  • Go client library
  • .NET client library
  • Dart client library
  • Elixir client library (maintained by jshmrtn)

Help and Documentation

How To Contribute

Details about how to contribute you can find in the Contribution Guide

Security

See the policy here

Features of ZITADEL platform

  • Authentication
    • OpenID Connect 1.0 Protocol (OP)
    • Username / Password
    • Machine-to-machine (JWT profile)
    • Passwordless with FIDO2
    • Multifactor authentication with OTP, U2F
    • Federation with OpenID Connect 1.0 Protocol (RP), OAuth 2.0 Protocol (RP)
    • Identity Brokering
  • Identity & Access Management
    • B2C, B2B, B2E, M2M identities
    • Authorization via Role Based Access Control (RBAC)
    • Delegation of roles to other organizations for self-management
    • Management roles
    • User self-service workflows
    • User register workflow
  • Strong audit trail for all IAM resources
  • Privatelabeling
    • Custom branding
    • Custom texts
    • Hosted login
    • Personal profile
  • Integration
    • API-first
    • Actions for custom code execution

Showcase

Passwordless Login

Use our login widget to allow easy and sucure access to your applications and enjoy all the benefits of passwordless (FIDO 2 / WebAuthN):

  • works on all modern platforms, devices, and browsers
  • phishing resistant alternative
  • requires only one gesture by the user
  • easy enrollment of the device during registration

passwordless-windows-hello

Admin Console

Use Console or our APIs to setup organizations, projects and applications.

Register new applications OIDC-Client-Register

Delegate the right to assign roles to another organization projects_create_org_grant

Customize login and console with your design
private_labeling

Other CAOS Projects

  • ORBOS - GitOps everything
  • OIDC for GO - OpenID Connect SDK (client and server) for Go
  • ZITADEL Tools - Go tool to convert key file to privately signed JWT

Usage Data

ZITADEL components send errors and usage data to CAOS Ltd., so that we are able to identify code improvement potential. If you don't want to send this data or don't have an internet connection, pass the global flag --disable-analytics when using zitadelctl. For disabling ingestion for already-running components, execute the takeoff command again with the --disable-analytics flag.

We try to distinguishing the environments from which events come from. As environment identifier, we enrich the events by the domain you have configured in zitadel.yml, as soon as it's available. When it's not available and you passed the --gitops flag, we defer the environment identifier from your git repository URL.

Besides from errors that don't clearly come from misconfiguration or cli misuage, we send an inital event when any binary is started. This is a " invoked" event along with the flags that are passed to it, except secret values of course.

We only ingest operational data. Your ZITADEL workload data from the IAM application itself is never sent anywhere unless you chose to integrate other systems yourself.

License

See the exact licensing terms here

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.