1
|
<!DOCTYPE html>
|
2
|
<html lang="en">
|
3
|
<head>
|
4
|
<meta charset="UTF-8">
|
5
|
<title>X.509 Certificate Management</title>
|
6
|
<link rel="stylesheet" href="/static/css/bootstrap.min.css">
|
7
|
<link href="https://cdn.jsdelivr.net/npm/vue-loading-overlay@3/dist/vue-loading.css" rel="stylesheet">
|
8
|
<link rel="stylesheet" href="/static/css/app.css">
|
9
|
</head>
|
10
|
<body class="p-4">
|
11
|
<div id="certificate-detailed-view-content" class="p-4">
|
12
|
<div v-if="loading">
|
13
|
<loading :active.sync="loading"
|
14
|
:can-cancel="false"
|
15
|
loader="dots"
|
16
|
:is-full-page="true"></loading>
|
17
|
</div>
|
18
|
<div id="404_page" v-if="!loading && error" align="center" v-cloak>
|
19
|
<div class="fof">
|
20
|
<h1>Error 404</h1>
|
21
|
</div>
|
22
|
<a href="/" class="caret-left">Home</a>
|
23
|
</div>
|
24
|
<div v-if="!loading && !error" v-cloak>
|
25
|
<div class="row">
|
26
|
<a href="/static/index.html"><div class="caret-left font-weight-bold ml-2 mb-2">Home</div></a>
|
27
|
</div>
|
28
|
<h1 class="mb-5 text-center">Certificate Detailed View</h1>
|
29
|
<div class="alert alert-success" v-if="successMessage !== ''" role="alert" v-cloak>
|
30
|
{{ successMessage }}
|
31
|
</div>
|
32
|
<div v-if="errorMessage !== ''" class="alert alert-danger" v-cloak role="alert">
|
33
|
{{ errorMessage }}
|
34
|
</div>
|
35
|
<div class="row">
|
36
|
<div class="col-xl-6">
|
37
|
<table class="ml-auto mr-auto mb-4">
|
38
|
<tr>
|
39
|
<td>Status:</td>
|
40
|
<td class="pl-3">
|
41
|
<h5><span class="badge badge-success" v-if="certificate.status == 'valid'">Valid</span></h5>
|
42
|
<h5><span class="badge badge-warning" v-if="certificate.status == 'revoked'">Revoked</span></h5>
|
43
|
<h5><span class="badge badge-danger" v-if="certificate.status == 'expired'">Expired</span></h5>
|
44
|
</td>
|
45
|
</tr>
|
46
|
<tr>
|
47
|
<div class="form-group">
|
48
|
<td><label for="validity_start">Validity start:</label></td>
|
49
|
<td class="pl-3">
|
50
|
<input :value="startDate" type="text" id="validity_start" name="validity_start" class="form-control" disabled>
|
51
|
</td>
|
52
|
</div>
|
53
|
</tr>
|
54
|
<tr>
|
55
|
<div class="form-group">
|
56
|
<td><label for="validity_end">Validity end:</label></td>
|
57
|
<td class="pl-3">
|
58
|
<input :value="endDate" type="text" id="validity_end" name="validity_end" class="form-control" disabled>
|
59
|
</td>
|
60
|
</div>
|
61
|
</tr>
|
62
|
<tr>
|
63
|
<td colspan="2"><h5>Subject</h5></td>
|
64
|
</tr>
|
65
|
<tr>
|
66
|
<div class="form-group">
|
67
|
<td><label for="subject_C">Country Code:</label></td>
|
68
|
<td class="pl-3">
|
69
|
<input :value="certificate.subject.C" type="text" id="subject_C" name="subject_C" class="form-control" disabled>
|
70
|
</td>
|
71
|
</div>
|
72
|
</tr>
|
73
|
<tr>
|
74
|
<div class="form-group">
|
75
|
<td><label for="subject_ST">Province/State:</label></td>
|
76
|
<td class="pl-3">
|
77
|
<input :value="certificate.subject.ST" type="text" id="subject_ST" name="subject_ST" class="form-control" disabled>
|
78
|
</td>
|
79
|
</div>
|
80
|
</tr>
|
81
|
<tr>
|
82
|
<div class="form-group">
|
83
|
<td><label for="subject_L">Locality:</label></td>
|
84
|
<td class="pl-3">
|
85
|
<input :value="certificate.subject.L" type="text" id="subject_L" name="subject_L" class="form-control" disabled>
|
86
|
</td>
|
87
|
</div>
|
88
|
</tr>
|
89
|
<tr>
|
90
|
<div class="form-group">
|
91
|
<td><label for="subject_CN">Common Name:</label></td>
|
92
|
<td class="pl-3">
|
93
|
<input :value="certificate.subject.CN" type="text" id="subject_CN" name="subject_CN" class="form-control" disabled>
|
94
|
</td>
|
95
|
</div>
|
96
|
</tr>
|
97
|
<tr>
|
98
|
<div class="form-group">
|
99
|
<td><label for="subject_O">Organization:</label></td>
|
100
|
<td class="pl-3">
|
101
|
<input :value="certificate.subject.O" type="text" id="subject_O" name="subject_O" class="form-control" disabled>
|
102
|
</td>
|
103
|
</div>
|
104
|
</tr>
|
105
|
<tr>
|
106
|
<div class="form-group">
|
107
|
<td><label for="subject_OU">Organization Unit:</label></td>
|
108
|
<td class="pl-3">
|
109
|
<input :value="certificate.subject.OU" type="text" id="subject_OU" name="subject_OU" class="form-control" disabled>
|
110
|
</td>
|
111
|
</div>
|
112
|
</tr>
|
113
|
<tr>
|
114
|
<div class="form-group">
|
115
|
<td><label for="subject_emailAddress">Email Address:</label></td>
|
116
|
<td class="pl-3">
|
117
|
<input :value="certificate.subject.emailAddress" type="text" id="subject_emailAddress" name="subject_emailAddress" class="form-control" disabled>
|
118
|
</td>
|
119
|
</div>
|
120
|
</tr>
|
121
|
<tr>
|
122
|
<td>Usage:</td>
|
123
|
<td class="form-check">
|
124
|
<input class="form-check-input" v-model="certificate.usage.CA" type="checkbox" id="isCA" name="isCA" value="CA" disabled>
|
125
|
<label class="form-check-label" for="isCA">CA</label><br>
|
126
|
|
127
|
<input class="form-check-input" v-model="certificate.usage.digitalSignature" type="checkbox" id="isDigitalSignature" name="isDigitalSignature" value="DigitalSignature" disabled>
|
128
|
<label class="form-check-label" for="isDigitalSignature">Digital Signature</label><br>
|
129
|
|
130
|
<input class="form-check-input" v-model="certificate.usage.authentication" type="checkbox" id="isAuthentication" name="isAuthentication" value="Authentication" disabled>
|
131
|
<label class="form-check-label" for="isAuthentication">Authentication</label><br>
|
132
|
|
133
|
<input class="form-check-input" v-model="certificate.usage.SSL" type="checkbox" id="isSSL_TLS" name="isSSL_TLS" value="SSL_TLS" disabled>
|
134
|
<label class="form-check-label" for="isSSL_TLS">SSL/TLS</label><br>
|
135
|
</td>
|
136
|
</tr>
|
137
|
<tr>
|
138
|
<td colspan="2" v-if="certificate.CA != id">
|
139
|
<button v-on:click="onShowIssuer()" class="btn btn-outline-secondary btn-block mt-5" type="button">
|
140
|
<span v-if="!displayIssuer">Show issuer</span>
|
141
|
<span v-if="displayIssuer">Hide issuer</span>
|
142
|
</button>
|
143
|
</td>
|
144
|
</tr>
|
145
|
<div id="issuerCollapse">
|
146
|
<tr v-if="displayIssuer">
|
147
|
<td colspan="2"><h5 class="mt-2">Issuer</h5></td>
|
148
|
</tr>
|
149
|
<tr v-if="displayIssuer" >
|
150
|
<div class="form-group">
|
151
|
<td><label for="subject_C">Country Code:</label></td>
|
152
|
<td class="pl-3">
|
153
|
<input :value="issuer.subject.C" type="text" id="subject_C" name="subject_C" class="form-control" disabled>
|
154
|
</td>
|
155
|
</div>
|
156
|
</tr>
|
157
|
<tr v-if="displayIssuer" >
|
158
|
<div class="form-group">
|
159
|
<td><label for="subject_ST">Province/State:</label></td>
|
160
|
<td class="pl-3">
|
161
|
<input :value="issuer.subject.ST" type="text" id="subject_ST" name="subject_ST" class="form-control" disabled>
|
162
|
</td>
|
163
|
</div>
|
164
|
</tr>
|
165
|
<tr v-if="displayIssuer" >
|
166
|
<div class="form-group">
|
167
|
<td><label for="subject_L">Locality:</label></td>
|
168
|
<td class="pl-3">
|
169
|
<input :value="issuer.subject.L" type="text" id="subject_L" name="subject_L" class="form-control" disabled>
|
170
|
</td>
|
171
|
</div>
|
172
|
</tr>
|
173
|
<tr v-if="displayIssuer" >
|
174
|
<div class="form-group">
|
175
|
<td><label for="subject_CN">Common Name:</label></td>
|
176
|
<td class="pl-3">
|
177
|
<input :value="issuer.subject.CN" type="text" id="subject_CN" name="subject_CN" class="form-control" disabled>
|
178
|
</td>
|
179
|
</div>
|
180
|
</tr>
|
181
|
<tr v-if="displayIssuer" >
|
182
|
<div class="form-group">
|
183
|
<td><label for="subject_O">Organization:</label></td>
|
184
|
<td class="pl-3">
|
185
|
<input :value="issuer.subject.O" type="text" id="subject_O" name="subject_O" class="form-control" disabled>
|
186
|
</td>
|
187
|
</div>
|
188
|
</tr>
|
189
|
<tr v-if="displayIssuer" >
|
190
|
<div class="form-group">
|
191
|
<td><label for="subject_OU">Organization Unit:</label></td>
|
192
|
<td class="pl-3">
|
193
|
<input :value="issuer.subject.OU" type="text" id="subject_OU" name="subject_OU" class="form-control" disabled>
|
194
|
</td>
|
195
|
</div>
|
196
|
</tr>
|
197
|
<tr v-if="displayIssuer" >
|
198
|
<div class="form-group">
|
199
|
<td><label for="subject_emailAddress">Email Address:</label></td>
|
200
|
<td class="pl-3">
|
201
|
<input :value="issuer.subject.emailAddress" type="text" id="subject_emailAddress" name="subject_emailAddress" class="form-control" disabled>
|
202
|
</td>
|
203
|
</div>
|
204
|
</tr>
|
205
|
<tr v-if="displayIssuer" >
|
206
|
<td>Usage:</td>
|
207
|
<td class="form-check">
|
208
|
<input class="form-check-input" v-model="issuer.usage.CA" type="checkbox" id="isCA" name="isCA" value="CA" disabled>
|
209
|
<label class="form-check-label" for="isCA">CA</label><br>
|
210
|
|
211
|
<input class="form-check-input" v-model="issuer.usage.digitalSignature" type="checkbox" id="isDigitalSignature" name="isDigitalSignature" value="DigitalSignature" disabled>
|
212
|
<label class="form-check-label" for="isDigitalSignature">Digital Signature</label><br>
|
213
|
|
214
|
<input class="form-check-input" v-model="issuer.usage.authentication" type="checkbox" id="isAuthentication" name="isAuthentication" value="Authentication" disabled>
|
215
|
<label class="form-check-label" for="isAuthentication">Authentication</label><br>
|
216
|
|
217
|
<input class="form-check-input" v-model="issuer.usage.SSL" type="checkbox" id="isSSL_TLS" name="isSSL_TLS" value="SSL_TLS" disabled>
|
218
|
<label class="form-check-label" for="isSSL_TLS">SSL/TLS</label><br>
|
219
|
</td>
|
220
|
</tr>
|
221
|
</div>
|
222
|
</table>
|
223
|
</div>
|
224
|
<div class="col-xl-5">
|
225
|
<div class="row table-responsive">
|
226
|
<table class="table">
|
227
|
<thead class="thead-dark">
|
228
|
<tr>
|
229
|
<th colspan="4" class="text-center">Manage certificate</th>
|
230
|
</tr>
|
231
|
</thead>
|
232
|
<tbody>
|
233
|
<tr class="d-flex">
|
234
|
<td style="width: 30%" class="font-weight-bold">Certificate download:</td>
|
235
|
<td><button v-on:click="onCertificateDownload()" class="btn btn-primary btn-sm certificate-control" href="">Certificate</button></td>
|
236
|
<td><button v-on:click="onChainDownload()" class="btn btn-primary btn-sm certificate-control" href="">Chain of trust</button></td>
|
237
|
<td><button v-on:click="onRootDownload()" class="btn btn-primary btn-sm certificate-control" href="">Root</button></td>
|
238
|
</tr>
|
239
|
<tr class="d-flex">
|
240
|
<td style="width: 30%" class="font-weight-bold">Key download:</td>
|
241
|
<td><button v-on:click="onPublicKeyDownload()" class="btn btn-success btn-sm certificate-control" href="">Public key</button></td>
|
242
|
<td><button v-on:click="onPrivateKeyDownload()" class="btn btn-success btn-sm certificate-control" href="">Private key</button></td>
|
243
|
<td> </td>
|
244
|
</tr>
|
245
|
<tr class="d-flex">
|
246
|
<td style="width: 30%" class="font-weight-bold">Actions:</td>
|
247
|
<td><button data-toggle="modal" data-target="#deleteModal" class="btn btn-danger btn-sm certificate-control" href="">Delete</button></td>
|
248
|
<td><button data-toggle="modal" data-target="#revokeModal" class="btn btn-warning btn-sm certificate-control" href="">Revoke</button></td>
|
249
|
<td> </td>
|
250
|
</tr>
|
251
|
<tr class="d-flex">
|
252
|
<td style="width: 30%" class="font-weight-bold">Endpoints:</td>
|
253
|
<td><a class="certificate-control font-weight-bold" :href="crlEndpoint">CRL</a></td>
|
254
|
<td><a class="certificate-control font-weight-bold" :href="ocspEndpoint">OCSP</a></td>
|
255
|
<td> </td>
|
256
|
</tr>
|
257
|
<tr class="d-flex" v-if="id != certificate.CA">
|
258
|
<td style="width: 30%" class="font-weight-bold">Issuer:</td>
|
259
|
<td><a class="certificate-control font-weight-bold" :href="issuerURL">show details</a></td>
|
260
|
<td> </td>
|
261
|
<td> </td>
|
262
|
</tr>
|
263
|
</tbody>
|
264
|
</table>
|
265
|
</div>
|
266
|
<div class="row table-responsive">
|
267
|
<table class="table table-striped table-hover">
|
268
|
<thead class="thead-dark text-center">
|
269
|
<tr>
|
270
|
<th scope="col" colspan="2">Issued Certificates</th>
|
271
|
</tr>
|
272
|
<tr>
|
273
|
<th class="w-65" scope="col">Common Name</th>
|
274
|
<th class="w-35" scope="col">Type</th>
|
275
|
</tr>
|
276
|
</thead>
|
277
|
<tbody>
|
278
|
<tr class="text-center font-italic">
|
279
|
<td v-if="issuedCertificates.length == 0" colspan="2">No issued certificates</td>
|
280
|
</tr>
|
281
|
<tr is="issued-by-list-item"
|
282
|
v-for="certificate in issuedCertificates"
|
283
|
v-bind:certificate="certificate"
|
284
|
v-bind:key="certificate.id">
|
285
|
</tr>
|
286
|
</tbody>
|
287
|
</table>
|
288
|
</div>
|
289
|
</div>
|
290
|
</div>
|
291
|
</div>
|
292
|
<div id="revokeModal" class="modal" tabindex="-1" role="dialog">
|
293
|
<div class="modal-dialog" role="document">
|
294
|
<div class="modal-content">
|
295
|
<div class="modal-header">
|
296
|
<h5 class="modal-title">Revoke certificate</h5>
|
297
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
298
|
<span aria-hidden="true">×</span>
|
299
|
</button>
|
300
|
</div>
|
301
|
<div class="modal-body">
|
302
|
<p>Do you really want to revoke certificate {{ certificate.subject.CN }}?</p>
|
303
|
<div class="form-group">
|
304
|
<label for="reasonSelect">Reason: </label>
|
305
|
<select v-model="revocationReason" class="form-control" id="reasonSelect">
|
306
|
<option value="unspecified">unspecified</option>
|
307
|
<option value="keyCompromise">keyCompromise</option>
|
308
|
<option value="CACompromise">CACompromise</option>
|
309
|
<option value="affiliationChanged">affiliationChanged</option>
|
310
|
<option value="superseded">superseded</option>
|
311
|
<option value="cessationOfOperation">cessationOfOperation</option>
|
312
|
<option value="certificateHold">certificateHold</option>
|
313
|
<option value="removeFromCRL">removeFromCRL</option>
|
314
|
</select>
|
315
|
</div>
|
316
|
</div>
|
317
|
<div class="modal-footer">
|
318
|
<button type="button" v-on:click="onRevoke()" class="btn btn-warning" data-dismiss="modal">Revoke</button>
|
319
|
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
|
320
|
</div>
|
321
|
</div>
|
322
|
</div>
|
323
|
</div>
|
324
|
<div id="deleteModal" class="modal" tabindex="-1" role="dialog">
|
325
|
<div class="modal-dialog" role="document">
|
326
|
<div class="modal-content">
|
327
|
<div class="modal-header">
|
328
|
<h5 class="modal-title">Delete certificate</h5>
|
329
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
330
|
<span aria-hidden="true">×</span>
|
331
|
</button>
|
332
|
</div>
|
333
|
<div class="modal-body">
|
334
|
<p>Do you really want to delete certificate {{ certificate.subject.CN }}?</p>
|
335
|
</div>
|
336
|
<div class="modal-footer">
|
337
|
<button type="button" v-on:click="onDelete()" class="btn btn-danger" data-dismiss="modal">Delete</button>
|
338
|
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
|
339
|
</div>
|
340
|
</div>
|
341
|
</div>
|
342
|
</div>
|
343
|
</div>
|
344
|
|
345
|
<script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
|
346
|
<script src="https://cdn.jsdelivr.net/npm/vue-loading-overlay@3"></script>
|
347
|
<script src="/static/js/jquery-3.6.0.min.js"></script>
|
348
|
<script src="/static/js/bootstrap.bundle.min.js"></script>
|
349
|
<script src="/static/js/axios.min.js"></script>
|
350
|
<script src="/static/js/constants.js"></script>
|
351
|
<script src="/static/js/utilities.js"></script>
|
352
|
<script src="/static/js/components.js"></script>
|
353
|
<script src="/static/js/certificate.js"></script>
|
354
|
|
355
|
</body>
|
356
|
</html>
|