Configurar o apigee-sso para acesso HTTPS

Edge para nuvem privada v4.18.05

Em Instalar e configurar o SSO de borda, descrevemos como instalar e configurar o módulo de SSO do Edge para usar HTTP na porta 9099, conforme especificado pela seguinte propriedade no arquivo de configuração:

SSO_TOMCAT_PROFILE=DEFAULT

Se preferir, defina SSO_TOMCAT_PROFILE como um dos seguintes valores para ativar o acesso HTTPS:

  • SSL_PROXY: configura apigee-sso no modo de proxy, o que significa que você instalou um balanceador de carga na frente do apigee-sso e encerrou o TLS no balanceador de carga. Em seguida, especifique a porta usada em apigee-sso para solicitações do balanceador de carga.
  • SSL_TERMINATION: foi ativado o acesso TLS ao apigee-sso, o módulo SSO do Edge, na porta de sua escolha. É preciso especificar um keystore para esse modo que contenha um certificado assinado por uma CA. Não é possível usar um certificado autoassinado.

É possível ativar o HTTPS no momento em que você instala e configura apigee-sso ou pode ativá-lo mais tarde.

Ativar o acesso HTTPS a apigee-sso usando qualquer um dos modos desativa o acesso HTTP. Ou seja, não é possível acessar apigee-sso usando HTTP e HTTPS ao mesmo tempo.

Ativar o modo SSL_PROXY

No modo SSL_PROXY, o sistema usa um balanceador de carga na frente do módulo SSO de borda e encerra o TLS no balanceador de carga. Na figura a seguir, o balanceador de carga encerra o TLS na porta 443 e, em seguida, encaminha as solicitações para o módulo SSO do Edge na porta 9099:

Nesta configuração, você confia na conexão do balanceador de carga para o módulo SSO de borda, então não é necessário usar TLS. No entanto, as entidades externas, como o IdP SAML, agora precisam acessar o módulo SSO do Edge na porta 443, não na porta desprotegida da 9099.

O motivo para configurar o módulo SSO de borda no modo SSL_PROXY é que ele gera automaticamente URLs de redirecionamento usados externamente pelo IdP como parte do processo de autenticação. Portanto, esses URLs de redirecionamento precisam conter o número da porta externa no balanceador de carga, 443 neste exemplo, e não a porta interna no módulo SSO de borda, 9099.

Observação: não é necessário criar um certificado TLS e uma chave para o modo SSL_PROXY porque a conexão do balanceador de carga com o módulo SSO de borda usa HTTP.

Se quiser configurar o módulo SSO do Edge para o modo SSL_PROXY, siga estas etapas:

  1. Adicione as seguintes definições ao seu arquivo de configuração:
    # Enable SSL_PROXY mode.
    SSO_TOMCAT_PROFILE=SSL_PROXY
    
    # Specify the apigee-sso port, typically between 1025 and 65535.
    # Typically ports 1024 and below require root access by apigee-sso.
    # The default is 9099.
    SSO_TOMCAT_PORT=9099
    
    # Specify the port number on the load balancer for terminating TLS.
    # This port number is necessary for apigee-sso to auto-generate redirect URLs.
    SSO_TOMCAT_PROXY_PORT=443
    SSO_PUBLIC_URL_PORT=443
    
    # Set public access scheme of apigee-sso to https.
    SSO_PUBLIC_URL_SCHEME=https
  2. Configure o módulo SSO do Edge:
    /opt/apigee/apigee-service/bin/apigee-service apigee-sso setup -f configFile
  3. Atualize a configuração do IdP para fazer uma solicitação HTTPS na porta 443 do balanceador de carga para acessar o SSO do Edge. Para mais informações, consulte Configurar o IdP SAML.
  4. Atualize a configuração da IU do Edge para HTTPS definindo as seguintes propriedades no arquivo de configuração:
    SSO_PUBLIC_URL_PORT=443
    SSO_PUBLIC_URL_SCHEME=https

    Em seguida, atualize a IU do Edge:

    /opt/apigee/apigee-service/bin/apigee-service edge-ui configure-sso -f configFile

    Consulte Ativar SAML na interface do Edge para mais informações.

  5. Se você instalou o portal de serviços para desenvolvedores da Apigee (ou simplesmente o portal), atualize-o para usar HTTPS para acessar o SSO do Ede. Para mais informações, consulte Como configurar o portal para usar o SAML para se comunicar com o Edge.

Ativar o modo SSL_TERMINATION

No modo SSL_TERMINATION, é necessário fazer o seguinte:

  • Criou um certificado e uma chave TLS e os armazenou em um arquivo de keystore. Não é possível usar um certificado autoassinado. É preciso gerar um certificado de uma CA.
  • Atualizar as definições de configuração de apigee-sso.

Para criar um arquivo de keystore a partir do seu certificado e chave:

  1. Crie um diretório para o arquivo JKS:
    sudo mkdir -p /opt/apigee/customer/application/apigee-sso/tomcat-ssl/
  2. Mude para o novo diretório:
    cd /opt/apigee/customer/application/apigee-sso/tomcat-ssl/
  3. Crie um arquivo JKS contendo o certificado e a chave. É preciso especificar um keystore para esse modo que contenha um certificado assinado por uma CA. Não é possível usar um certificado autoassinado. Para ver um exemplo de como criar um arquivo JKS, consulte Como configurar TLS/SSL para o Edge local.
  4. Crie o arquivo JKS do usuário "apigee":
    sudo chown -R apigee:apigee /opt/apigee/customer/application/apigee-sso/tomcat-ssl

Para configurar o módulo SSO do Edge:

  1. Adicione as seguintes definições ao seu arquivo de configuração:
    # Enable SSL_TERMINATION mode.
    SSO_TOMCAT_PROFILE=SSL_TERMINATION
    
    # Specify the path to the keystore file.
    SSO_TOMCAT_KEYSTORE_FILEPATH=/opt/apigee/customer/application/apigee-sso/tomcat-ssl/keystore.jks
    
    SSO_TOMCAT_KEYSTORE_ALIAS=sso
    
    # The password specified when you created the keystore.
    SSO_TOMCAT_KEYSTORE_PASSWORD=keystorePassword
    
    # Specify the HTTPS port number between 1025 and 65535.
    # Typically ports 1024 and below require root access by apigee-sso.
    # The default is 9099.
    SSO_TOMCAT_PORT=9443
    SSO_PUBLIC_URL_PORT=9443
    
    # Set public access scheme of apigee-sso to https.
    SSO_PUBLIC_URL_SCHEME=https
  2. Configure o módulo SSO do Edge:
    /opt/apigee/apigee-service/bin/apigee-service apigee-sso setup -f configFile
  3. Atualize a configuração do IdP para fazer uma solicitação HTTPS na porta 9443 do balanceador de carga para acessar o SSO do Edge. Para mais informações, consulte Configurar o IdP SAML.
  4. Atualize a configuração da IU do Edge para HTTPS definindo as seguintes propriedades:
    SSO_PUBLIC_URL_PORT=9443
    SSO_PUBLIC_URL_SCHEME=https

    Consulte Ativar SAML na interface do Edge para mais informações.

  5. Se você instalou o portal de serviços para desenvolvedores, atualize-o para usar HTTPS para acessar o SSO Ede. Para mais informações, consulte Como configurar o portal de serviços para desenvolvedores para usar SAML para se comunicar com o Edge.

Como configurar SSO_TOMCAT_PROXY_PORT ao usar o modo SSL_TERMINATION

Talvez você tenha um balanceador de carga na frente do módulo SSO de borda que encerre o TLS no balanceador de carga, mas também ative o TLS entre o balanceador de carga e o SSO de borda. Na figura acima, para o modo SSL_PROXY, isso significa que a conexão do balanceador de carga com o SSO de borda usa o TLS.

Neste cenário, você configura o TLS no SSO do Edge como fez acima para o modo SSL_TERMINATION. No entanto, se o balanceador de carga usar um número de porta TLS diferente do que o SSO de borda usa para o TLS, você também vai precisar especificar a propriedade SSO_TOMCAT_PROXY_PORT no arquivo de configuração. Exemplo:

  • O balanceador de carga encerra o TLS na porta 443
  • O SSO de borda encerra o TLS na porta 9443

Inclua a seguinte definição no arquivo de configuração:

# Specify the port number on the load balancer for terminating TLS.
# This port number is necessary for apigee-sso to generate redirect URLs.
SSO_TOMCAT_PROXY_PORT=443
SSO_PUBLIC_URL_PORT=443

Configure o IdP e a IU do Edge para fazer solicitações HTTPS na porta 443.