All Downloads are FREE. Search and download functionalities are using the official Maven repository.

liquibase.changelogs.v3_5_0.schema.yml Maven / Gradle / Ivy

databaseChangeLog:
  - changeSet:
      id: 3.5.0
      author: GraviteeSource Team
      changes:

        # Organizations
        ###############
        - createTable:
            tableName: organizations
            columns:
              - column: {name: id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: description, type: clob, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_organizations
            columnNames: id
            tableName: organizations

        - createTable:
            tableName: organization_identities
            columns:
              - column: {name: organization_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: identity_id, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name:  organization_id
            indexName:  idx_organization_identities
            tableName:  organization_identities
            unique:  false

        - createTable:
            tableName: organization_domain_restrictions
            columns:
              - column: {name: organization_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: domain_restriction, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name:  organization_id
            indexName:  idx_organization_domain_restrictions
            tableName:  organization_domain_restrictions
            unique:  false

        # Environments
        ##############
        - createTable:
            tableName: environments
            columns:
              - column: {name: id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: organization_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: description, type: clob, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_environments
            columnNames: id
            tableName: environments

        - createTable:
            tableName: environment_domain_restrictions
            columns:
              - column: {name: environment_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: domain_restriction, type: nvarchar(255), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name:  environment_id
            indexName:  idx_environment_domain_restrictions
            tableName:  environment_domain_restrictions
            unique:  false

        # Domain
        ##############
        - createTable:
            tableName: domains
            columns:
              - column: {name: id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: reference_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: reference_type, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: description, type: clob, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: enabled, type: boolean, constraints: { nullable: true }}
              - column: {name: path, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: vhost_mode, type: boolean, constraints: { nullable: true }}
              - column: {name: oidc, type: clob, constraints: { nullable: true } }
              - column: {name: uma, type: clob, constraints: { nullable: true } }
              - column: {name: login_settings, type: clob, constraints: { nullable: true } }
              - column: {name: web_authn_settings, type: clob, constraints: { nullable: true } }
              - column: {name: scim, type: clob, constraints: { nullable: true } }
              - column: {name: account_settings, type: clob, constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_domain
            columnNames: id
            tableName: domains

        - createTable:
            tableName: domain_identities
            columns:
              - column: {name: domain_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: identity_id, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name:  domain_id
            indexName:  idx_domain_identities
            tableName:  domain_identities
            unique:  false

        - createTable:
            tableName: domain_tags
            columns:
              - column: {name: domain_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: tag, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name:  domain_id
            indexName:  idx_domain_tags
            tableName:  domain_tags
            unique:  false

        - createTable:
            tableName: domain_vhosts
            columns:
              - column: {name: domain_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: host, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: path, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: override_endpoints, type: boolean, constraints: { nullable: true } }

        - createIndex:
            columns:
              - column:
                  name:  domain_id
            indexName:  idx_domain_vhosts
            tableName:  domain_vhosts
            unique:  false

            # AccessPolicy
            ##############
        - createTable:
            tableName: uma_access_policies
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: type, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: enabled, type: boolean, constraints: { nullable: true } }
              - column: {name: description, type: clob, constraints: { nullable: true } }
              - column: {name: order, type: integer, constraints: { nullable: true } }
              - column: {name: condition, type: clob, constraints: { nullable: true } }
              - column: {name: domain, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: resource, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_uma_access_policies
            columnNames: id
            tableName: uma_access_policies

        - createIndex:
            columns:
              - column:
                  name:  domain
            indexName:  idx_uma_access_policies_doman
            tableName:  uma_access_policies
            unique:  false

        - createIndex:
            columns:
              - column:
                  name:  resource
            indexName:  idx_uma_access_policies_resource
            tableName:  uma_access_policies
            unique:  false

        - createIndex:
            columns:
              - column:
                  name: domain
              - column:
                  name: resource
            indexName:  idx_uma_access_policies_domain_resource
            tableName:  uma_access_policies
            unique:  false

        - createIndex:
            columns:
              - column:
                  name:  updated_at
            indexName:  idx_uma_access_policies_updated_at
            tableName:  uma_access_policies
            unique:  false

        # Certificates
        ##############
        - createTable:
            tableName: certificates
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: type, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: domain, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: metadata, type: clob, constraints: { nullable: true } }
              - column: {name: configuration, type: clob, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - sql:
            dbms: postgresql
            sql: ALTER TABLE certificates ALTER metadata TYPE JSON USING metadata::json

        - sql:
            dbms: mysql
            sql: ALTER TABLE certificates MODIFY metadata JSON;

        - addPrimaryKey:
            constraintName: pk_certificates
            columnNames: id
            tableName: certificates

        - createIndex:
            columns:
              - column:
                  name: domain
            indexName:  idx_certificates_domain
            tableName:  certificates
            unique:  false

        # Credentials
        ##############
        - createTable:
            tableName: webauthn_credentials
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: reference_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: reference_type, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: user_id, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: username, type: nvarchar(320), constraints: { nullable: true } }
              - column: {name: user_agent, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: ip_address, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: credential_id, type: nvarchar(128), constraints: { nullable: true } }
              - column: {name: public_key, type: clob, constraints: { nullable: true } }
              - column: {name: counter, type: bigint, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: accessed_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_webauthn_credentials
            columnNames: id
            tableName: webauthn_credentials

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: user_id
            indexName:  idx_webauthn_credentials_ref_userid
            tableName:  webauthn_credentials
            unique:  false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: credential_id
            indexName:  idx_webauthn_credentials_ref_credential
            tableName:  webauthn_credentials
            unique:  false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: username
            indexName:  idx_webauthn_credentials_ref_username
            tableName:  webauthn_credentials
            unique:  false


        # Emails
        ##############
        - createTable:
            tableName: emails
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: reference_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: reference_type, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: enabled, type: boolean, constraints: { nullable: true } }
              - column: {name: client, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: template, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: from, type: nvarchar(320), constraints: { nullable: true } }
              - column: {name: from_name, type: nvarchar(320), constraints: { nullable: true } }
              - column: {name: subject, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: content, type: clob, constraints: { nullable: true } }
              - column: {name: expires_after, type: integer, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_emails
            columnNames: id
            tableName: emails

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
            indexName:  idx_emails_ref
            tableName:  emails
            unique:  false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: template
            indexName:  idx_emails_ref_tpl
            tableName:  emails
            unique:  false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: client
              - column:
                  name: template
            indexName:  idx_emails_ref_client_tpl
            tableName:  emails
            unique:  false

        # Entrypoints
        ##############
        - createTable:
            tableName: entrypoints
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: organization_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: description, type: clob, constraints: { nullable: true } }
              - column: {name: url, type: nvarchar(512), constraints: { nullable: true } }
              - column: {name: default_entrypoint, type: boolean, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_entrypoints
            columnNames: id
            tableName: entrypoints

        - createIndex:
            columns:
              - column:
                  name: organization_id
            indexName:  idx_entrypoint_organization_id
            tableName:  entrypoints
            unique:  false

        - createTable:
            tableName: entrypoint_tags
            columns:
              - column: {name: entrypoint_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: tag, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name:  entrypoint_id
            indexName:  idx_entrypoint_tags_entrypoint_id
            tableName:  entrypoint_tags
            unique:  false


        # Events
        ##############
        - createTable:
            tableName: events
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: type, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: payload, type: clob, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - sql:
            dbms: postgresql
            sql: ALTER TABLE events ALTER payload TYPE JSONB USING payload::jsonb

        - sql:
            dbms: mysql
            sql: ALTER TABLE events MODIFY payload JSON;

        - addPrimaryKey:
            constraintName: pk_events
            columnNames: id
            tableName: events

        - createIndex:
            columns:
              - column:
                  name: updated_at
            indexName:  idx_events_updated_at
            tableName:  events
            unique:  false

        # ExtensionGrants
        ##############
        - createTable:
            tableName: extension_grants
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: type, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: configuration, type: clob, constraints: { nullable: true } }
              - column: {name: domain, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: grant_type, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: identity_provider, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: create_user, type: boolean, constraints: { nullable: true } }
              - column: {name: user_exists, type: boolean, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_extension_grants
            columnNames: id
            tableName: extension_grants

        - createIndex:
            columns:
              - column:
                  name: domain
            indexName:  idx_extension_grants_domain
            tableName:  extension_grants
            unique:  false

        - createIndex:
            columns:
              - column:
                  name: domain
              - column:
                  name: name
            indexName:  idx_extension_grants_domain_name
            tableName:  extension_grants
            unique:  false

        # Factor
        ##############
        - createTable:
            tableName: factors
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: type, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: configuration, type: clob, constraints: { nullable: true } }
              - column: {name: domain, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: factor_type, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_factors
            columnNames: id
            tableName: factors

        - createIndex:
            columns:
              - column:
                  name: domain
            indexName:  idx_factors_domain
            tableName:  factors
            unique:  false

        - createIndex:
            columns:
              - column:
                  name: domain
              - column:
                  name: factor_type
            indexName:  idx_factors_domain_factor_type
            tableName:  factors
            unique:  false

        # Form
        ##############
        - createTable:
            tableName: forms
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: reference_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: reference_type, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: enabled, type: boolean, constraints: { nullable: true } }
              - column: {name: client, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: template, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: content, type: clob, constraints: { nullable: true } }
              - column: {name: assets, type: clob, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_forms
            columnNames: id
            tableName: forms

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
            indexName:  idx_forms_ref
            tableName:  forms
            unique:  false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: template
            indexName:  idx_forms_ref_tpl
            tableName:  forms
            unique:  false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: client
              - column:
                  name: template
            indexName:  idx_forms_ref_client_tpl
            tableName:  forms
            unique:  false

        # Groups
        ##############
        - createTable:
            tableName: groups
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: reference_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: reference_type, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: description, type: clob, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_groups
            columnNames: id
            tableName: groups

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
            indexName:  idx_groups_ref
            tableName:  groups
            unique:  false

        - createTable:
            tableName: group_members
            columns:
              - column: {name: group_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: member, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name: group_id
            indexName: idx_group_members_group
            tableName: group_members
            unique: false

        - createIndex:
            columns:
              - column:
                  name: member
            indexName: idx_group_members_member
            tableName: group_members
            unique: false

        - createTable:
            tableName: group_roles
            columns:
              - column: {name: group_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: role, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name: group_id
            indexName: idx_group_roles_group
            tableName: group_roles
            unique: false

        # identities
        ##############
        - createTable:
            tableName: identities
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: reference_id, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: reference_type, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: type, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: configuration, type: clob, constraints: { nullable: true } }
              - column: {name: mappers, type: clob, constraints: { nullable: true } }
              - column: {name: role_mapper, type: clob, constraints: { nullable: true } }
              - column: {name: external, type: boolean, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - sql:
            dbms: postgresql
            sql: ALTER TABLE identities ALTER role_mapper TYPE JSON USING role_mapper::json

        - sql:
            dbms: postgresql
            sql: ALTER TABLE identities ALTER mappers TYPE JSON USING mappers::json

        - sql:
            dbms: mysql
            sql: ALTER TABLE identities MODIFY role_mapper JSON;

        - sql:
            dbms: mysql
            sql: ALTER TABLE identities MODIFY mappers JSON;

        - addPrimaryKey:
            constraintName: pk_identities
            columnNames: id
            tableName: identities

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
            indexName:  idx_identities_ref
            tableName:  identities
            unique:  false

        # LoginAttempts
        ##############
        - createTable:
            tableName: login_attempts
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: domain, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: client, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: identity_provider, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: username, type: nvarchar(320), constraints: { nullable: true } }
              - column: {name: attempts, type: integer, constraints: { nullable: true } }
              - column: {name: expire_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_login_attempts
            columnNames: id
            tableName: login_attempts

        - createIndex:
            columns:
              - column:
                  name: expire_at
            indexName: idx_login_attempts_expire
            tableName: login_attempts
            unique: false

        - createIndex:
            columns:
              - column:
                  name: domain
              - column:
                  name: client
              - column:
                  name: username
            indexName:  idx_login_attempts_domain_client_username
            tableName:  login_attempts
            unique:  false


        # Memberships
        ##############
        - createTable:
            tableName: memberships
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: domain, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: member_id, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: member_type, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: reference_id, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: reference_type, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: role_id, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_memberships
            columnNames: id
            tableName: memberships

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
            indexName:  idx_memberships_refid_reftype
            tableName:  memberships
            unique:  false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: member_id
            indexName:  idx_memberships_refid_memberid
            tableName:  memberships
            unique:  false

        - createIndex:
            columns:
              - column:
                  name: member_id
              - column:
                  name: member_type
            indexName:  idx_memberships_memberid_membertype
            tableName:  memberships
            unique:  false

        # PermissionRequest
        ##############
        - createTable:
            tableName: uma_permission_ticket
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: domain, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: user_id, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: client_id, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: permission_request, type: clob, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: expire_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_uma_permission_ticket
            columnNames: id
            tableName: uma_permission_ticket

        - sql:
            dbms: postgresql
            sql: ALTER TABLE uma_permission_ticket ALTER permission_request TYPE JSON USING permission_request::json

        - sql:
            dbms: mysql
            sql: ALTER TABLE uma_permission_ticket MODIFY permission_request JSON;

        - createIndex:
            columns:
              - column:
                  name: expire_at
            indexName: idx_uma_permission_ticket_expire
            tableName: uma_permission_ticket
            unique: false

        # Reporter
        ##############
        - createTable:
            tableName: reporters
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: enabled, type: boolean, constraints: { nullable: true } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: type, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: configuration, type: clob, constraints: { nullable: true } }
              - column: {name: domain, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: data_type, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_reporter
            columnNames: id
            tableName: reporters

        - createIndex:
            columns:
              - column:
                  name: domain
            indexName:  idx_reporter_domain
            tableName:  reporters
            unique:  false


        # Resource
        ##############
        - createTable:
            tableName: uma_resource_set
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: description, type: clob, constraints: { nullable: true } }
              - column: {name: icon_uri, type: nvarchar(512), constraints: { nullable: true } }
              - column: {name: type, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: domain, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: user_id, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: client_id, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_uma_resources
            columnNames: id
            tableName: uma_resource_set

        - createIndex:
            columns:
              - column:
                  name: domain
              - column:
                  name: client_id
              - column:
                  name: user_id
            indexName:  idx_uma_resource_set_domain_client_user
            tableName:  uma_resource_set
            unique:  false

        - createTable:
            tableName: uma_resource_scopes
            columns:
              - column: {name: resource_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: scope, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name: resource_id
            indexName: idx_uma_resource_scopes_resource
            tableName: uma_resource_scopes
            unique: false

        # Roles
        ##############
        - createTable:
            tableName: roles
            columns:
              - column: { name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: name, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: description, type: clob, constraints: { nullable: true } }
              - column: { name: reference_type, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: reference_id, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: assignable_type, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: system, type: boolean, constraints: { nullable: true } }
              - column: { name: default_role, type: boolean, constraints: { nullable: true } }
              - column: { name: permission_acls, type: clob, constraints: { nullable: true } }
              - column: { name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_roles
            columnNames: id
            tableName: roles

        - sql:
            dbms: postgresql
            sql: ALTER TABLE roles ALTER permission_acls TYPE JSON USING permission_acls::json

        - sql:
            dbms: mysql
            sql: ALTER TABLE roles MODIFY permission_acls JSON;

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: name
            indexName: idx_roles_reference_name
            tableName: roles
            unique: false

        - createTable:
            tableName: role_oauth_scopes
            columns:
              - column: { name: role_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: scope, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name: role_id
            indexName: idx_role_oauth_scopes_role
            tableName: role_oauth_scopes
            unique: false

        # Scope
        ##############
        - createTable:
            tableName: scopes
            columns:
              - column: { name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: name, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: key, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: domain, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: description, type: clob, constraints: { nullable: true } }
              - column: { name: icon_uri, type: nvarchar(512), constraints: { nullable: true } }
              - column: { name: system, type: boolean, constraints: { nullable: true } }
              - column: { name: discovery, type: boolean, constraints: { nullable: true } }
              - column: { name: expires_in, type: integer, constraints: { nullable: true } }
              - column: { name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_scopes
            columnNames: id
            tableName: scopes

        - createIndex:
            columns:
              - column:
                  name: domain
              - column:
                  name: key
            indexName: idx_scopes_domain_key
            tableName: scopes
            unique: false

        - createTable:
            tableName: scope_claims
            columns:
              - column: { name: scope_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: claim, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name: scope_id
            indexName: idx_scope_claim_scope
            tableName: scope_claims
            unique: false

        # Tags
        ##############
        - createTable:
            tableName: tags
            columns:
              - column: { name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: name, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: organization_id, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: description, type: clob, constraints: { nullable: true } }
              - column: { name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_tags
            columnNames: id
            tableName: tags

        - createIndex:
            columns:
              - column:
                  name: organization_id
            indexName: idx_tags_organization
            tableName: tags
            unique: false

        # Applications
        ##############
        - createTable:
            tableName: applications
            columns:
              - column: { name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: name, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: type, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: description, type: clob, constraints: { nullable: true } }
              - column: { name: domain, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: certificate, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: enabled, type: boolean, constraints: { nullable: true } }
              - column: { name: template, type: boolean, constraints: { nullable: true } }
              - column: { name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: updated_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: metadata, type: clob, constraints: { nullable: true } }
              - column: { name: settings, type: clob, constraints: { nullable: true } }

        - sql:
            dbms: postgresql
            sql: ALTER TABLE applications ALTER metadata TYPE JSONB USING metadata::jsonb

        - sql:
            dbms: postgresql
            sql: ALTER TABLE applications ALTER settings TYPE JSONB USING settings::jsonb

        - sql:
            dbms: postgresql
            sql: CREATE INDEX idx_application_domain_client ON applications USING BTREE (domain, ((settings->'oauth'->>'clientId')))

        - sql:
            dbms: mysql
            sql: ALTER TABLE applications MODIFY metadata JSON;

        - sql:
            dbms: mysql
            sql: ALTER TABLE applications MODIFY settings JSON;

        - sql:
            dbms: mysql
            sql: ALTER TABLE applications ADD settings_client_id VARCHAR(64) AS (JSON_UNQUOTE(settings->"$.oauth.clientId"));

        - sql:
            dbms: mariadb
            sql: ALTER TABLE applications ADD settings_client_id VARCHAR(64) AS (JSON_VALUE(settings, "$.oauth.clientId"));

        - sql:
            dbms: mysql, mariadb
            sql: CREATE INDEX idx_application_domain_client ON applications(domain, settings_client_id);

        - sql:
            dbms: mssql
            sql: ALTER TABLE applications ADD settings_client_id AS JSON_VALUE(settings, '$.oauth.clientId');

        - sql:
            dbms: mssql
            sql: CREATE INDEX idx_application_domain_client ON applications(domain, settings_client_id);

        - addPrimaryKey:
            constraintName: pk_applications
            columnNames: id
            tableName: applications

        - createIndex:
            columns:
              - column:
                  name: domain
            indexName: idx_application_domain
            tableName: applications
            unique: false

        - createIndex:
            columns:
              - column:
                  name: updated_at
                  descending: true
            indexName: idx_application_updated_at
            tableName: applications
            unique: false

        - createIndex:
            columns:
              - column:
                  name: certificate
            indexName: idx_application_certificate
            tableName: applications
            unique: false

        - createIndex:
            columns:
              - column:
                  name: domain
              - column:
                  name: name
            indexName: idx_application_domain_name
            tableName: applications
            unique: false

        - createTable:
            tableName: application_grants
            columns:
              - column: { name: application_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: grant_type, type: nvarchar(255), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name: application_id
            indexName: idx_application_grants_app
            tableName: application_grants
            unique: false

        - createIndex:
            columns:
              - column:
                  name: grant_type
            indexName: idx_application_grants_grant
            tableName: application_grants
            unique: false

        - createTable:
            tableName: application_identities
            columns:
              - column: { name: application_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: identity, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name: application_id
            indexName: idx_application_identities_app
            tableName: application_identities
            unique: false

        - createIndex:
            columns:
              - column:
                  name: identity
            indexName: idx_application_identities_identity
            tableName: application_identities
            unique: false

        - createTable:
            tableName: application_factors
            columns:
              - column: { name: application_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: factor, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name: application_id
            indexName: idx_application_factor_app
            tableName: application_factors
            unique: false

        - createIndex:
            columns:
              - column:
                  name: factor
            indexName: idx_application_factor_factor
            tableName: application_factors
            unique: false

        # Users
        ##############
        - createTable:
            tableName: users
            columns:
              - column: { name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: external_id, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: username, type: nvarchar(320), constraints: { nullable: true } }
              - column: { name: email, type: nvarchar(320), constraints: { nullable: true } }
              - column: { name: display_name, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: nick_name, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: first_name, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: last_name, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: title, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: type, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: preferred_language, type: nvarchar(10), constraints: { nullable: true } }
              - column: { name: account_non_expired, type: boolean, constraints: { nullable: true } }
              - column: { name: account_locked_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: account_locked_until, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: account_non_locked, type: boolean, constraints: { nullable: true } }
              - column: { name: credentials_non_expired, type: boolean, constraints: { nullable: true } }
              - column: { name: enabled, type: boolean, constraints: { nullable: true } }
              - column: { name: internal, type: boolean, constraints: { nullable: true } }
              - column: { name: pre_registration, type: boolean, constraints: { nullable: true } }
              - column: { name: registration_completed, type: boolean, constraints: { nullable: true } }
              - column: { name: newsletter, type: boolean, constraints: { nullable: true } }
              - column: { name: registration_user_uri, type: nvarchar(1024), constraints: { nullable: true } }
              - column: { name: registration_access_token, type: clob, constraints: { nullable: true } }
              - column: { name: reference_type, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: reference_id, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: source, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: client, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: logins_count, type: integer, constraints: { nullable: true } }
              - column: { name: logged_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: updated_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: x509_certificates, type: clob, constraints: { nullable: true } }
              - column: { name: factors, type: clob, constraints: { nullable: true } }
              - column: { name: additional_information, type: clob, constraints: { nullable: true } }

        - sql:
            dbms: postgresql
            sql: ALTER TABLE users ALTER x509_certificates TYPE JSON USING x509_certificates::json

        - sql:
            dbms: mysql
            sql: ALTER TABLE users MODIFY x509_certificates JSON;

        - sql:
            dbms: postgresql
            sql: ALTER TABLE users ALTER factors TYPE JSON USING factors::json

        - sql:
            dbms: mysql
            sql: ALTER TABLE users MODIFY factors JSON;

        - sql:
            dbms: postgresql
            sql: ALTER TABLE users ALTER additional_information TYPE JSONB USING additional_information::jsonb

        - sql:
            dbms: postgresql
            sql: CREATE INDEX idx_users_additional_info_email ON users USING BTREE (reference_id, reference_type, ((additional_information->>'email')))
        - sql:
            dbms: postgresql
            sql: CREATE INDEX idx_users_additional_info_family_name ON users USING BTREE (reference_id, reference_type, ((additional_information->>'family_name')))
        - sql:
            dbms: postgresql
            sql: CREATE INDEX idx_users_additional_info_given_name ON users USING BTREE (reference_id, reference_type, ((additional_information->>'given_name')))
        - sql:
            dbms: postgresql
            sql: CREATE INDEX idx_users_additional_info_middle_name ON users USING BTREE (reference_id, reference_type, ((additional_information->>'middle_name')))
        - sql:
            dbms: postgresql
            sql: CREATE INDEX idx_users_additional_info_locale ON users USING BTREE (reference_id, reference_type, ((additional_information->>'locale')))
        - sql:
            dbms: postgresql
            sql: CREATE INDEX idx_users_additional_info_zoneinfo ON users USING BTREE (reference_id, reference_type, ((additional_information->>'zoneinfo')))

        - sql:
            dbms: mysql
            sql: ALTER TABLE users MODIFY additional_information JSON;

        - sql:
            dbms: mysql
            sql: ALTER TABLE users ADD additional_information_email VARCHAR(320) AS (JSON_UNQUOTE(additional_information->"$.email"));
        - sql:
            dbms: mysql
            sql: ALTER TABLE users ADD additional_information_family_name VARCHAR(128) AS (JSON_UNQUOTE(additional_information->"$.family_name"));
        - sql:
            dbms: mysql
            sql: ALTER TABLE users ADD additional_information_given_name VARCHAR(128) AS (JSON_UNQUOTE(additional_information->"$.given_name")) ;
        - sql:
            dbms: mysql
            sql: ALTER TABLE users ADD additional_information_middle_name VARCHAR(128) AS (JSON_UNQUOTE(additional_information->"$.middle_name"));
        - sql:
            dbms: mysql
            sql: ALTER TABLE users ADD additional_information_profile VARCHAR(1024) AS (JSON_UNQUOTE(additional_information->"$.profile"));
        - sql:
            dbms: mysql
            sql: ALTER TABLE users ADD additional_information_locale VARCHAR(35) AS (JSON_UNQUOTE(additional_information->"$.locale"));
        - sql:
            dbms: mysql
            sql: ALTER TABLE users ADD additional_information_zoneinfo VARCHAR(256) AS (JSON_UNQUOTE(additional_information->"$.zoneinfo"));

        - sql:
            dbms: mariadb
            sql: ALTER TABLE users ADD additional_information_email VARCHAR(320) AS (JSON_VALUE(additional_information, "$.email"));
        - sql:
            dbms: mariadb
            sql: ALTER TABLE users ADD additional_information_family_name VARCHAR(128) AS (JSON_VALUE(additional_information, "$.family_name"));
        - sql:
            dbms: mariadb
            sql: ALTER TABLE users ADD additional_information_given_name VARCHAR(128) AS (JSON_VALUE(additional_information, "$.given_name"));
        - sql:
            dbms: mariadb
            sql: ALTER TABLE users ADD additional_information_middle_name VARCHAR(128) AS (JSON_VALUE(additional_information, "$.middle_name"));
        - sql:
            dbms: mariadb
            sql: ALTER TABLE users ADD additional_information_profile VARCHAR(1024) AS (JSON_VALUE(additional_information, "$.profile"));
        - sql:
            dbms: mariadb
            sql: ALTER TABLE users ADD additional_information_locale VARCHAR(35) AS (JSON_VALUE(additional_information, "$.locale"));
        - sql:
            dbms: mariadb
            sql: ALTER TABLE users ADD additional_information_zoneinfo VARCHAR(256) AS (JSON_VALUE(additional_information, "$.zoneinfo"));

        - sql:
            dbms: mysql, mariadb
            sql: CREATE INDEX idx_users_additional_information_email ON users(reference_id, reference_type, additional_information_email);
        - sql:
            dbms: mysql, mariadb
            sql: CREATE INDEX idx_users_additional_information_family_name ON users(reference_id, reference_type, additional_information_family_name);
        - sql:
            dbms: mysql, mariadb
            sql: CREATE INDEX idx_users_additional_information_given_name ON users(reference_id, reference_type, additional_information_given_name);
        - sql:
            dbms: mysql, mariadb
            sql: CREATE INDEX idx_users_additional_information_middle_name ON users(reference_id, reference_type, additional_information_middle_name);
        - sql:
            dbms: mysql, mariadb
            sql: CREATE INDEX idx_users_additional_information_locale ON users(reference_id, reference_type, additional_information_locale);
        - sql:
            dbms: mysql, mariadb
            sql: CREATE INDEX idx_users_additional_information_zoneinfo ON users(reference_id, reference_type, additional_information_zoneinfo);

        - sql:
            dbms: mssql
            sql: ALTER TABLE users ADD additional_information_email AS JSON_VALUE(additional_information, '$.email');
        - sql:
            dbms: mssql
            sql: ALTER TABLE users ADD additional_information_family_name AS JSON_VALUE(additional_information, '$.family_name');
        - sql:
            dbms: mssql
            sql: ALTER TABLE users ADD additional_information_given_name AS JSON_VALUE(additional_information, '$.given_name');
        - sql:
            dbms: mssql
            sql: ALTER TABLE users ADD additional_information_middle_name AS JSON_VALUE(additional_information, '$.middle_name');
        - sql:
            dbms: mssql
            sql: ALTER TABLE users ADD additional_information_profile AS JSON_VALUE(additional_information, '$.profile');
        - sql:
            dbms: mssql
            sql: ALTER TABLE users ADD additional_information_locale AS JSON_VALUE(additional_information, '$.locale');
        - sql:
            dbms: mssql
            sql: ALTER TABLE users ADD additional_information_zoneinfo AS JSON_VALUE(additional_information, '$.zoneinfo');

        - sql:
            dbms: mssql
            sql: CREATE INDEX idx_users_additional_information_email ON users(reference_id, reference_type, additional_information_email);
        - sql:
            dbms: mssql
            sql: CREATE INDEX idx_users_additional_information_family_name ON users(reference_id, reference_type, additional_information_family_name);
        - sql:
            dbms: mssql
            sql: CREATE INDEX idx_users_additional_information_given_name ON users(reference_id, reference_type, additional_information_given_name);
        - sql:
            dbms: mssql
            sql: CREATE INDEX idx_users_additional_information_middle_name ON users(reference_id, reference_type, additional_information_middle_name);
        - sql:
            dbms: mssql
            sql: CREATE INDEX idx_users_additional_information_locale ON users(reference_id, reference_type, additional_information_locale);
        - sql:
            dbms: mssql
            sql: CREATE INDEX idx_users_additional_information_zoneinfo ON users(reference_id, reference_type, additional_information_zoneinfo);

        - addPrimaryKey:
            constraintName: pk_users
            columnNames: id
            tableName: users

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
            indexName: idx_users_reference
            tableName: users
            unique: false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: email
            indexName: idx_users_reference_email
            tableName: users
            unique: false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: username
            indexName: idx_users_reference_username
            tableName: users
            unique: false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: display_name
            indexName: idx_users_reference_displayname
            tableName: users
            unique: false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: first_name
            indexName: idx_users_reference_firstname
            tableName: users
            unique: false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: last_name
            indexName: idx_users_reference_lastname
            tableName: users
            unique: false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: external_id
            indexName: idx_users_reference_external
            tableName: users
            unique: false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: username
              - column:
                  name: source
            indexName: idx_users_reference_username_source
            tableName: users
            unique: false

        - createIndex:
            columns:
              - column:
                  name: reference_id
              - column:
                  name: reference_type
              - column:
                  name: external_id
              - column:
                  name: source
            indexName: idx_users_reference_externalid_source
            tableName: users
            unique: false

        - createTable:
            tableName: user_entitlements
            columns:
              - column: { name: user_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: entitlement, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name: user_id
            indexName: idx_user_entitlements_user
            tableName: user_entitlements
            unique: false

        - createTable:
            tableName: user_roles
            columns:
              - column: { name: user_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: role, type: nvarchar(64), constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name: user_id
            indexName: idx_user_roles_user
            tableName: user_roles
            unique: false

        - createTable:
            tableName: user_addresses
            columns:
              - column: { name: user_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: type, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: formatted, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: street_address, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: locality, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: region, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: postal_code, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: country, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: primary, type: boolean, constraints: { nullable: true } }

        - createIndex:
            columns:
              - column:
                  name: user_id
            indexName: idx_user_addresses_user
            tableName: user_addresses
            unique: false

        - createTable:
            tableName: user_attributes
            columns:
              - column: { name: user_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: user_field, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: value, type: clob, constraints: { nullable: true } }
              - column: { name: type, type: nvarchar(128), constraints: { nullable: true } }
              - column: { name: primary, type: boolean, constraints: { nullable: true } }

        - createIndex:
            columns:
              - column:
                  name: user_id
            indexName: idx_user_attributes_user
            tableName: user_attributes
            unique: false

        # Flows
        ##############
        - createTable:
            tableName: flows
            columns:
              - column: {name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: reference_id, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: reference_type, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: true } }
              - column: {name: enabled, type: boolean, constraints: { nullable: true } }
              - column: {name: type, type: nvarchar(64), constraints: { nullable: true } }
              - column: {name: condition, type: clob, constraints: { nullable: true } }
              - column: {name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: {name: updated_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_flows
            columnNames: id
            tableName: flows

        - createIndex:
            columns:
              - column:
                  name:  reference_id
              - column:
                  name:  reference_type
            indexName:  idx_flow_by_reference
            tableName:  flows
            unique:  false

        - createTable:
            tableName: flow_steps
            columns:
              - column: {name: flow_id, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: stage, type: nvarchar(64), constraints: { nullable: false } }
              - column: {name: stage_order, type: integer, constraints: { nullable: false } }
              - column: {name: name, type: nvarchar(255), constraints: { nullable: false } }
              - column: {name: policy, type: nvarchar(128), constraints: { nullable: false } }
              - column: {name: description, type: clob, constraints: { nullable: false } }
              - column: {name: configuration, type: clob, constraints: { nullable: false } }
              - column: {name: enabled, type: boolean, constraints: { nullable: false } }

        - createIndex:
            columns:
              - column:
                  name:  flow_id
            indexName:  idx_flow_step_flowid
            tableName:  flow_steps
            unique:  false

        ## request_objects
        ###################
        - createTable:
            tableName: request_objects
            columns:
              - column: { name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: domain, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: client, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: payload, type: clob, constraints: { nullable: true } }
              - column: { name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: expire_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_request_objects
            columnNames: id
            tableName: request_objects

        - createIndex:
            columns:
              - column:
                  name: expire_at
            indexName: idx_request_objects_expire
            tableName: request_objects
            unique: false

        ## access token
        ###################
        - createTable:
            tableName: access_tokens
            columns:
              - column: { name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: domain, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: client, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: subject, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: token, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: expire_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: authorization_code, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: refresh_token, type: clob, constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_access_tokens
            columnNames: id
            tableName: access_tokens

        - createIndex:
            columns:
              - column:
                  name: expire_at
            indexName: idx_access_tokens_expire
            tableName: access_tokens
            unique: false

        - createIndex:
            columns:
              - column:
                  name: token
            indexName: idx_access_tokens_token
            tableName: access_tokens
            unique: false

        - createIndex:
            columns:
              - column:
                  name: client
            indexName: idx_access_tokens_client
            tableName: access_tokens
            unique: false

        - createIndex:
            columns:
              - column:
                  name: authorization_code
            indexName: idx_access_tokens_auth_code
            tableName: access_tokens
            unique: false

        - createIndex:
            columns:
              - column:
                  name: subject
            indexName: idx_access_tokens_subject
            tableName: access_tokens
            unique: false

        - createIndex:
            columns:
              - column:
                  name: domain
              - column:
                  name: client
              - column:
                  name: subject
            indexName: idx_access_tokens_domain_client_subject
            tableName: access_tokens
            unique: false


        ## auhtorization code
        ###################
        - createTable:
            tableName: authorization_codes
            columns:
              - column: { name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: transaction_id, type: nvarchar(128), constraints: { nullable: true } }
              - column: { name: code, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: expire_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: client_id, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: subject, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: redirect_uri, type: clob, constraints: { nullable: true } }
              - column: { name: scopes, type: clob, constraints: { nullable: true } }
              - column: { name: request_parameters, type: clob, constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_authorization_codes
            columnNames: id
            tableName: authorization_codes

        - createIndex:
            columns:
              - column:
                  name: expire_at
            indexName: idx_authorization_codes_expire
            tableName: authorization_codes
            unique: false

        - createIndex:
            columns:
              - column:
                  name: code
            indexName: idx_authorization_codes_code
            tableName: authorization_codes
            unique: false

        ## refresh token
        ###################
        - createTable:
            tableName: refresh_tokens
            columns:
              - column: { name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: domain, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: client, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: subject, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: token, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: expire_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_refresh_tokens
            columnNames: id
            tableName: refresh_tokens

        - createIndex:
            columns:
              - column:
                  name: expire_at
            indexName: idx_refresh_token_expire
            tableName: refresh_tokens
            unique: false

        - createIndex:
            columns:
              - column:
                  name: token
            indexName: idx_refresh_tokens_token
            tableName: refresh_tokens
            unique: false

        - createIndex:
            columns:
              - column:
                  name: client
            indexName: idx_refresh_tokens_client
            tableName: refresh_tokens
            unique: false

        - createIndex:
            columns:
              - column:
                  name: subject
            indexName: idx_refresh_tokens_subject
            tableName: refresh_tokens
            unique: false

        - createIndex:
            columns:
              - column:
                  name: domain
              - column:
                  name: client
              - column:
                  name: subject
            indexName: idx_refresh_tokens_domain_client_subject
            tableName: refresh_tokens
            unique: false

        - createIndex:
            columns:
              - column:
                  name: domain
              - column:
                  name: subject
            indexName: idx_refresh_tokens_domain_subject
            tableName: refresh_tokens
            unique: false

        ## scope approval
        ###################
        - createTable:
            tableName: scope_approvals
            columns:
              - column: { name: id, type: nvarchar(64), constraints: { nullable: false } }
              - column: { name: domain, type: nvarchar(255), constraints: { nullable: true } }
              - column: { name: user_id, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: client_id, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: transaction_id, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: scope, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: status, type: nvarchar(64), constraints: { nullable: true } }
              - column: { name: created_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: updated_at, type: timestamp(6), constraints: { nullable: true } }
              - column: { name: expires_at, type: timestamp(6), constraints: { nullable: true } }

        - addPrimaryKey:
            constraintName: pk_scope_approvals
            columnNames: id
            tableName: scope_approvals

        - createIndex:
            columns:
              - column:
                  name: transaction_id
            indexName: idx_scope_approvals_transaction_id
            tableName: scope_approvals
            unique: false

        - createIndex:
            columns:
              - column:
                  name: domain
              - column:
                  name: user_id
            indexName: idx_scope_approvals_domain_user
            tableName: scope_approvals
            unique: false

        - createIndex:
            columns:
              - column:
                  name: domain
              - column:
                  name: client_id
              - column:
                  name: user_id
              - column:
                  name: scope
            indexName: idx_scope_approvals_domain_client_user_scope
            tableName: scope_approvals
            unique: true

        - createIndex:
            columns:
              - column:
                  name: expires_at
            indexName: idx_scope_approvals_expire
            tableName: scope_approvals
            unique: false




© 2015 - 2025 Weber Informatics LLC | Privacy Policy