Como configurar o TLS para API BaaS

Edge para nuvem privada v. 4.17.01

O TLS (Transport Layer Security, cujo antecessor é o SSL) é a tecnologia de segurança padrão para garantir mensagens seguras e criptografadas no ambiente da API. É possível configurar o TLS no portal da API BaaS e nos nós da pilha de APIs BaaS.

A imagem a seguir mostra um diagrama de implantação típico da API BaaS com um único nó do Portal da BaaS e três nós da pilha da API BaaS.

Os desenvolvedores usam um navegador para fazer solicitações ao Portal. Por padrão, as solicitações usam o protocolo HTTP na porta 9000 do nó do Portal.

Essa implantação inclui um balanceador de carga entre os nós do Portal e da pilha. Nessa configuração, o Portal faz solicitações HTTP para o balanceador de carga, que as encaminha para um dos nós da pilha. Este é o ambiente de implantação recomendado para um sistema de produção.

Opções de configuração de TLS

Ao configurar o TLS para o BaaS de API, você tem várias opções:

  • Configurar o TLS no Portal e no balanceador de carga para os nós da pilha

    Nessa configuração, os desenvolvedores usam o protocolo HTTPS para acessar o Portal, e o Portal em execução no navegador usa o HTTPS para fazer solicitações aos nós da pilha pelo balanceador de carga. O balanceador de carga usa HTTP para acessar os nós da pilha.
  • Configurar o TLS no portal, no balanceador de carga e nos nós da pilha

    Para mais segurança, configure o balanceador de carga para usar o TLS ao acessar os nós da pilha.
  • Configurar o TLS no portal e em um único nó de pilha

    Em um ambiente pequeno, como um de teste ou de desenvolvimento, talvez você tenha apenas um nó de pilha, o que significa que não é necessário incluir um balanceador de carga. Nessa configuração, defina o TLS nos nós do portal e da pilha.
  • Configurar o TLS em um balanceador de carga para o Portal

    Uma opção não mostrada acima é usar um balanceador de carga na frente do nó do Portal. Nessa configuração, é possível configurar o TLS no balanceador de carga e, opcionalmente, na conexão entre o balanceador de carga e o Portal.

Verifique se a porta TLS está aberta

Os procedimentos abaixo configuram o TLS na porta 9000 do Portal padrão e no nó de pilha 8080. No entanto, é possível mudar essa porta, se quiser.

Independentemente da porta usada, é necessário garantir que ela esteja aberta no nó. Por exemplo, use o seguinte comando para abrir a porta 8443:

$ iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 8443 -j ACCEPT --verbose

Como configurar o TLS na pilha de BaaS da API

Por padrão, o TLS está desativado para a pilha API BaaS. Em seguida, acesse a API BaaS por HTTP usando o endereço IP ou o nome DNS do nó da pilha e a porta 8080. Exemplo:

http://stack_IP:8080

Como alternativa, é possível configurar o acesso TLS à API BaaS para que ela possa ser acessada na forma:

https://stack_IP:8080

Neste exemplo, você configura o acesso TLS para usar a porta 8080. No entanto, a porta 8080 não é necessária. Configure a pilha para usar uma porta diferente. O único requisito é que o firewall permita o tráfego pela porta especificada.

A pilha só pode oferecer suporte a um tipo de solicitação (HTTP ou HTTPS) em uma única porta. Portanto, se você configurar o acesso HTTPS na porta 8080, não poderá usar o HTTP para acessar a porta 8080. Se você configurar a pilha para usar a porta 8443 com HTTPS, ela não vai mais detectar a porta 8080.

Use o procedimento a seguir para configurar o acesso TLS à pilha:

  1. Gere o arquivo JKS do keystore que contém a certificação TLS e a chave privada. Para mais informações, consulte Como configurar TLS/SSL para o Edge no local.
    Observação: verifique se a senha no keystore e na chave são as mesmas.
  2. Copie o arquivo JKS do keystore para um diretório no nó da pilha, como /opt/apigee/customer/application. O diretório precisa ser acessível ao usuário "apigee".
  3. Mude a propriedade do arquivo JKS para o usuário "apigee":
    > chown apigee:apigee /opt/apigee/customer/application/keystore.jks

    em que keystore.jks é o nome do arquivo de keystore.
  4. Edite o arquivo /opt/apigee/customer/application/usergrid.properties para definir as propriedades a seguir, incluindo o caminho para o arquivo JKS e a senha no keystore e na chave. Se esse arquivo não existir, crie-o:
    tomcat-server_scheme=https
    tomcat-server_secure=true
    tomcat-server_ssl.enabled=true
    tomcat-server_keystore.type=JKS
    tomcat-server_keystore.file=/opt/apigee/customer/application/keystore.jks
    tomcat-server_keystore.password=password
    tomcat-server_keyalias=keystore_alias
    tomcat-server_clientauth.enabled=false
    tomcat-server_ssl.protocols=TLSv1,TLSv1.1,TLSv1.2
    # Por padrão, o acesso TLS usa a porta 8080.
    # Use essa propriedade para especificar uma porta diferente.
    # tomcat-server_port=8080


    Aviso: o valor de password precisa estar em texto não criptografado. Portanto, proteja usergrid.properties contra acesso não autorizado.

    Use a propriedade tomcat-server_keyalias para especificar o alias do keystore. Você define o alias da chave no momento em que criou a chave. Por exemplo, é possível definir essa opção usando a opção -alias no comando keytool.

    Usar tomcat-server_ssl.protocols para definir os protocolos TLS aceitos pela pilha. Para conferir uma lista de protocolos com suporte do Java 8, consulte http://docs.oracle.com/javase/8/docs/technotes/guides/security/StandardNames.html#jssename.
  5. Configure o nó da pilha:
    > /opt/apigee/apigee-service/bin/apigee-service baas-usergrid configure
  6. Reinicie a pilha BaaS:
    > /opt/apigee/apigee-service/bin/apigee-service baas-usergrid restart
  7. Confirme se o TLS está funcionando executando o comando cURL abaixo no nó da pilha usando HTTPS:
    > curl -k https://localhost:8080/status -v

    Se o TLS estiver configurado corretamente, você verá uma resposta com informações de status.

    Se você configurou o acesso TLS em uma porta diferente da 8080, modifique o comando acima para usar a porta correta.
  8. Repita em todos os nós da pilha.
  9. Se você tiver um balanceador de carga na frente dos nós da pilha, configure o balanceador de carga para fazer solicitações aos nós da pilha por HTTPS. Consulte a documentação do seu balanceador de carga para mais informações.

    Se o portal fizer solicitações diretas para a pilha, configure o portal para acessar a pilha por HTTPS, conforme descrito na próxima seção.
  10. Use o procedimento abaixo em "Configurar nós de pilha do BaaS de API para TLS na pilha ou portal" para garantir que o nó de pilha tenha os URLs TLS corretos ao gerar respostas do usuário.

Como configurar o Portal para acessar a pilha por TLS

O Portal do BaaS em execução em um navegador funciona fazendo chamadas de API para a pilha do BaaS. Se você configurar a pilha BaaS para usar o TLS, também precisará configurar o portal para fazer essas chamadas por HTTPS.

Uma instalação de API BaaS geralmente é configurada para:

  • Usar um balanceador de carga entre os nós do Portal e da pilha

    Configure o balanceador de carga para fazer solicitações aos nós da pilha por HTTPS. Consulte a documentação do balanceador de carga para mais informações.

    Nessa configuração, o Portal pode acessar o balanceador de carga por HTTP ou HTTPS, dependendo de como você o configurou. Se o balanceador de carga usar TLS, use o procedimento abaixo para configurar o Portal para fazer solicitações ao balanceador de carga do HTTPS.
  • O Portal pode fazer solicitações diretas para a pilha

    Configure o Portal para acessar a pilha por HTTPS, conforme descrito abaixo.

Use o procedimento a seguir para configurar o Portal do API BaaS para fazer chamadas de API por HTTPS:

  1. Configure o acesso TLS na pilha BaaS conforme descrito acima ou no balanceador de carga para os nós da pilha, conforme descrito na documentação do balanceador.
  2. Edite /opt/apigee/customer/application/portal.properties para definir a propriedade a seguir. Se esse arquivo não existir, crie-o:
    baas.portal.config.overrideUrl=https://stackIP:port

    Especifique como valor dessa propriedade o endereço IP ou o nome DNS e a porta do nó da pilha de API para uma instalação de nó único, ou do balanceador de carga se você tiver um balanceador de carga na frente dos nós da pilha do BaaS da API.
  3. Configure o nó do Portal:
    > /opt/apigee/apigee-service/bin/apigee-service baas-portal configure
  4. Reinicie o portal usando o comando:
    > /opt/apigee/apigee-service/bin/apigee-service baas-portal restart
  5. Se você usou um certificado autoassinado ao configurar o acesso TLS à pilha acima, talvez seu navegador não permita solicitações à pilha pelo Portal. Se aparecer um erro no navegador informando que o acesso HTTPS à pilha não é permitido, solicite o seguinte URL no navegador e adicione uma exceção de segurança para permitir o acesso:
    https://stackIP:port/status

    Especifique o endereço IP ou o nome DNS e a porta do nó da pilha da API ou do balanceador de carga.

Como configurar o TLS no portal do API BaaS

Por padrão, os usuários acessam o Portal fazendo solicitações HTTP não criptografadas pela porta 9000 no servidor do Portal. É possível configurar o portal para usar HTTPS e criptografar os dados enviados para e do portal.

Por padrão, você acessa o Portal por HTTP usando o endereço IP ou o nome DNS do nó do Portal e a porta 9000. Exemplo:

http://portal_IP:9000

Como alternativa, você pode configurar o acesso TLS ao Portal para acessá-lo no formulário:

https://portal_IP:9443

Neste exemplo, você configura o acesso por TLS para usar a porta 9443. No entanto, a porta 9443 não é necessária. É possível configurar o portal para usar uma porta diferente.

O Portal só pode aceitar um tipo de solicitação (HTTP ou HTTPS) em uma única porta. Portanto, se você configurar o acesso HTTPS na porta 9000, não poderá usar o HTTP para acessar a porta 9000. Se você configurar o portal para usar a porta 9443 com HTTPS, ele não escutará mais a porta 9000.

Para configurar o TLS para o portal:

  1. Crie um arquivo de chave e um arquivo de certificado no formato PEM.
    Observação: verifique se não há senha/senha longa na chave ou no certificado.
  2. Copie os arquivos PEM em um diretório no nó do portal, como /opt/apigee/customer/application. O diretório precisa ser acessível ao usuário "apigee".
  3. Mude a propriedade dos arquivos PEM para o usuário "apigee":
    > chown apigee:apigee /opt/apigee/customer/application/*.PEM
  4. Edite o arquivo /opt/apigee/customer/application/portal.properties para definir as propriedades a seguir. Se esse arquivo não existir, crie-o:
    baas.portal.ssl=on
    baas.portal.ssl.certificate=/opt/apigee/customer/application/defaultcert.pem
    baas.portal.ssl.key=/opt/apigee/customer/application/defaultkey.pem
    baas.portal.sslv1

    # Use essa propriedade para especificar uma porta diferente.
    # baas.portal.listen=9000


    Use baas.portal.ssl.protocols para definir os protocolos TLS aceitos pelo Portal. Para conferir uma lista de protocolos compatíveis, consulte a lista de nomes de protocolos SSL definidos pelo Nginx: http://nginx.org/en/docs/http/ngx_http_ssl_module.html#ssl_protocols.
  5. Configure o nó do Portal:
    > /opt/apigee/apigee-service/bin/apigee-service baas-portal configure
  6. Reinicie o portal:
    > /opt/apigee/apigee-service/bin/apigee-service baas-portal restart
  7. Use o procedimento abaixo em "Configurar nós de pilha do BaaS de API para TLS na pilha ou portal" para garantir que o nó de pilha tenha o URL TLS correto para o portal.

Configurar nós de API BaaS para TLS no Stack ou Portal

Se você incluir um balanceador de carga na frente dos nós da pilha ou do Portal ou ativar o TLS diretamente no nó do Portal ou da pilha, será necessário configurar os nós com os URLs corretos para acessar a pilha e o Portal. Por exemplo, os nós da pilha exigem essas informações quando:

  • Incluir um URL nas respostas de solicitações da API BaaS.
  • Adicionar links em modelos de e-mail ao redefinir uma senha ou enviar outras notificações.
  • redirecionamento de usuários para páginas específicas do portal

Se você usar um balanceador de carga na frente dos nós da pilha ou configurar o TLS no nó da pilha, defina a propriedade a seguir em /opt/apigee/customer/application/usergrid.properties:

usergrid-deployment_usergrid.api.url.base=http://localhost:8080

Substitua http://localhost:8080 pelo URL do balanceador de carga. Se o balanceador de carga estiver configurado para usar TLS, utilize o protocolo HTTPS. Você só precisará incluir a porta se estiver usando uma porta não padrão, ou seja, algo diferente da porta 80 para HTTP e da porta 443 para HTTPS.

Também será preciso definir a seguinte propriedade em /opt/apigee/customer/application/portal.properties se você usar um balanceador de carga na frente dos nós de pilha:

baas.portal.config.overrideUrl=http://localhost:8080

Substitua http://localhost:8080 pelo URL do balanceador de carga da pilha.

Se você usar um balanceador de carga na frente do nó do Portal ou configurar o TLS no nó da pilha, defina as seguintes propriedades em usergrid.properties:

usergrid-deployment_portal.url=http://localhost:9000

Substitua http://localhost:9000 pelo URL do balanceador de carga. Se o balanceador de carga estiver configurado para usar TLS, utilize o protocolo HTTPS. Você só precisa incluir a porta se estiver usando uma porta não padrão, ou seja, algo diferente da porta 80 para HTTP e 443 para HTTPS.

Depois de editar usergrid.properties:

  1. Configure o nó da pilha:
    > /opt/apigee/apigee-service/bin/apigee-service baas-usergrid configure
  2. Reinicie a pilha BaaS:
    > /opt/apigee/apigee-service/bin/apigee-service baas-usergrid restart
  3. Se você modificou portal.properties, configure o nó do portal:
    > /opt/apigee/apigee-service/bin/apigee-service baas-portal configure
  4. Reinicie o portal do BaaS:
    > /opt/apigee/apigee-service/bin/apigee-service baas-portal restart