Skip to main content

Identity schema, custom fields

The Identity Schema is a JSON Schema which describes your identity's (your customers / users / employees ...) fields. In Ory, every identity can have their own model, allowing you to separate between different customer types, user types (employees and customers). For technical information on Identity Schemas, check out the open source documentation:

The Identity Schema can either be one of the available presets or a customized model.

Available presets

Ory Cloud provides three basic Identity Schema Presets.

Username and password

This preset is useful for applications that don't require email addresses and a high degree of anonymity.

note

This preset disables account verification, account recovery, and account enumeration defenses! Don't use it in security-sensitive environments.

With this preset, every identity has just one trait - the username. The username is the login identifier:

// Identity example
{
id: "6e9d3d30-f93e-4630-901f-c2096953723d",
traits: {
username: "some-username",
},
}

Email and password

With this preset, identities have just one trait, the email. The email is the login identifier, for email verification, and for account recovery:

// Identity example
{
id: "6e9d3d30-f93e-4630-901f-c2096953723d",
traits: {
email: "foo@bar.com",
},
}

Demo profile

warning

This profile is EXPERIMENTAL and you should only use it for PoCs and demos.

The Demo Profile preset has - like the Email & Password preset - an email field, a first name, last name, and a checkbox.

// Identity example
{
id: "6e9d3d30-f93e-4630-901f-c2096953723d",
traits: {
email: "foo@bar.com",
name: {
first: "Foo",
last: "Bar",
},
newsletter: true,
},
}

Custom identity schema

Ory gives you the option to add custom fields to your Identity Schema.

You can define new traits for an identity, save the identity as a template and switch between different Identity Schemas.