summaryrefslogtreecommitdiffstats
path: root/library/X509/CertificatesTable.php
diff options
context:
space:
mode:
Diffstat (limited to 'library/X509/CertificatesTable.php')
-rw-r--r--library/X509/CertificatesTable.php109
1 files changed, 109 insertions, 0 deletions
diff --git a/library/X509/CertificatesTable.php b/library/X509/CertificatesTable.php
new file mode 100644
index 0000000..3900221
--- /dev/null
+++ b/library/X509/CertificatesTable.php
@@ -0,0 +1,109 @@
+<?php
+// Icinga Web 2 X.509 Module | (c) 2018 Icinga GmbH | GPLv2
+
+namespace Icinga\Module\X509;
+
+use Icinga\Web\Url;
+use ipl\Html\Html;
+
+/**
+ * Table widget to display X.509 certificates
+ */
+class CertificatesTable extends DataTable
+{
+ protected $defaultAttributes = [
+ 'class' => 'cert-table common-table table-row-selectable',
+ 'data-base-target' => '_next'
+ ];
+
+ protected function createColumns()
+ {
+ return [
+ 'version' => [
+ 'attributes' => ['class' => 'version-col'],
+ 'renderer' => function ($version) {
+ return Html::tag('div', ['class' => 'badge'], $version);
+ }
+ ],
+
+ 'subject' => mt('x509', 'Certificate'),
+
+ 'ca' => [
+ 'attributes' => ['class' => 'icon-col'],
+ 'renderer' => function ($ca) {
+ if ($ca === 'no') {
+ return null;
+ }
+
+ return Html::tag(
+ 'i',
+ ['class' => 'x509-icon-ca', 'title' => mt('x509', 'Is Certificate Authority')]
+ );
+ }
+ ],
+
+ 'self_signed' => [
+ 'attributes' => ['class' => 'icon-col'],
+ 'renderer' => function ($selfSigned) {
+ if ($selfSigned === 'no') {
+ return null;
+ }
+
+ return Html::tag(
+ 'i',
+ ['class' => 'x509-icon-self-signed', 'title' => mt('x509', 'Is Self-Signed')]
+ );
+ }
+ ],
+
+ 'trusted' => [
+ 'attributes' => ['class' => 'icon-col'],
+ 'renderer' => function ($trusted) {
+ if ($trusted === 'no') {
+ return null;
+ }
+
+ return Html::tag(
+ 'i',
+ ['class' => 'icon icon-thumbs-up', 'title' => mt('x509', 'Is Trusted')]
+ );
+ }
+ ],
+
+ 'issuer' => mt('x509', 'Issuer'),
+
+ 'signature_algo' => [
+ 'label' => mt('x509', 'Signature Algorithm'),
+ 'renderer' => function ($algo, $data) {
+ return "{$data['signature_hash_algo']} with $algo";
+ }
+ ],
+
+ 'pubkey_algo' => [
+ 'label' => mt('x509', 'Public Key'),
+ 'renderer' => function ($algo, $data) {
+ return "$algo {$data['pubkey_bits']} bits";
+ }
+ ],
+
+ 'valid_to' => [
+ 'attributes' => ['class' => 'expiration-col'],
+ 'label' => mt('x509', 'Expiration'),
+ 'renderer' => function ($to, $data) {
+ return new ExpirationWidget($data['valid_from'], $to);
+ }
+ ]
+ ];
+ }
+
+ protected function renderRow($row)
+ {
+ $tr = parent::renderRow($row);
+
+ $url = Url::fromPath('x509/certificate', ['cert' => $row['id']]);
+
+ $tr->getAttributes()->add(['href' => $url->getAbsoluteUrl()]);
+
+ return $tr;
+ }
+}