ui: Add Consul API Gateway as an external source (#11371)

pull/11551/head
Kenia 2021-11-10 16:54:12 -05:00 committed by GitHub
parent 3e486cae86
commit 37de276350
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
18 changed files with 93 additions and 30 deletions

3
.changelog/11371.txt Normal file
View File

@ -0,0 +1,3 @@
```release-note:feature
ui: Adding support of Consul API Gateway as an external source.
```

View File

@ -1,21 +1,46 @@
{{#if @item}} {{#if @item}}
{{#let (service/external-source @item) as |externalSource|}} {{#let (service/external-source @item) as |externalSource|}}
{{#if externalSource}} {{#if (and @withInfo (eq externalSource 'consul-api-gateway'))}}
<span <dl class="tooltip-panel">
data-test-external-source={{externalSource}} <dt>
class="consul-external-source {{externalSource}}" <span
...attributes data-test-external-source={{externalSource}}
> class="consul-external-source {{externalSource}}"
{{#if @label}} ...attributes
{{@label}} >
{{else}} Registered via {{t (concat "common.brand." externalSource)}}
{{#if (eq externalSource 'aws')}} </span>
Registered via {{uppercase externalSource}} </dt>
{{else}} <dd>
Registered via {{capitalize externalSource}} <MenuPanel @position="left" @menu={{false}}>
{{/if}} <BlockSlot @name="header">
{{/if}} API Gateways manage north-south traffic from external services to services in the Datacenter. For more information, read our documentation.
</span> </BlockSlot>
{{/if}} <BlockSlot @name="menu">
<li role="separator">
About {{t (concat "common.brand." externalSource)}}
</li>
<li role="none" class="learn-link">
<a tabindex="-1" role="menuitem" href={{concat (env 'CONSUL_DOCS_LEARN_URL')}} rel="noopener noreferrer" target="_blank">
Learn guides
</a>
</li>
</BlockSlot>
</MenuPanel>
</dd>
</dl>
{{else if externalSource}}
<span
data-test-external-source={{externalSource}}
class="consul-external-source {{externalSource}}"
...attributes
>
{{#if @label}}
{{@label}}
{{else}}
Registered via {{t (concat "common.brand." externalSource)}}
{{/if}}
</span>
{{/if}}
{{/let}} {{/let}}
{{/if}} {{/if}}

View File

@ -65,7 +65,7 @@ as |item index|>
{{/if}} {{/if}}
</td> </td>
</BlockSlot> </BlockSlot>
{{#if (or (can "write intention" item=item) (can "view CRD intention" item=item))}} {{#if (and (or (can "write intention" item=item) (can "view CRD intention" item=item)) (not-eq item.Meta.external-source 'consul-api-gateway'))}}
<BlockSlot @name="actions" as |index change checked|> <BlockSlot @name="actions" as |index change checked|>
<PopoverMenu <PopoverMenu
@expanded={{if (eq checked index) true false}} @expanded={{if (eq checked index) true false}}

View File

@ -29,7 +29,8 @@ span.policy-service-identity::before {
%pill.nomad::before { %pill.nomad::before {
@extend %with-logo-nomad-color-icon, %as-pseudo; @extend %with-logo-nomad-color-icon, %as-pseudo;
} }
%pill.consul::before { %pill.consul::before,
%pill.consul-api-gateway::before {
@extend %with-logo-consul-color-icon, %as-pseudo; @extend %with-logo-consul-color-icon, %as-pseudo;
} }
%pill.vault::before { %pill.vault::before {

View File

@ -5,7 +5,7 @@
display: block; display: block;
} }
%popover-menu-panel { %popover-menu-panel {
width: 192px; min-width: 192px;
} }
%popover-menu-panel:not(.above) { %popover-menu-panel:not(.above) {
top: 38px; top: 38px;

View File

@ -55,12 +55,16 @@
%popover-select .oidc button::before { %popover-select .oidc button::before {
@extend %with-logo-oidc-color-icon, %as-pseudo; @extend %with-logo-oidc-color-icon, %as-pseudo;
} }
%popover-select .consul button::before { %popover-select .consul button::before,
%popover-select .consul-api-gateway button::before {
@extend %with-logo-consul-color-icon, %as-pseudo; @extend %with-logo-consul-color-icon, %as-pseudo;
} }
%popover-select .nomad button::before { %popover-select .nomad button::before {
@extend %with-logo-nomad-color-icon, %as-pseudo; @extend %with-logo-nomad-color-icon, %as-pseudo;
} }
%popover-select .vault button::before {
@extend %with-logo-vault-color-icon, %as-pseudo;
}
%popover-select .terraform button::before { %popover-select .terraform button::before {
@extend %with-logo-terraform-color-icon, %as-pseudo; @extend %with-logo-terraform-color-icon, %as-pseudo;
} }

View File

@ -48,6 +48,7 @@
<div class="metrics-header"> <div class="metrics-header">
{{@service.Service.Service}} {{@service.Service.Service}}
</div> </div>
{{#if (not-eq @service.Service.Meta.external-source 'consul-api-gateway')}}
{{#if @hasMetricsProvider}} {{#if @hasMetricsProvider}}
<TopologyMetrics::Series <TopologyMetrics::Series
@nspace={{or @service.Service.Namespace 'default'}} @nspace={{or @service.Service.Namespace 'default'}}
@ -76,6 +77,7 @@
<a class="config-link" href="{{env 'CONSUL_DOCS_URL'}}/connect/observability/ui-visualization" target="_blank" rel="noopener noreferrer">Configure dashboard</a> <a class="config-link" href="{{env 'CONSUL_DOCS_URL'}}/connect/observability/ui-visualization" target="_blank" rel="noopener noreferrer">Configure dashboard</a>
{{/if}} {{/if}}
</div> </div>
{{/if}}
</div> </div>
<div id="downstream-lines"> <div id="downstream-lines">
<TopologyMetrics::DownLines <TopologyMetrics::DownLines

View File

@ -7,7 +7,12 @@ export function serviceExternalSource(params, hash) {
source = get(params[0], 'Meta.external-source'); source = get(params[0], 'Meta.external-source');
} }
const prefix = typeof hash.prefix === 'undefined' ? '' : hash.prefix; const prefix = typeof hash.prefix === 'undefined' ? '' : hash.prefix;
if (source && ['vault', 'kubernetes', 'terraform', 'nomad', 'consul', 'aws'].includes(source)) { if (
source &&
['consul-api-gateway', 'vault', 'kubernetes', 'terraform', 'nomad', 'consul', 'aws'].includes(
source
)
) {
return `${prefix}${source}`; return `${prefix}${source}`;
} }
return; return;

View File

@ -97,7 +97,7 @@ as |item|}}
<h1> <h1>
<route.Title @title={{item.Service.ID}} /> <route.Title @title={{item.Service.ID}} />
</h1> </h1>
<Consul::ExternalSource @item={{item}} /> <Consul::ExternalSource @item={{item}} @withInfo={{true}} />
<Consul::Kind @item={{item}} @withInfo={{true}} /> <Consul::Kind @item={{item}} @withInfo={{true}} />
{{#if (eq proxy.ServiceProxy.Mode 'transparent')}} {{#if (eq proxy.ServiceProxy.Mode 'transparent')}}
<Consul::TransparentProxy /> <Consul::TransparentProxy />

View File

@ -112,7 +112,7 @@ as |items item dc|}}
<h1> <h1>
<route.Title @title={{item.Service.Service}} /> <route.Title @title={{item.Service.Service}} />
</h1> </h1>
<Consul::ExternalSource @item={{item.Service}} /> <Consul::ExternalSource @item={{item.Service}} @withInfo={{true}} />
<Consul::Kind @item={{item.Service}} @withInfo={{true}} /> <Consul::Kind @item={{item.Service}} @withInfo={{true}} />
</BlockSlot> </BlockSlot>
<BlockSlot @name="nav"> <BlockSlot @name="nav">

View File

@ -96,7 +96,7 @@ ${fake.helpers.randomize([
"Precedence": ${i + 1}, "Precedence": ${i + 1},
${ fake.random.number({min: 1, max: 10}) > 2 ? ` ${ fake.random.number({min: 1, max: 10}) > 2 ? `
"Meta": { "Meta": {
"external-source": "${fake.helpers.randomize(['kubernetes'])}" "external-source": "${fake.helpers.randomize(['kubernetes', 'consul-api-gateway'])}"
}, },
` : `` } ` : `` }
"CreatedAt": "2018-05-21T16:41:27.977155457Z", "CreatedAt": "2018-05-21T16:41:27.977155457Z",

View File

@ -81,7 +81,7 @@ ${fake.helpers.randomize([
"Precedence": ${fake.random.number({min: 1, max: 100})}, "Precedence": ${fake.random.number({min: 1, max: 100})},
${ !legacy && fake.random.number({min: 1, max: 10}) > 2 ? ` ${ !legacy && fake.random.number({min: 1, max: 10}) > 2 ? `
"Meta": { "Meta": {
"external-source": "${fake.helpers.randomize(['kubernetes'])}" "external-source": "${fake.helpers.randomize(['kubernetes', 'consul-api-gateway'])}"
}, },
` : `` } ` : `` }
"CreatedAt": "2018-05-21T16:41:27.977155457Z", "CreatedAt": "2018-05-21T16:41:27.977155457Z",

View File

@ -83,7 +83,7 @@ ${fake.helpers.randomize([
"Precedence": ${fake.random.number({min: 1, max: 100})}, "Precedence": ${fake.random.number({min: 1, max: 100})},
${ !legacy && fake.random.number({min: 1, max: 10}) > 2 ? ` ${ !legacy && fake.random.number({min: 1, max: 10}) > 2 ? `
"Meta": { "Meta": {
"external-source": "${fake.helpers.randomize(['kubernetes'])}" "external-source": "${fake.helpers.randomize(['kubernetes', 'consul-api-gateway'])}"
}, },
` : `` } ` : `` }
"CreatedAt": "2018-05-21T16:41:27.977155457Z", "CreatedAt": "2018-05-21T16:41:27.977155457Z",

View File

@ -81,7 +81,7 @@ ${typeof location.search.partition !== 'undefined' ? `
${ fake.random.number({min: 1, max: 10}) > 2 ? ` ${ fake.random.number({min: 1, max: 10}) > 2 ? `
"Meta": { "Meta": {
"consul-dashboard-url": "${fake.internet.protocol()}://${fake.internet.domainName()}/?id={{Service}}", "consul-dashboard-url": "${fake.internet.protocol()}://${fake.internet.domainName()}/?id={{Service}}",
"external-source": "${fake.helpers.randomize(['vault', 'consul', 'nomad', 'terraform', 'kubernetes', 'aws', ''])}" "external-source": "${fake.helpers.randomize(['consul-api-gateway', 'vault', 'consul', 'nomad', 'terraform', 'kubernetes', 'aws', ''])}"
}, },
` : ` ` : `
"Meta": null, "Meta": null,

View File

@ -60,7 +60,7 @@ return `
], ],
${ fake.random.number({min: 1, max: 10}) > 2 ? ` ${ fake.random.number({min: 1, max: 10}) > 2 ? `
"Meta": { "Meta": {
"external-source": "${fake.helpers.randomize(['consul', 'nomad', 'terraform', 'kubernetes', ''])}" "external-source": "${fake.helpers.randomize(['consul-api-gateway', 'consul', 'nomad', 'terraform', 'kubernetes', ''])}"
}, },
` : `` } ` : `` }
"Address":"", "Address":"",

View File

@ -82,7 +82,7 @@ ${ fake.random.number({min: 1, max: 10}) > 2 ? `
range(fake.random.number({min: 1, max: 1})).map( range(fake.random.number({min: 1, max: 1})).map(
function(item, i) function(item, i)
{ {
return `"${fake.helpers.randomize(['vault', 'nomad', 'terraform', 'kubernetes', 'aws', ''])}"`; return `"${fake.helpers.randomize(['consul-api-gateway', 'vault', 'nomad', 'terraform', 'kubernetes', 'aws', ''])}"`;
} }
) )
} }

View File

@ -48,3 +48,25 @@ Feature: dc / services / show / topology / metrics
service: web service: web
--- ---
And I see the "[data-test-sparkline]" element And I see the "[data-test-sparkline]" element
Scenario: Metrics enabled but serivce source is Consul API Gateway
Given 1 datacenter model with the value "datacenter"
And the local datacenter is "datacenter"
And 1 service model from yaml
---
- Service:
Name: web
Kind: ~
Meta:
external-source: consul-api-gateway
---
And ui_config from yaml
---
metrics_proxy_enabled: true
metrics_provider: 'prometheus'
---
When I visit the service page for yaml
---
dc: datacenter
service: web
---
And I don't see the "[data-test-sparkline]" element

View File

@ -1,5 +1,6 @@
brand: brand:
consul: Consul consul: Consul
consul-api-gateway: Consul API Gateway
terraform: Terraform terraform: Terraform
nomad: Nomad nomad: Nomad
vault: Vault vault: Vault