swirl/views/service/detail.jet
2017-09-26 20:50:09 +08:00

463 lines
16 KiB
Go

{{ extends "../_layouts/default" }}
{{ import "../_modules/detail" }}
{{ block body() }}
<section class="hero is-info">
<div class="hero-body">
<div class="container has-text-centered">
<h1 class="title is-2">
SERVICE
</h1>
<h2 class="subtitle is-5">
Services are the definitions of tasks to run on a swarm.
</h2>
</div>
</div>
</section>
<div class="container">
<nav class="breadcrumb has-succeeds-separator is-small is-marginless" aria-label="breadcrumbs">
<ul>
<li><a href="/">Dashboard</a></li>
<li><a href="/service/">Services</a></li>
<li class="is-active"><a>Detail</a></li>
</ul>
</nav>
</div>
<section class="hero is-small is-light">
<div class="hero-body">
<div class="container">
<h2 class="title is-2">
{{ .Service.Spec.Name }}
</h2>
</div>
</div>
</section>
<nav class="navbar has-shadow">
<div class="container">
<div class="navbar-brand">
<a class="navbar-item is-tab is-active" href="/service/{{.Service.Spec.Name}}/detail">Detail</a>
<a class="navbar-item is-tab" href="/service/{{.Service.Spec.Name}}/raw">Raw</a>
<a class="navbar-item is-tab" href="/service/{{.Service.Spec.Name}}/edit">Edit</a>
</div>
</div>
</nav>
<section class="section">
<div class="container">
<div class="message is-primary">
<div class="message-body">
<dl class="is-horizontal is-marginless">
<dt class="has-text-left">ID</dt>
<dd>{{ .Service.ID }}</dd>
<dt class="has-text-left">Image</dt>
<dd>{{ .Service.Spec.TaskTemplate.ContainerSpec.Image }}</dd>
<dt class="has-text-left">Mode</dt>
<dd>
<div class="tags has-addons">
<span class="tag is-info">{{if .Service.Spec.Mode.Replicated}}replicated{{else}}global{{end}}</span>
{{if .Service.Spec.Mode.Replicated}}
<span class="tag is-success">{{.Service.Replicas}}</span>
{{end}}
</div>
</dd>
{{ if .Service.Spec.TaskTemplate.ContainerSpec.Command }}
<dt class="has-text-left">Command</dt>
<dd>{{ json(.Service.Spec.TaskTemplate.ContainerSpec.Command) }}</dd>
{{ end }}
{{ if .Service.Spec.TaskTemplate.ContainerSpec.Args }}
<dt class="has-text-left">Args</dt>
<dd>{{ json(.Service.Spec.TaskTemplate.ContainerSpec.Args) }}</dd>
{{ end }}
{{ if .Service.Spec.TaskTemplate.ContainerSpec.Dir }}
<dt class="has-text-left">Work directory</dt>
<dd>{{ .Service.Spec.TaskTemplate.ContainerSpec.Dir }}</dd>
{{ end }}
{{ if .Service.Spec.TaskTemplate.ContainerSpec.User }}
<dt class="has-text-left">User</dt>
<dd>{{ .Service.Spec.TaskTemplate.ContainerSpec.User }}</dd>
{{ end }}
<dt class="has-text-left">Created at</dt>
<dd>{{ time(.Service.CreatedAt) }}</dd>
<dt class="has-text-left">Updated at</dt>
<dd>{{ time(.Service.UpdatedAt) }}</dd>
</dl>
</div>
</div>
{{if .Service.Endpoint.VirtualIPs}}
<div class="block">
<div class="block-header">
<p>Networks</p>
</div>
<div class="block-body is-paddingless">
<table class="table is-bordered is-narrow is-fullwidth is-marginless">
<thead>
<tr>
<th>Name</th>
<th>ID</th>
<th>Address</th>
</tr>
</thead>
<tbody>
{{range .Service.Networks}}
<tr>
<td><a href="/network/{{.Name}}/detail">{{.Name}}</a></td>
<td>{{.ID}}</td>
<td>{{.Address}}</td>
</tr>
{{end}}
</tbody>
</table>
</div>
</div>
{{end}}
{{ yield tags(title="Environment variables", tags=.Service.Env) }}
{{ yield tags(title="Service labels", tags=.Service.Spec.Annotations.Labels) }}
{{ yield tags(title="Container labels", tags=.Service.Spec.TaskTemplate.ContainerSpec.Labels) }}
{{if .Service.Spec.TaskTemplate.ContainerSpec.Mounts}}
<div class="block">
<div class="block-header">
<p>Mounts</p>
</div>
<div class="block-body is-paddingless">
<table class="table is-bordered is-striped is-narrow is-fullwidth is-marginless">
<thead>
<tr>
<th>Type</th>
<th>Source</th>
<th>Target</th>
<th>Read only</th>
</tr>
</thead>
<tbody>
{{range .Service.Spec.TaskTemplate.ContainerSpec.Mounts}}
<tr>
<td>{{.Type}}</td>
<td>{{.Source}}</td>
<td>{{.Target}}</td>
<td>{{.ReadOnly ? "Yes" : "No"}}</td>
</tr>
{{end}}
</tbody>
</table>
</div>
</div>
{{end}}
<div class="tabs is-toggle is-fullwidth is-marginless" data-target="tab-content">
<ul>
<li class="is-active">
<a>
<span>Ports</span>
</a>
</li>
<li>
<a>
<span>Configurations</span>
</a>
</li>
<li>
<a>
<span>Resources</span>
</a>
</li>
<li>
<a>
<span>Placement</span>
</a>
</li>
<li>
<a>
<span>Schedule policy</span>
</a>
</li>
<li>
<a>
<span>Log driver</span>
</a>
</li>
</ul>
</div>
<div id="tab-content" class="tabs-content has-no-top-border">
<div>
<dl class="is-horizontal1 is-marginless">
<dt class="has-text-left">Resolution mode</dt>
<dd>{{ .Service.Endpoint.Spec.Mode }}</dd>
<dt class="has-text-left">Port config</dt>
<dd>
<table class="table is-bordered is-narrow is-fullwidth is-marginless">
<thead>
<tr>
<th>Host</th>
<th>Container</th>
<th>Protocol</th>
<th>Mode</th>
</tr>
</thead>
<tbody>
{{range i, p := .Service.Endpoint.Spec.Ports}}
<tr>
<td>{{p.PublishedPort}}</td>
<td>{{p.TargetPort}}</td>
<td>{{p.Protocol}}</td>
<td>{{p.PublishMode}}</td>
</tr>
{{end}}
</tbody>
</table>
</dd>
</dl>
</div>
<div style="display: none">
{{ if .Service.Spec.TaskTemplate.ContainerSpec.Secrets }}
<div class="field">
<p class="lead is-5">Secrets</p>
<table class="table is-bordered is-narrow is-fullwidth is-marginless">
<thead>
<tr>
<th>Name</th>
<th>File name</th>
<th>UID</th>
<th>GID</th>
<th>Mode</th>
</tr>
</thead>
<tbody>
{{ range .Service.Spec.TaskTemplate.ContainerSpec.Secrets }}
<tr>
<td>{{ .SecretName }}</td>
<td>{{ .File.Name }}</td>
<td>{{ .File.UID }}</td>
<td>{{ .File.GID }}</td>
<td>{{ .File.Mode }}</td>
</tr>
{{ end }}
</tbody>
</table>
</div>
{{ end }}
{{ if .Service.Spec.TaskTemplate.ContainerSpec.Configs }}
<div class="field">
<p class="lead is-5">Configs</p>
<table class="table is-bordered is-narrow is-fullwidth is-marginless">
<thead>
<tr>
<th>Name</th>
<th>File name</th>
<th>UID</th>
<th>GID</th>
<th>Mode</th>
</tr>
</thead>
<tbody>
{{ range .Service.Spec.TaskTemplate.ContainerSpec.Configs }}
<tr>
<td>{{ .ConfigName }}</td>
<td>{{ .File.Name }}</td>
<td>{{ .File.UID }}</td>
<td>{{ .File.GID }}</td>
<td>{{ .File.Mode }}</td>
</tr>
{{ end }}
</tbody>
</table>
</div>
{{ end }}
</div>
<div style="display: none">
{{ if .Service.Spec.TaskTemplate.Resources }}
<div class="columns">
<div class="column">
<p class="lead is-5">Limits</p>
{{ if .Service.Spec.TaskTemplate.Resources.Limits }}
<dl class="is-horizontal is-marginless">
<dt class="has-text-left">CPU</dt>
<dd>{{ .Service.Spec.TaskTemplate.Resources.Limits.NanoCPUs / 1e9 }}</dd>
<dt class="has-text-left">Memory</dt>
<dd>{{ .Service.Spec.TaskTemplate.Resources.Limits.MemoryBytes / 1024 / 1024 }}M</dd>
</dl>
{{ end }}
</div>
<div class="is-divider-vertical" data-content=""></div>
<div class="column">
<p class="lead is-5">Reservations</p>
{{ if .Service.Spec.TaskTemplate.Resources.Reservations }}
<dl class="is-horizontal is-marginless">
<dt class="has-text-left">CPU</dt>
<dd>{{ .Service.Spec.TaskTemplate.Resources.Reservations.NanoCPUs / 1e9 }}</dd>
<dt class="has-text-left">Memory</dt>
<dd>{{ .Service.Spec.TaskTemplate.Resources.Reservations.MemoryBytes / 1024 / 1024 }}M</dd>
</dl>
{{ end }}
</div>
</div>
{{ end }}
</div>
<div style="display: none">
{{ if .Service.Spec.TaskTemplate.Placement }}
<div class="columns">
<div class="column">
<p class="lead is-5">Constraints</p>
<table class="table is-bordered is-narrow is-fullwidth is-marginless">
<tbody>
{{ range .Service.Spec.TaskTemplate.Placement.Constraints }}
<tr>
<td>{{ . }}</td>
</tr>
{{ end }}
</tbody>
</table>
</div>
<div class="column">
<p class="lead is-5">Preferences</p>
<table class="table is-bordered is-narrow is-fullwidth is-marginless">
<tbody>
{{ range .Service.Spec.TaskTemplate.Placement.Preferences }}
<tr>
<td>{{ .Spread }}</td>
</tr>
{{ end }}
</tbody>
</table>
</div>
</div>
{{ end }}
</div>
<div style="display: none">
<div class="columns">
<div class="column">
<p class="lead is-5">Update</p>
{{ if .Service.Spec.UpdateConfig }}
<dl class="is-horizontal is-marginless">
<dt class="has-text-left">Parallelism</dt>
<dd>{{ .Service.Spec.UpdateConfig.Parallelism }}</dd>
<dt class="has-text-left">Delay</dt>
<dd>{{ .Service.Spec.UpdateConfig.Delay }}</dd>
<dt class="has-text-left">Failure action</dt>
<dd>{{ .Service.Spec.UpdateConfig.FailureAction }}</dd>
<dt class="has-text-left">Order</dt>
<dd>{{ .Service.Spec.UpdateConfig.Order }}</dd>
</dl>
{{ end }}
</div>
<div class="is-divider-vertical" data-content=""></div>
<div class="column">
<p class="lead is-5">Rollback</p>
{{ if .Service.Spec.RollbackConfig }}
<dl class="is-horizontal is-marginless">
<dt class="has-text-left">Parallelism</dt>
<dd>{{ .Service.Spec.RollbackConfig.Parallelism }}</dd>
<dt class="has-text-left">Delay</dt>
<dd>{{ .Service.Spec.RollbackConfig.Delay }}</dd>
<dt class="has-text-left">Failure action</dt>
<dd>{{ .Service.Spec.RollbackConfig.FailureAction }}</dd>
<dt class="has-text-left">Order</dt>
<dd>{{ .Service.Spec.RollbackConfig.Order }}</dd>
</dl>
{{ end }}
</div>
<div class="is-divider-vertical" data-content=""></div>
<div class="column">
<p class="lead is-5">Restart</p>
{{ if .Service.Spec.TaskTemplate.RestartPolicy }}
<dl class="is-horizontal is-marginless">
<dt class="has-text-left">Condition</dt>
<dd>{{ .Service.Spec.TaskTemplate.RestartPolicy.Condition }}</dd>
{{ if .Service.Spec.TaskTemplate.RestartPolicy.MaxAttempts }}
<dt class="has-text-left">Max attempts</dt>
<dd>{{ elem(.Service.Spec.TaskTemplate.RestartPolicy.MaxAttempts) }}</dd>
{{ end }}
{{ if .Service.Spec.TaskTemplate.RestartPolicy.Delay }}
<dt class="has-text-left">Delay</dt>
<dd>{{ .Service.Spec.TaskTemplate.RestartPolicy.Delay }}</dd>
{{ end }}
{{ if .Service.Spec.TaskTemplate.RestartPolicy.Window }}
<dt class="has-text-left">Window</dt>
<dd>{{ .Service.Spec.TaskTemplate.RestartPolicy.Window }}</dd>
{{ end }}
</dl>
{{ end }}
</div>
</div>
</div>
<div style="display: none">
{{ if .Service.Spec.TaskTemplate.LogDriver }}
<dl class="is-horizontal is-marginless">
<dt class="has-text-left">Name</dt>
<dd>{{ .Service.Spec.TaskTemplate.LogDriver.Name }}</dd>
<dt class="has-text-left">Options</dt>
<dd>
<table class="table is-bordered is-narrow is-fullwidth is-marginless">
<thead>
<tr>
<th>Name</th>
<th>Value</th>
</tr>
</thead>
<tbody>
{{range k, v := .Service.Spec.TaskTemplate.LogDriver.Options}}
<tr>
<td>{{ k }}</td>
<td>{{ v }}</td>
</tr>
{{end}}
</tbody>
</table>
</dd>
</dl>
{{end}}
</div>
</div>
{{if .Tasks}}
<div class="block">
<div class="block-header">
<p>Tasks</p>
</div>
<div class="block-body is-paddingless">
<table class="table is-bordered is-striped is-narrow is-fullwidth">
<thead>
<tr>
<th>ID</th>
<th>Status</th>
<th>Node</th>
<th>Networks</th>
<th>Updated</th>
</tr>
</thead>
<tbody>
{{range .Tasks}}
<tr>
<td><a href="/task/{{.ID}}/detail">{{.ID}}</a></td>
<td><span class="tag is-{{ .Status.State == "running" ? "success" : (.Status.State == "preparing" ? "warning": "danger") }}">{{.Status.State}}</span></td>
<td>{{ if .NodeName }}<a href="/node/{{.NodeID}}/detail">{{.NodeName}}</a>{{ end }}</td>
<td>
<div class="field is-grouped is-grouped-multiline">
{{ range .NetworksAttachments }}
<div class="control">
<div class="tags has-addons"><span class="tag is-grey">{{ .Network.Spec.Name }}</span><span class="tag is-warning">{{ .Addresses }}</span></div>
</div>
{{ end }}
</div>
</td>
<td>{{time(.UpdatedAt)}}</td>
</tr>
{{end}}
</tbody>
</table>
</div>
</div>
{{end}}
<a href="/service/" class="button is-primary">
<span class="icon"><i class="fa fa-reply"></i></span>
<span>Return</span>
</a>
</div>
</section>
{{ end }}