mirror of https://github.com/hashicorp/consul
Hide the hcp link banner behind an env variable (#20392)
parent
9f90060b0f
commit
da42f7a00b
|
@ -3,17 +3,19 @@
|
||||||
* SPDX-License-Identifier: BUSL-1.1
|
* SPDX-License-Identifier: BUSL-1.1
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import Service from '@ember/service';
|
import Service, { inject as service } from '@ember/service';
|
||||||
import { tracked } from '@glimmer/tracking';
|
import { tracked } from '@glimmer/tracking';
|
||||||
|
|
||||||
const LOCAL_STORAGE_KEY = 'consul:hideHcpLinkBanner';
|
const LOCAL_STORAGE_KEY = 'consul:hideHcpLinkBanner';
|
||||||
|
|
||||||
export default class HcpLinkStatus extends Service {
|
export default class HcpLinkStatus extends Service {
|
||||||
|
@service('env') env;
|
||||||
@tracked
|
@tracked
|
||||||
userDismissedBanner = false;
|
userDismissedBanner = false;
|
||||||
|
|
||||||
get shouldDisplayBanner() {
|
get shouldDisplayBanner() {
|
||||||
return !this.userDismissedBanner;
|
const hcpLinkEnabled = this.env.var('CONSUL_HCP_LINK_ENABLED');
|
||||||
|
return !this.userDismissedBanner && hcpLinkEnabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
|
|
|
@ -146,7 +146,7 @@ export default function (config = {}, win = window, doc = document) {
|
||||||
case 'CONSUL_API_PREFIX':
|
case 'CONSUL_API_PREFIX':
|
||||||
// we want API prefix to look like an env var for if we ever change
|
// we want API prefix to look like an env var for if we ever change
|
||||||
// operator config to be an API request, we need this variable before we
|
// operator config to be an API request, we need this variable before we
|
||||||
// make and API request so this specific variable should never be be
|
// make and API request so this specific variable should never be
|
||||||
// retrived via an API request
|
// retrived via an API request
|
||||||
return operatorConfig.APIPrefix;
|
return operatorConfig.APIPrefix;
|
||||||
case 'CONSUL_HCP_URL':
|
case 'CONSUL_HCP_URL':
|
||||||
|
|
|
@ -6,6 +6,7 @@
|
||||||
import { module, test } from 'qunit';
|
import { module, test } from 'qunit';
|
||||||
import { click, visit } from '@ember/test-helpers';
|
import { click, visit } from '@ember/test-helpers';
|
||||||
import { setupApplicationTest } from 'ember-qunit';
|
import { setupApplicationTest } from 'ember-qunit';
|
||||||
|
import { EnvStub } from 'consul-ui/services/env';
|
||||||
|
|
||||||
const bannerSelector = '[data-test-link-to-hcp-banner]';
|
const bannerSelector = '[data-test-link-to-hcp-banner]';
|
||||||
module('Acceptance | link to hcp banner', function (hooks) {
|
module('Acceptance | link to hcp banner', function (hooks) {
|
||||||
|
@ -14,9 +15,14 @@ module('Acceptance | link to hcp banner', function (hooks) {
|
||||||
hooks.beforeEach(function () {
|
hooks.beforeEach(function () {
|
||||||
// clear local storage so we don't have any settings
|
// clear local storage so we don't have any settings
|
||||||
window.localStorage.clear();
|
window.localStorage.clear();
|
||||||
// setupTestEnv(this.owner, {
|
this.owner.register(
|
||||||
// CONSUL_ACLS_ENABLED: true,
|
'service:env',
|
||||||
// });
|
class Stub extends EnvStub {
|
||||||
|
stubEnv = {
|
||||||
|
CONSUL_HCP_LINK_ENABLED: true,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('the banner is initially displayed on services page', async function (assert) {
|
test('the banner is initially displayed on services page', async function (assert) {
|
||||||
|
@ -32,4 +38,17 @@ module('Acceptance | link to hcp banner', function (hooks) {
|
||||||
await visit('/');
|
await visit('/');
|
||||||
assert.dom(bannerSelector).doesNotExist('Banner is still gone after refresh');
|
assert.dom(bannerSelector).doesNotExist('Banner is still gone after refresh');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('the banner is not displayed if the env var is not set', async function (assert) {
|
||||||
|
this.owner.register(
|
||||||
|
'service:env',
|
||||||
|
class Stub extends EnvStub {
|
||||||
|
stubEnv = {};
|
||||||
|
}
|
||||||
|
);
|
||||||
|
// default route is services page so we're good here
|
||||||
|
await visit('/');
|
||||||
|
// Expect the banner to be visible by default
|
||||||
|
assert.dom(bannerSelector).doesNotExist('Banner is not here');
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -31,7 +31,7 @@ module('Integration | Component | link-to-hcp-banner', function (hooks) {
|
||||||
'service:env',
|
'service:env',
|
||||||
class Stub extends EnvStub {
|
class Stub extends EnvStub {
|
||||||
stubEnv = {
|
stubEnv = {
|
||||||
isEnterprise: false,
|
CONSUL_HCP_LINK_ENABLED: true,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
Loading…
Reference in New Issue