SELECT 'dynamic' AS component, sqlpage.run_sql('shell/shell.sql') AS properties;
-- not including breadcrumbs from sqlpage_aide_navigation
-- not including page title from sqlpage_aide_navigation
SELECT 'title' AS component, (SELECT COALESCE(title, caption)
FROM sqlpage_aide_navigation
WHERE namespace = 'prime' AND path = 'tem/session/openssl.sql/index.sql') as contents;
;
--- Breadcrumb setup
SELECT 'breadcrumb' AS component;
SELECT 'Home' AS title,
sqlpage.environment_variable('SQLPAGE_SITE_PREFIX') || '/' AS link;
SELECT 'Threat Exposure Management' AS title,
sqlpage.environment_variable('SQLPAGE_SITE_PREFIX') || '/tem/index.sql' AS link;
SELECT 'Attack Surface Mapping By Session' AS title,
sqlpage.environment_variable('SQLPAGE_SITE_PREFIX') || '/tem/attack_surface_mapping_session.sql' AS link;
SELECT 'Findings' AS title,
sqlpage.environment_variable('SQLPAGE_SITE_PREFIX') || '/tem/session/finding.sql?session_id=' || $session_id AS link;
SELECT 'SSL/TLS Certificate Metadata' AS title,
'#' AS link;
--- Page title
SELECT 'title' AS component,
'SSL/TLS Certificate Metadata' AS contents;
--- Page description
SELECT 'text' AS component,
'This page displays structured SSL/TLS certificate details extracted from OpenSSL output for a given session.
Each row represents a certificate discovered within the session’s infrastructure, showing subject details, issuer information, and validity periods.
These insights help assess certificate ownership, identify expired or weakly issued certificates, and strengthen the session’s security posture.' AS contents;
--- Table setup
SELECT 'table' AS component,
TRUE AS sort,
TRUE AS search;
SET total_rows = (SELECT COUNT(*) FROM tem_openssl WHERE ur_ingest_session_id = $session_id);
SET limit = COALESCE($limit, 50);
SET offset = COALESCE($offset, 0);
SET total_pages = ($total_rows + $limit - 1) / $limit;
SET current_page = ($offset / $limit) + 1;
SELECT
CASE WHEN tenant_name IS NULL OR trim(tenant_name) = '' THEN '-' ELSE tenant_name END AS "Tenant",
CASE WHEN common_name IS NULL OR trim(common_name) = '' THEN '-' ELSE common_name END AS "Common Name",
CASE WHEN subject_organization IS NULL OR trim(subject_organization) = '' THEN '-' ELSE subject_organization END AS "Subject Organization",
CASE WHEN issuer_common_name IS NULL OR trim(issuer_common_name) = '' THEN '-' ELSE issuer_common_name END AS "Issuer CN",
CASE WHEN issuer_organization IS NULL OR trim(issuer_organization) = '' THEN '-' ELSE issuer_organization END AS "Issuer Organization",
CASE WHEN issuer_country IS NULL OR trim(issuer_country) = '' THEN '-' ELSE issuer_country END AS "Issuer Country",
-- Issued Date
CASE
WHEN issued_date IS NULL OR trim(issued_date) = '' THEN '-'
ELSE printf(
'%s %s %s',
trim(substr(replace(replace(issued_date, ' ', ' '), ' ', ' '), 1, 3)),
trim(substr(replace(replace(issued_date, ' ', ' '), ' ', ' '), 5, 2)),
trim(substr(replace(replace(issued_date, ' ', ' '), ' ', ' '), -9, 4))
)
END AS "Issued Date",
-- Expires Date
CASE
WHEN expires_date IS NULL OR trim(expires_date) = '' THEN '-'
ELSE printf(
'%s %s %s',
trim(substr(replace(replace(expires_date, ' ', ' '), ' ', ' '), 1, 3)),
trim(substr(replace(replace(expires_date, ' ', ' '), ' ', ' '), 5, 2)),
trim(substr(replace(replace(expires_date, ' ', ' '), ' ', ' '), -9, 4))
)
END AS "Expires Date"
FROM tem_openssl
WHERE ur_ingest_session_id = $session_id;
SELECT 'text' AS component,
(SELECT CASE WHEN CAST($current_page AS INTEGER) > 1 THEN '[Previous](?limit=' || $limit || '&offset=' || ($offset - $limit) || COALESCE('&session_id=' || replace($session_id, ' ', '%20'), '') || ')' ELSE '' END)
|| ' '
|| '(Page ' || $current_page || ' of ' || $total_pages || ") "
|| (SELECT CASE WHEN CAST($current_page AS INTEGER) < CAST($total_pages AS INTEGER) THEN '[Next](?limit=' || $limit || '&offset=' || ($offset + $limit) || COALESCE('&session_id=' || replace($session_id, ' ', '%20'), '') || ')' ELSE '' END)
AS contents_md
;
;