--- name: inspect_ssl_cert kind: function lang: bash domain: cybersecurity version: "1.0.0" purity: impure signature: "inspect_ssl_cert(host: string) -> void" description: "Inspecciona el certificado SSL/TLS de un host: muestra sujeto, emisor, fechas de validez, días hasta expiración, SANs (Subject Alternative Names), cadena de confianza completa y detecta soporte de versiones inseguras TLS 1.0/1.1." tags: [bash, cybersecurity, ssl, tls, certificate, web, openssl, security, pendiente-usar] uses_functions: [] uses_types: [] returns: [] returns_optional: false error_type: "error_go_core" imports: [] params: - name: host desc: "host a inspeccionar, acepta formato host o host:puerto (por defecto puerto 443), ej: example.com o example.com:8443" output: "imprime detalles del certificado SSL/TLS, días hasta expiración con nivel de alerta, SANs, cadena de confianza y resultado de checks de versiones TLS" tested: false tests: [] test_file_path: "" file_path: "bash/functions/cybersecurity/inspect_ssl_cert.sh" source_repo: "https://gitea-dgg044oo04woo4ggcsws4gk0.organic-machine.com/egutierrez/DevLauncher.git" source_license: "MIT" source_file: "scripts/linux/ciberseguridad/web/ssl_cert_info.sh" --- ## Ejemplo ```bash source bash/functions/cybersecurity/inspect_ssl_cert.sh # Puerto 443 por defecto inspect_ssl_cert example.com # Puerto personalizado inspect_ssl_cert example.com:8443 # API interna inspect_ssl_cert api.internal.example.com:4443 ``` ## Notas Requiere `openssl` y `timeout`. Usa `openssl s_client` con SNI (`-servername`) para soportar virtual hosting. La alerta de expiración se activa a 30 días o menos. La detección de TLS 1.0/1.1 usa flags `-tls1` y `-tls1_1` de openssl s_client — si el servidor acepta la conexión y negocia un cipher, el protocolo inseguro está habilitado. Cada conexión tiene timeout de 10 segundos para evitar cuelgues en hosts sin respuesta.