Servidor Linux

circle-info

Esta función requiere la versión 2.3.689 o superior.

circle-exclamation

Mientras que los otros casos de uso de SCEPman proporcionan la capacidad de autenticar interactivamente a un usuario para luego permitirle solo inscribir certificados de usuario para su cuenta o sus dispositivos, es posible que desee poder inscribir certificados de forma no interactiva para sujetos arbitrarios.

Para lograr esto, podemos autenticar un service principal y permitir que aproveche la API REST de inscripción de SCEPman.

Requisitos previos

Consulte el artículo de inscripción de la API sobre cómo crear un service principal que pueda usarse para la autenticación:

Inscripción mediante APIchevron-right

Módulo de PowerShell SCEPmanClient

Solicitudes iniciales

Puede usar el módulo SCEPmanClient de PowerShell para solicitar certificados en su servidor Linux:

$Parameters = @{
    'Url'              = 'scepman.contoso.com'
    'ClientId'         = '569fbf51-aa63-4b5c-8b26-ebbcfcde2715'
    'TenantId'         = '8aa3123d-e76c-42e2-ba3c-190cabbec531'
    'ClientSecret'     = 'csa8Q~aVaWCLZTzswIBGvhxUiEvhptuqEyJugb70'
    'Subject'          = 'CN=LinuxServer'
    'IP'               = '10.22.11.8'
    'ExtendedKeyUsage' = 'ServerAuth'
    'SaveToFolder'     = '/etc/ssl/scepman'
    'IncludeRootCA'    = $true
}

New-SCEPmanCertificate @Parameters

Renovación de certificados

También puedes usar el módulo de PowerShell para renovar certificados ya existentes. Esto también evitará la necesidad de usar un principal de servicio para la autenticación:

Script de inscripción y renovación

Si el módulo de PowerShell no es una opción para ti, el enrollrenewcertificate.sharrow-up-right script puede usarse para obtener inicialmente un certificado, así como para verificarlo e intentar una renovación en caso de que esté a punto de expirar.

Requisitos previos del cliente

Ejemplo:

1. Comando

Define el comportamiento del script

Para este caso de uso podemos usar las siguientes opciones:

-s para certificado de servidor con detección automática de si se trata de una inscripción inicial o una renovación

-y para la inscripción inicial de un certificado de servidor

-c para enviar una solicitud de firma de certificado existente

Para los casos de uso de autenticación de cliente, consulte:

Cliente Linux no administradochevron-right

2. URL del servicio de aplicación

La URL del servicio de aplicación SCEPman.

Ejemplo: "https://scepman.contoso.net/"

3. Alcance de la API

Este es el URI del ID de la aplicación de la SCEPman-api registro de aplicación en tu entorno.

Ejemplo: "api://a7a1d6c8-51b9-48ec-9ca0-a363dc2c8436"

4. Nombre de archivo del certificado

El nombre de archivo (sin extensión) del certificado que se creará o se leerá para la renovación.

Ejemplo: "myCertificate"

5. Directorio del certificado

El directorio en el que se creará el certificado o se intentará renovar.

Ejemplo: ~/certs/

8. Umbral de renovación

La cantidad de días que deben quedar para que venza el certificado para que el script comience el proceso de renovación.

Ejemplo: 30

Parámetros adicionales para certificados de servidor:

9. Id de cliente del service principal

El Id de la aplicación (cliente) del registro de la aplicación con la que queremos autenticarnos.

10. Secreto de cliente del service principal

El secreto de cliente creado del registro de la aplicación con la que queremos autenticarnos.

11. Id de inquilino del service principal

El id de inquilino de nuestro registro de aplicación.

12. Asunto del certificado

El asunto con el que desea inscribir el certificado.

Formato: /CN=SubjectName,O=Organization

13. Extensión del certificado

Esto se agregará como nombre alternativo del sujeto

Ejemplo: DNS:webserver.contoso.com

Ejemplo de uso para la firma de CSR (-c command)

Consideraciones

  • Este script no cifra las claves generadas (esto requiere la introducción de una frase de contraseña, por lo que se ha omitido el cifrado para permitir la renovación automática).

  • Si estás renovando certificados protegidos con frase de contraseña de Certificate Master, deberás introducir esta frase de contraseña para poder renovarlos.

Configurar la renovación automática

Cuando se ejecuta el script bash anterior y detecta que un certificado ya ha sido inscrito, renovará el certificado (si está cerca de expirar) usando mTLS. Si el script se ejecuta regularmente, esto garantizará que el certificado se renueve cuando se acerque a su vencimiento. Puedes configurar un cronjob para lograr esto. El siguiente comando es un ejemplo de cómo podría hacerse. Configurará un cronjob para ejecutar el comando diariamente (si el sistema está encendido) y un cronjob para ejecutar el comando al reiniciar.

Dado que los comandos ejecutados por Cron no necesariamente se ejecutarán desde el directorio en el que se encuentran el script/los certificados, es importante proporcionar las rutas absolutas al script/a los certificados.

Última actualización

¿Te fue útil?