AD Certificates
Last updated
Last updated
Learn & practice AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE) Learn & practice GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
El Sujeto del certificado denota su propietario.
Una Clave Pública se empareja con una clave privada para vincular el certificado a su legítimo propietario.
El Período de Validez, definido por las fechas NotBefore y NotAfter, marca la duración efectiva del certificado.
Un Número de Serie único, proporcionado por la Autoridad de Certificación (CA), identifica cada certificado.
El Emisor se refiere a la CA que ha emitido el certificado.
SubjectAlternativeName permite nombres adicionales para el sujeto, mejorando la flexibilidad de identificación.
Restricciones Básicas identifican si el certificado es para una CA o una entidad final y definen restricciones de uso.
Usos de Clave Extendidos (EKUs) delinean los propósitos específicos del certificado, como la firma de código o la encriptación de correos electrónicos, a través de Identificadores de Objetos (OIDs).
El Algoritmo de Firma especifica el método para firmar el certificado.
La Firma, creada con la clave privada del emisor, garantiza la autenticidad del certificado.
Nombres Alternativos del Sujeto (SANs) amplían la aplicabilidad de un certificado a múltiples identidades, crucial para servidores con múltiples dominios. Los procesos de emisión seguros son vitales para evitar riesgos de suplantación por parte de atacantes que manipulan la especificación SAN.
AD CS reconoce los certificados de CA en un bosque de AD a través de contenedores designados, cada uno con roles únicos:
El contenedor de Autoridades de Certificación contiene certificados de CA raíz de confianza.
El contenedor de Servicios de Inscripción detalla las CAs Empresariales y sus plantillas de certificados.
El objeto NTAuthCertificates incluye certificados de CA autorizados para la autenticación de AD.
El contenedor de AIA (Acceso a Información de Autoridad) facilita la validación de la cadena de certificados con certificados de CA intermedios y cruzados.
El proceso de solicitud comienza con los clientes encontrando una CA Empresarial.
Se crea un CSR, que contiene una clave pública y otros detalles, después de generar un par de claves pública-privada.
La CA evalúa el CSR contra las plantillas de certificados disponibles, emitiendo el certificado basado en los permisos de la plantilla.
Tras la aprobación, la CA firma el certificado con su clave privada y se lo devuelve al cliente.
Definidas dentro de AD, estas plantillas describen la configuración y permisos para emitir certificados, incluyendo EKUs permitidos y derechos de inscripción o modificación, críticos para gestionar el acceso a los servicios de certificados.
El proceso de inscripción para certificados es iniciado por un administrador que crea una plantilla de certificado, que luego es publicada por una Autoridad de Certificación Empresarial (CA). Esto hace que la plantilla esté disponible para la inscripción del cliente, un paso logrado al agregar el nombre de la plantilla al campo certificatetemplates
de un objeto de Active Directory.
Para que un cliente solicite un certificado, deben otorgarse derechos de inscripción. Estos derechos están definidos por descriptores de seguridad en la plantilla de certificado y en la propia CA Empresarial. Los permisos deben otorgarse en ambas ubicaciones para que una solicitud sea exitosa.
Estos derechos se especifican a través de Entradas de Control de Acceso (ACEs), detallando permisos como:
Derechos de Inscripción de Certificado y AutoInscripción de Certificado, cada uno asociado con GUIDs específicos.
Derechos Extendidos, que permiten todos los permisos extendidos.
ControlTotal/GenericAll, proporcionando control completo sobre la plantilla.
Los derechos de la CA están delineados en su descriptor de seguridad, accesible a través de la consola de gestión de la Autoridad de Certificación. Algunas configuraciones incluso permiten a usuarios con bajos privilegios acceso remoto, lo que podría ser una preocupación de seguridad.
Ciertos controles pueden aplicarse, como:
Aprobación del Gerente: Coloca las solicitudes en un estado pendiente hasta que sean aprobadas por un gerente de certificados.
Agentes de Inscripción y Firmas Autorizadas: Especifican el número de firmas requeridas en un CSR y los OIDs de Política de Aplicación necesarios.
Los certificados se pueden solicitar a través de:
Protocolo de Inscripción de Certificados de Cliente de Windows (MS-WCCE), utilizando interfaces DCOM.
Protocolo Remoto ICertPassage (MS-ICPR), a través de pipes nombrados o TCP/IP.
La interfaz web de inscripción de certificados, con el rol de Inscripción Web de la Autoridad de Certificación instalado.
El Servicio de Inscripción de Certificados (CES), en conjunto con el servicio de Política de Inscripción de Certificados (CEP).
El Servicio de Inscripción de Dispositivos de Red (NDES) para dispositivos de red, utilizando el Protocolo Simple de Inscripción de Certificados (SCEP).
Los usuarios de Windows también pueden solicitar certificados a través de la GUI (certmgr.msc
o certlm.msc
) o herramientas de línea de comandos (certreq.exe
o el comando Get-Certificate
de PowerShell).
Active Directory (AD) admite la autenticación por certificado, utilizando principalmente los protocolos Kerberos y Secure Channel (Schannel).
En el proceso de autenticación de Kerberos, la solicitud de un usuario para un Ticket Granting Ticket (TGT) se firma utilizando la clave privada del certificado del usuario. Esta solicitud pasa por varias validaciones por parte del controlador de dominio, incluyendo la validez, ruta y estado de revocación del certificado. Las validaciones también incluyen verificar que el certificado provenga de una fuente confiable y confirmar la presencia del emisor en el almacén de certificados NTAUTH. Las validaciones exitosas resultan en la emisión de un TGT. El objeto NTAuthCertificates
en AD, se encuentra en:
es central para establecer confianza en la autenticación de certificados.
Schannel facilita conexiones seguras TLS/SSL, donde durante un apretón de manos, el cliente presenta un certificado que, si se valida con éxito, autoriza el acceso. La asignación de un certificado a una cuenta de AD puede involucrar la función S4U2Self de Kerberos o el Nombre Alternativo del Sujeto (SAN) del certificado, entre otros métodos.
Los servicios de certificados de AD se pueden enumerar a través de consultas LDAP, revelando información sobre Autoridades de Certificación (CAs) Empresariales y sus configuraciones. Esto es accesible para cualquier usuario autenticado en el dominio sin privilegios especiales. Herramientas como Certify y Certipy se utilizan para la enumeración y evaluación de vulnerabilidades en entornos de AD CS.
Los comandos para usar estas herramientas incluyen:
Aprende y practica Hacking en AWS:HackTricks Training AWS Red Team Expert (ARTE) Aprende y practica Hacking en GCP: HackTricks Training GCP Red Team Expert (GRTE)