Skip to content

Commit

Permalink
Revert "refact: conditional checks for token secret before fetch (#14134
Browse files Browse the repository at this point in the history
)" (#14381)

This reverts commit b9fec22.
  • Loading branch information
lgfa29 authored Aug 29, 2022
1 parent 61fd943 commit 17cc73d
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 65 deletions.
99 changes: 42 additions & 57 deletions ui/app/services/system.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import Service, { inject as service } from '@ember/service';
import { computed } from '@ember/object';
import { alias } from '@ember/object/computed';
import Ember from 'ember';
import PromiseObject from '../utils/classes/promise-object';
import PromiseArray from '../utils/classes/promise-array';
import { namespace } from '../adapters/application';
Expand All @@ -17,78 +16,64 @@ export default class SystemService extends Service {
@computed('activeRegion')
get leader() {
const token = this.token;
if (token.secret || Ember.testing) {
return PromiseObject.create({
promise: token
.authorizedRequest(`/${namespace}/status/leader`)
.then((res) => res.json())
.then((rpcAddr) => ({ rpcAddr }))
.then((leader) => {
// Dirty self so leader can be used as a dependent key
this.notifyPropertyChange('leader.rpcAddr');
return leader;
}),
});
}
return null;

return PromiseObject.create({
promise: token
.authorizedRequest(`/${namespace}/status/leader`)
.then((res) => res.json())
.then((rpcAddr) => ({ rpcAddr }))
.then((leader) => {
// Dirty self so leader can be used as a dependent key
this.notifyPropertyChange('leader.rpcAddr');
return leader;
}),
});
}

@computed
get agent() {
const token = this.token;

if (token.secret || Ember.testing) {
return PromiseObject.create({
promise: token
.authorizedRawRequest(`/${namespace}/agent/self`)
.then(jsonWithDefault({}))
.then((agent) => {
if (agent?.config?.Version) {
const { Version, VersionPrerelease, VersionMetadata } =
agent.config.Version;
agent.version = Version;
if (VersionPrerelease)
agent.version = `${agent.version}-${VersionPrerelease}`;
if (VersionMetadata)
agent.version = `${agent.version}+${VersionMetadata}`;
}
return agent;
}),
});
}
return null;
return PromiseObject.create({
promise: token
.authorizedRawRequest(`/${namespace}/agent/self`)
.then(jsonWithDefault({}))
.then((agent) => {
if (agent?.config?.Version) {
const { Version, VersionPrerelease, VersionMetadata } =
agent.config.Version;
agent.version = Version;
if (VersionPrerelease)
agent.version = `${agent.version}-${VersionPrerelease}`;
if (VersionMetadata)
agent.version = `${agent.version}+${VersionMetadata}`;
}
return agent;
}),
});
}

@computed
get defaultRegion() {
const token = this.token;

if (token.secret || Ember.testing) {
return PromiseObject.create({
promise: token
.authorizedRawRequest(`/${namespace}/agent/members`)
.then(jsonWithDefault({}))
.then((json) => {
return { region: json.ServerRegion };
}),
});
}
return null;
return PromiseObject.create({
promise: token
.authorizedRawRequest(`/${namespace}/agent/members`)
.then(jsonWithDefault({}))
.then((json) => {
return { region: json.ServerRegion };
}),
});
}

@computed
get regions() {
const token = this.token;

if (token.secret || Ember.testing) {
return PromiseArray.create({
promise: token
.authorizedRawRequest(`/${namespace}/regions`)
.then(jsonWithDefault([])),
});
}

return null;
return PromiseArray.create({
promise: token
.authorizedRawRequest(`/${namespace}/regions`)
.then(jsonWithDefault([])),
});
}

@computed('regions.[]')
Expand Down
11 changes: 3 additions & 8 deletions ui/app/services/token.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ import { computed } from '@ember/object';
import { alias, reads } from '@ember/object/computed';
import { getOwner } from '@ember/application';
import { assign } from '@ember/polyfills';
import Ember from 'ember';
import { task } from 'ember-concurrency';
import queryString from 'query-string';
import fetch from 'nomad-ui/utils/fetch';
Expand Down Expand Up @@ -32,11 +31,9 @@ export default class TokenService extends Service {
@task(function* () {
const TokenAdapter = getOwner(this).lookup('adapter:token');
try {
if (this.secret || Ember.testing) {
var token = yield TokenAdapter.findSelf();
this.secret = token.secret;
return token;
}
var token = yield TokenAdapter.findSelf();
this.secret = token.secret;
return token;
} catch (e) {
const errors = e.errors ? e.errors.mapBy('detail') : [];
if (errors.find((error) => error === 'ACL support disabled')) {
Expand Down Expand Up @@ -90,8 +87,6 @@ export default class TokenService extends Service {
const headers = {};
const token = this.secret;

if (!token && !Ember.testing) return null;

if (token) {
headers['X-Nomad-Token'] = token;
}
Expand Down

0 comments on commit 17cc73d

Please sign in to comment.