Habilitar la autenticación multifactor para el acceso SSH

Para mayor seguridad, Adobe Commerce en la infraestructura en la nube proporciona aplicación de autenticación de varios factores (MFA) para administrar los requisitos de autenticación para el acceso SSH a los entornos en la nube.

Cuando MFA está habilitado en un proyecto, todas las cuentas de usuario con acceso SSH requieren un código de autenticación de doble factor (TFA) o un token de API y un certificado SSH para acceder al entorno.

NOTE
MFA no está habilitado en los proyectos de Cloud de manera predeterminada. El propietario de la cuenta para el proyecto de Adobe Commerce en la nube debe enviar un vale de soporte de Adobe Commerce para habilitarlo. Cuando MFA está habilitado, todos los usuarios deben tener habilitada la autenticación de doble factor (TFA) en su cuenta de Adobe Commerce en la infraestructura de la nube para el acceso SSH a los entornos del proyecto.

Certificados para acceso SSH

El MFA permite a los usuarios intercambiar un token de acceso de OAUTH con un certificado SSH de corta duración generado por la API de certificador de Adobe Cloud. Si el usuario tiene la función Administrador o Colaborador, una clave SSH válida y un código TFA o token de API válido, Adobe Commerce en la infraestructura en la nube utiliza estas credenciales para generar el certificado SSH temporal. La caducidad del certificado se establece en una hora, pero se actualiza automáticamente durante la sesión actual.

Después de iniciar sesión en un proyecto con MFA, los usuarios deben usar la CLI magento-cloud para generar el certificado SSH:

magento-cloud ssh-cert:load

El comando ssh-cert:load genera el certificado SSH y lo instala en el agente SSH del usuario local.

Generar automáticamente un certificado al iniciar sesión

Puede configurar su entorno local para que genere el certificado SSH automáticamente al autenticarse en la CLI magento-cloud.

Para agregar la generación automática de certificados SSH a su configuración CLI magento-cloud:

  1. En la estación de trabajo local, cree un archivo con el nombre config.yaml en la carpeta .magento-cloud del directorio particular si no existe.

    code language-bash
    touch ~/.magento-cloud/config.yaml
    
  2. Agregue la siguiente configuración al archivo config.yaml.

    code language-yaml
    api:
       auto_load_ssh_cert: true
    
  3. Utilice la CLI magento-cloud para autenticarse de nuevo:

    Cerrar sesión:

    code language-bash
    magento-cloud logout
    

    Iniciar sesión:

    code language-bash
    magento-cloud login
    

    Siga la respuesta:

    code language-terminal
    Please open the following URL in a browser and log in:
    http://127.0.0.1:5000
    
    Help:
      Leave this command running during login.
      If you need to quit, use Ctrl+C.
    
      To log in using an API token, run: magento-cloud auth:api-token-login
    
    Login information received. Verifying...
    You are logged in.
    
    Generating SSH certificate...
    A new SSH certificate has been generated.
    It will be automatically refreshed when necessary.
    The certificate is included in your SSH configuration: /Users/<user-name>/.ssh/config
    

Conexión a un entorno mediante SSH con TFA

Cuando MFA está habilitado en un proyecto, debe tener TFA habilitado en su cuenta para poder conectarse a un entorno remoto mediante un SSH. Consulte Habilitar TFA.

recommendation-more-help

Requisitos previos:

Para los proyectos habilitados con aplicación MFA, el acceso SSH requiere los siguientes permisos y configuración de cuenta:

Para conectarse mediante SSH con credenciales de cuenta de usuario de TFA:

  1. Inicie sesión en su cuenta.

  2. En la estación de trabajo local, use la CLI magento-cloud para generar el certificado SSH.

    code language-bash
    magento-cloud ssh-cert:load
    

    Respuesta de ejemplo:

    code language-terminal
    Generating SSH certificate...
      Expires at: 2020-07-13T15:28:13-04:00
      Multi-factor authentication: verified
      Mode: interactive
    The certificate will be automatically refreshed when necessary.
    Checking SSH configuration file: /Users/<user-name>/.ssh/config
    Do you want to update the file automatically? [Y/n] Y
    Configuration file updated successfully: /Users/<user-name>/.ssh/config
    
  3. Utilice un SSH para conectarse al entorno remoto.

    code language-bash
    ssh abcdef7uyxabce-master-7rqtwti--mymagento@ssh.us-5.magento.cloud
    
    code language-terminal
     __  __                   _          ___ _             _
    |  \/  |__ _ __ _ ___ _ _| |_ ___   / __| |___ _  _ __| |
    | |\/| / _` / _` / -_) ' \  _/ _ \ | (__| / _ \ || / _` |
    |_|  |_\__,_\__, \___|_||_\__\___/  \___|_\___/\_,_\__,_|
                |___/
    
     Welcome to Magento Cloud.
    
     This is environment master-7rqtwti
     of project abcdef7uyxabce.
    
    web@mymagento.0:~$
    

Administración del código fuente mediante SSH con TFA

Al administrar el código fuente de Adobe Commerce en proyectos de infraestructura en la nube, se utiliza SSH para autenticarse en el repositorio Git del proyecto. Si el proyecto tiene habilitada la aplicación MFA, debe generar un certificado SSH para poder realizar operaciones de línea de comandos usando el repositorio Git.

Para conectarse mediante SSH con credenciales de cuenta de usuario de TFA:

  1. Inicie sesión en su cuenta y realice la autenticación mediante TFA.

    note note
    NOTE
    Si no tiene TFA habilitado en su cuenta, debe habilitarlo. Consulte Habilitar TFA en cuentas en la nube.
  2. En la estación de trabajo local, use la CLI magento-cloud para generar el certificado SSH.

    code language-bash
    magento-cloud ssh-cert:load
    

    Respuesta de ejemplo:

    code language-terminal
    Generating SSH certificate...
      Expires at: 2020-07-13T15:28:13-04:00
      Multi-factor authentication: verified
      Mode: interactive
    The certificate will be automatically refreshed when necessary.
    Checking SSH configuration file: /Users/<user-name>/.ssh/config
    Do you want to update the file automatically? [Y/n] Y
    Configuration file updated successfully: /Users/<user-name>/.ssh/config
    
  3. Clone el repositorio Git para su entorno de proyecto:

    code language-bash
    git clone --branch integration abcdef7uyxabce@git.us-3.magento.cloud:abcdef7uyxabce.git myproject
    

    Respuesta de ejemplo:

    code language-terminal
    Cloning into 'myproject'...
    Connection to git.us-3.magento.cloud port 22 [tcp/ssh] succeeded!
    remote: counting objects: 22, done.
    Receiving objects: 100% (22/22), 82.42 KiB | 16.48 MiB/s, done.
    

Conexión a un entorno mediante SSH con un token de API

Cuando MFA está habilitado en un proyecto, los procesos automatizados que requieren acceso SSH a un entorno de nube requieren un token de API. Puede generar el token desde una cuenta de Adobe Commerce en la infraestructura de la nube con acceso de administrador o colaborador en el proyecto.

La autenticación con un token de API aún requiere la generación de un certificado SSH. Los procesos automatizados también deben automatizar la generación de un certificado SSH.

Requisitos previos:

Para conectarse mediante SSH con una credencial de token de API:

  1. Inicie sesión en el proyecto de Cloud mediante la autenticación de clave de API.

    code language-bash
    magento-cloud auth:api-token
    
  2. Cuando se le solicite, introduzca el valor de un token de API válido.

    code language-terminal
    Please enter an API token:
    >
    
    The API token is valid.
    You are logged in.
    

Ejemplo: script SSH automatizado

Existen dos opciones para almacenar el token de API.

NOTE
Si se almacena un token de API, la CLI de magento-cloud se autentica automáticamente y no es necesario ejecutar el comando magento-cloud login.

Opción 1: cree una variable de entorno para almacenar el token de API

Escriba el token en su bash_profile

echo "export MAGENTO_CLOUD_CLI_TOKEN=<your api token>" >> ~/.bash_profile

Opción 2: agregar el token al archivo config.yaml

  1. En la estación de trabajo local, cree un archivo con el nombre config.yaml en la carpeta .magento-cloud del directorio particular si no existe.

    code language-bash
    touch ~/.magento-cloud/config.yaml
    
  2. Agregue la siguiente configuración al archivo config.yaml.

    code language-yaml
    api:
       token: <your api token>
    

Ejemplo de script bash

#!/bin/bash
magento-cloud ssh-cert:load
ssh abcdef7uyxabce-master-7rqtabc--mymagento@ssh.us-3.magento.cloud "tail -n 10 ~/var/log/cloud.log"

Resolución de problemas

Utilice la siguiente información para resolver errores de solicitudes de conexión SSH debido a errores de autenticación como access requires MFA o permission denied.

La solicitud no proporciona un certificado válido

Si la solicitud no proporciona un certificado válido, aparecerá un mensaje similar al siguiente:

to Hello user-test (UUID: abaacca12-5cd1-4b123-9096-411add578998), you successfully
authenticated, but could not connect to service abcdef7uyxabce-master-7rqtabc--mymagento@ssh.us-3.magento.cloud:>
(reason: access requires MFA)

Intente los siguientes procedimientos de solución de problemas para resolver el problema de conexión:

  • Verifique la configuración de TFA de la cuenta
  • Vuelva a autenticarse y vuelva a cargar el certificado

Para comprobar la configuración y autenticación de TFA:

  1. Inicie sesión en su cuenta.

  2. En el menú superior derecho de la cuenta, haga clic en My Profile.

  3. En la página Mi perfil, haga clic en la ficha Security.

    Si TFA está habilitado, la sección Seguridad proporciona opciones para administrar la configuración de TFA.

  4. Si TFA no está configurado, haga clic en Set up application y siga las instrucciones para habilitarlo. Consulte Habilitar TFA.

  5. Si TFA está configurado, intente autenticarse de nuevo.

Para autenticar y volver a cargar el certificado SSH:

  1. Utilice la CLI magento-cloud para autenticarse de nuevo:

    code language-bash
    magento-cloud logout
    
    code language-bash
    magento-cloud login
    
  2. Vuelva a cargar el certificado SSH:

    code language-bash
    magento-cloud ssh-cert:load
    

Permiso denegado

Si falta la clave SSH o esta no es válida, la solicitud de conexión SSH devolverá un error Permission denied (publickey).

Hello user-test (UUID: abaacca12-5cd1-4b123-9096-411add578998), you successfully authenticated, but could not connect to service oh2wi6klp5ytk-mc-35985-integration-nnulm4a--mymagento (reason: service doesn't exist or you do not have access to it)
oh2wi6klp5ytk-mc-35985-integration-nnulm4a--mymagento@ssh.eu-3.magento.cloud: Permission denied (publickey).

Para solucionar el problema, añada la clave SSH a la sesión actual o actualice el archivo de configuración SSH para cargar las claves SSH automáticamente. Consulte Añadir una clave SSH pública.

No se puede acceder a los proyectos sin MFA

Si se autentica en un proyecto con la autenticación multifactor (MFA) habilitada, podría recibir el siguiente error al conectarse a otros proyectos que no requieran MFA:

ssh abcdef7uyxabce-master-7rqtabc--mymagento@ssh.us-3.magento.cloud

Respuesta de ejemplo:

abcdef7uyxabce-master-7rqtabc--mymagento@ssh.us-3.magento.cloud: Permission denied (publickey).

Durante la generación del certificado SSH, la CLI magento-cloud agrega una clave SSH adicional al entorno local. Esa clave se utiliza de forma predeterminada si la configuración SSH local no incluye la clave SSH para el acceso al proyecto.

Para agregar su clave SSH a la configuración local:

  1. Cree el archivo config si no existe.

    code language-bash
    touch ~/.ssh/config
    
  2. Agregar una configuración de IdentityFile.

    code language-yaml
    Host *
      IdentityFile ~/.ssh/id_rsa
    
NOTE
Puede especificar varias claves SSH añadiendo varias entradas IdentityFile a la configuración.
05f2f56e-ac5d-4931-8cdb-764e60e16f26