import { supportedSecretBackends } from 'vault/helpers/supported-secret-backends'; const supportedBackends = supportedSecretBackends(); export default { key: 'secrets', initial: 'idle', on: { RESET: 'idle', DONE: 'complete', ERROR: 'error', }, states: { idle: { onEntry: [ { type: 'routeTransition', params: ['vault.cluster.settings.mount-secret-backend'] }, { type: 'render', level: 'feature', component: 'wizard/mounts-wizard' }, { type: 'render', level: 'step', component: 'wizard/secrets-idle' }, ], on: { CONTINUE: 'enable', }, }, enable: { onEntry: [ { type: 'render', level: 'feature', component: 'wizard/mounts-wizard' }, { type: 'render', level: 'step', component: 'wizard/secrets-enable' }, ], on: { CONTINUE: { details: { cond: type => supportedBackends.includes(type) }, list: { cond: type => !supportedBackends.includes(type) }, }, }, }, details: { onEntry: [ { type: 'render', level: 'feature', component: 'wizard/mounts-wizard' }, { type: 'render', level: 'step', component: 'wizard/secrets-details' }, ], on: { CONTINUE: { role: { cond: type => ['pki', 'aws', 'ssh'].includes(type), }, secret: { cond: type => ['cubbyhole', 'database', 'gcp', 'kv', 'nomad', 'rabbitmq', 'totp'].includes(type), }, encryption: { cond: type => type === 'transit', }, }, }, }, encryption: { onEntry: [ { type: 'render', level: 'feature', component: 'wizard/mounts-wizard' }, { type: 'render', level: 'step', component: 'wizard/secrets-encryption' }, ], on: { CONTINUE: 'display', }, }, credentials: { onEntry: [ { type: 'render', level: 'step', component: 'wizard/secrets-credentials' }, { type: 'render', level: 'feature', component: 'wizard/mounts-wizard' }, ], on: { CONTINUE: 'display', }, }, role: { onEntry: [ { type: 'render', level: 'step', component: 'wizard/secrets-role' }, { type: 'render', level: 'feature', component: 'wizard/mounts-wizard' }, ], on: { CONTINUE: 'displayRole', }, }, displayRole: { onEntry: [ { type: 'render', level: 'step', component: 'wizard/secrets-display-role' }, { type: 'render', level: 'feature', component: 'wizard/mounts-wizard' }, ], on: { CONTINUE: 'credentials', }, }, secret: { onEntry: [ { type: 'render', level: 'step', component: 'wizard/secrets-secret' }, { type: 'render', level: 'feature', component: 'wizard/mounts-wizard' }, ], on: { CONTINUE: 'display', }, }, display: { onEntry: [ { type: 'render', level: 'step', component: 'wizard/secrets-display' }, { type: 'render', level: 'feature', component: 'wizard/mounts-wizard' }, ], on: { REPEAT: { role: { cond: type => ['pki', 'aws', 'ssh'].includes(type), actions: [{ type: 'routeTransition', params: ['vault.cluster.secrets.backend.create-root'] }], }, secret: { cond: type => ['cubbyhole', 'database', 'gcp', 'kv', 'nomad', 'rabbitmq', 'totp'].includes(type), actions: [{ type: 'routeTransition', params: ['vault.cluster.secrets.backend.create-root'] }], }, encryption: { cond: type => type === 'transit', actions: [{ type: 'routeTransition', params: ['vault.cluster.secrets.backend.create-root'] }], }, }, }, }, list: { onEntry: [ { type: 'render', level: 'step', component: 'wizard/secrets-list' }, { type: 'render', level: 'feature', component: 'wizard/mounts-wizard' }, ], on: { CONTINUE: 'display', }, }, error: { onEntry: [ { type: 'render', level: 'step', component: 'wizard/tutorial-error' }, { type: 'render', level: 'feature', component: 'wizard/mounts-wizard' }, ], on: { CONTINUE: 'complete', }, }, complete: { onEntry: ['completeFeature'], }, }, };