mirror of
				https://github.com/optim-enterprises-bv/vault.git
				synced 2025-11-03 20:17:59 +00:00 
			
		
		
		
	* Add new route w/ controller oidc-provider * oidc-provider controller has params, template has success message (temporary), model requests correct endpoint * Move oidc-provider route to under identity * Do not redirect after poll if on oidc-provider page * WIP provider -- beforeModel handles prompt, logout, redirect * Auth service fetch method rejects with fetch response if status >= 300 * New component OidcConsentBlock * Fix redirect to/from auth with cluster name, show error and consent form if applicable * Show error and consent form on template * Add component test, update docs * Test for oidc-consent-block component * Add changelog * fix tests * Add authorize to end of router path * Remove unused tests * Update changelog with feature name * Add descriptions for OidcConsentBlock component * glimmerize token-expire-warning and don't override yield if on oidc-provider route * remove text on token-expire-warning * Fix null transition.to on cluster redirect * Hide nav links if oidc-provider route
		
			
				
	
	
		
			150 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			150 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import EmberRouter from '@ember/routing/router';
 | 
						|
import config from 'vault/config/environment';
 | 
						|
 | 
						|
export default class Router extends EmberRouter {
 | 
						|
  location = config.locationType;
 | 
						|
  rootURL = config.rootURL;
 | 
						|
}
 | 
						|
 | 
						|
Router.map(function() {
 | 
						|
  this.route('vault', { path: '/' }, function() {
 | 
						|
    this.route('cluster', { path: '/:cluster_name' }, function() {
 | 
						|
      this.route('oidc-callback', { path: '/auth/*auth_path/oidc/callback' });
 | 
						|
      this.route('auth');
 | 
						|
      this.route('init');
 | 
						|
      this.route('logout');
 | 
						|
      this.mount('open-api-explorer', { path: '/api-explorer' });
 | 
						|
      this.route('license');
 | 
						|
      this.route('clients', function() {
 | 
						|
        this.route('index', { path: '/' });
 | 
						|
        this.route('edit');
 | 
						|
      });
 | 
						|
      this.route('storage', { path: '/storage/raft' });
 | 
						|
      this.route('storage-restore', { path: '/storage/raft/restore' });
 | 
						|
      this.route('settings', function() {
 | 
						|
        this.route('index', { path: '/' });
 | 
						|
        this.route('seal');
 | 
						|
        this.route('auth', function() {
 | 
						|
          this.route('index', { path: '/' });
 | 
						|
          this.route('enable');
 | 
						|
          this.route('configure', { path: '/configure/:method' }, function() {
 | 
						|
            this.route('index', { path: '/' });
 | 
						|
            this.route('section', { path: '/:section_name' });
 | 
						|
          });
 | 
						|
        });
 | 
						|
        this.route('mount-secret-backend');
 | 
						|
        this.route('configure-secret-backend', { path: '/secrets/configure/:backend' }, function() {
 | 
						|
          this.route('index', { path: '/' });
 | 
						|
          this.route('section', { path: '/:section_name' });
 | 
						|
        });
 | 
						|
      });
 | 
						|
      this.route('unseal');
 | 
						|
      this.route('tools', function() {
 | 
						|
        this.route('tool', { path: '/:selected_action' });
 | 
						|
      });
 | 
						|
      this.route('access', function() {
 | 
						|
        this.route('methods', { path: '/' });
 | 
						|
        this.route('method', { path: '/:path' }, function() {
 | 
						|
          this.route('index', { path: '/' });
 | 
						|
          this.route('item', { path: '/item/:item_type' }, function() {
 | 
						|
            this.route('list', { path: '/' });
 | 
						|
            this.route('create');
 | 
						|
            this.route('edit', { path: '/edit/:item_id' });
 | 
						|
            this.route('show', { path: '/show/:item_id' });
 | 
						|
          });
 | 
						|
          this.route('section', { path: '/:section_name' });
 | 
						|
        });
 | 
						|
        this.route('leases', function() {
 | 
						|
          // lookup
 | 
						|
          this.route('index', { path: '/' });
 | 
						|
          // lookup prefix
 | 
						|
          // revoke prefix + revoke force
 | 
						|
          this.route('list-root', { path: '/list/' });
 | 
						|
          this.route('list', { path: '/list/*prefix' });
 | 
						|
          //renew + revoke
 | 
						|
          this.route('show', { path: '/show/*lease_id' });
 | 
						|
        });
 | 
						|
        // the outer identity route handles group and entity items
 | 
						|
        this.route('identity', { path: '/identity/:item_type' }, function() {
 | 
						|
          this.route('index', { path: '/' });
 | 
						|
          this.route('create');
 | 
						|
          this.route('merge');
 | 
						|
          this.route('edit', { path: '/edit/:item_id' });
 | 
						|
          this.route('show', { path: '/:item_id/:section' });
 | 
						|
          this.route('aliases', function() {
 | 
						|
            this.route('index', { path: '/' });
 | 
						|
            this.route('add', { path: '/add/:item_id' });
 | 
						|
            this.route('edit', { path: '/edit/:item_alias_id' });
 | 
						|
            this.route('show', { path: '/:item_alias_id/:section' });
 | 
						|
          });
 | 
						|
        });
 | 
						|
        this.route('control-groups');
 | 
						|
        this.route('control-groups-configure', { path: '/control-groups/configure' });
 | 
						|
        this.route('control-group-accessor', { path: '/control-groups/:accessor' });
 | 
						|
        this.route('namespaces', function() {
 | 
						|
          this.route('index', { path: '/' });
 | 
						|
          this.route('create');
 | 
						|
        });
 | 
						|
      });
 | 
						|
      this.route('secrets', function() {
 | 
						|
        this.route('backends', { path: '/' });
 | 
						|
        this.route('backend', { path: '/:backend' }, function() {
 | 
						|
          this.mount('kmip');
 | 
						|
          this.route('index', { path: '/' });
 | 
						|
          this.route('configuration');
 | 
						|
          // because globs / params can't be empty,
 | 
						|
          // we have to special-case ids of '' with their own routes
 | 
						|
          this.route('list-root', { path: '/list/' });
 | 
						|
          this.route('create-root', { path: '/create/' });
 | 
						|
          this.route('show-root', { path: '/show/' });
 | 
						|
          this.route('edit-root', { path: '/edit/' });
 | 
						|
 | 
						|
          this.route('list', { path: '/list/*secret' });
 | 
						|
          this.route('show', { path: '/show/*secret' });
 | 
						|
          this.route('metadata', { path: '/metadata/*secret' });
 | 
						|
          this.route('edit-metadata', { path: '/edit-metadata/*secret' });
 | 
						|
          this.route('create', { path: '/create/*secret' });
 | 
						|
          this.route('edit', { path: '/edit/*secret' });
 | 
						|
 | 
						|
          this.route('credentials-root', { path: '/credentials/' });
 | 
						|
          this.route('credentials', { path: '/credentials/*secret' });
 | 
						|
 | 
						|
          // kv v2 versions
 | 
						|
          this.route('versions-root', { path: '/versions/' });
 | 
						|
          this.route('versions', { path: '/versions/*secret' });
 | 
						|
 | 
						|
          // ssh sign
 | 
						|
          this.route('sign-root', { path: '/sign/' });
 | 
						|
          this.route('sign', { path: '/sign/*secret' });
 | 
						|
          // transit-specific routes
 | 
						|
          this.route('actions-root', { path: '/actions/' });
 | 
						|
          this.route('actions', { path: '/actions/*secret' });
 | 
						|
          // database specific route
 | 
						|
          this.route('overview');
 | 
						|
        });
 | 
						|
      });
 | 
						|
      this.route('policies', { path: '/policies/:type' }, function() {
 | 
						|
        this.route('index', { path: '/' });
 | 
						|
        this.route('create');
 | 
						|
      });
 | 
						|
      this.route('policy', { path: '/policy/:type' }, function() {
 | 
						|
        this.route('show', { path: '/:policy_name' });
 | 
						|
        this.route('edit', { path: '/:policy_name/edit' });
 | 
						|
      });
 | 
						|
      this.route('replication-dr-promote', function() {
 | 
						|
        this.route('details');
 | 
						|
      });
 | 
						|
      if (config.addRootMounts) {
 | 
						|
        config.addRootMounts.call(this);
 | 
						|
      }
 | 
						|
 | 
						|
      this.route('not-found', { path: '/*path' });
 | 
						|
 | 
						|
      this.route('identity', function() {
 | 
						|
        this.route('oidc-provider', { path: '/oidc/provider/:oidc_name/authorize' });
 | 
						|
      });
 | 
						|
    });
 | 
						|
    this.route('not-found', { path: '/*path' });
 | 
						|
  });
 | 
						|
});
 |