Além de enviar conteúdo para os destinos integrados do Looker, você pode usar ações, também chamadas de integrações, para enviar conteúdo a serviços de terceiros integrados ao Looker por um servidor de hub de ações.
Nesta página, você vai conhecer as opções de criação de ações personalizadas que podem ser adicionadas ao Hub de ações do Looker ou ao seu próprio servidor privado de hub de ações. Esta página também descreve como iniciar um servidor local do hub de ações para testar suas ações personalizadas ou executar um servidor privado do hub de ações.
Para começar a usar as ações, você pode:
- Use as ações atuais do Looker disponíveis no Hub de ações do Looker.
- Crie e publique uma ação personalizada no Hub de ações do Looker para uso público.
- Crie e publique uma ação personalizada em um servidor particular do hub de ações para uso privado.
Depois que a ação for adicionada ao hub, um administrador do Looker poderá ativá-la para enviar conteúdo do Looker a esses serviços.
Também é possível configurar vários hubs de ações se você quiser usar as integrações do Looker pelo Hub de Ações do Looker e hospedar suas próprias ações privadas ou personalizadas. As ações de cada hub de ações aparecem na página Ações do painel Administrador.
Central de ações do Looker
O Looker hospeda e fornece a central de ações do Looker, um servidor sem estado que implementa a API Action do Looker e expõe ações populares. Todos os dados que os usuários enviam usando uma ação são processados temporariamente no servidor do hub de ações do Looker, e não na sua instância do Looker.
O Looker já está integrado a vários serviços. Consulte a página de documentação Configurações de administrador: ações para saber como ativar esses serviços.
Requisitos da central de ações do Looker
O Action Hub do Looker precisa enviar e receber solicitações de API das seguintes maneiras:
- Da instância do Looker para a rede da central de ações do Looker
- Do navegador do usuário do Looker para a rede da central de ações do Looker
- Da rede da central de ações do Looker para a instância do Looker
Se a implantação do Looker não puder acomodar essas solicitações ou se o recurso Lista de permissões de IP estiver ativado na instância do Looker, considere configurar um servidor de hub de ações local para exibir integrações do Looker particulares ou ações personalizadas. Os administradores de instâncias hospedadas pelo cliente também podem implantar um servidor de ações local especificamente para ações de streaming e OAuth.
Solicitações da instância do Looker para a rede da central de ações do Looker
As solicitações para actions.looker.com
são resolvidas para um endereço IP dinâmico. As solicitações de saída da instância do Looker precisam alcançar os seguintes endpoints:
actions.looker.com/
actions.looker.com/actions/<name>/execute
actions.looker.com/actions/<name>/form
em que name
é o nome programático da ação.
Solicitações do navegador do usuário do Looker para a rede do hub de ações do Looker
O navegador do usuário do Looker precisa fazer solicitações aos seguintes endpoints do Hub de Ações do Looker (para OAuth):
actions.looker.com/actions/<name>/oauth
em que name
é o nome programático da ação.
Solicitações da rede da central de ações do Looker para a instância do Looker
O Hub de ações do Looker precisa fazer solicitações à instância do Looker para ações que ofereçam suporte a resultados transmitidos em streaming ou que usem OAuth.
Uma ação de streaming permite que a ação consuma consultas que geram Todos os resultados. As ações ativadas pelo OAuth usam a autenticação por usuário nos fluxos do OAuth 2.0. As ações do OAuth precisam armazenar as credenciais do usuário na instância de origem do Looker porque o Hub de Ações do Looker é sem estado e multissetorial e não armazena credenciais específicas do usuário de nenhum tipo.
As solicitações da central de ações do Looker para uma instância do Looker têm os seguintes formatos:
GET <host_looker_url>/downloads/<random_40_char_token>
POST <host_looker_url>/action_hub_state/<random_40_char_token>
Esses URLs são gerados na hora na instância do Looker antes de serem enviados ao hub de ações do Looker. Por esse motivo, o Hub de ações do Looker precisa resolver o <host_looker_url>
em um endereço IP e fazer solicitações na rede em que a instância do Looker está.
O Hub de Ação do Looker tem endereços IP de saída estáticos de onde as solicitações sempre vêm: 35.153.89.114
, 104.196.138.163
e 35.169.42.87
. Os administradores de instâncias hospedadas pelo Looker que ativaram a lista de permissões de IP precisam adicionar esses endereços para usar ações que oferecem suporte a resultados transmitidos em streaming ou que usam OAuth.
Considerações para instâncias hospedadas pelo cliente
Para usar as integrações do Looker, o hub de ações do Looker precisa se comunicar com a instância do Looker e atender aos requisitos do hub de ações do Looker. Isso nem sempre é possível com instâncias do Looker hospedadas pelo cliente por vários motivos. Se não for possível estabelecer uma comunicação bidirecional entre o Hub de ações do Looker e a instância do Looker, o Hub de ações do Looker poderá apresentar um comportamento inesperado ou indesejado, como consultas pendentes ou ações indisponíveis.
Para resolver o possível problema de o Hub de Ações do Looker não conseguir se comunicar com a instância do Looker, os administradores do Looker podem implementar uma das soluções mostradas mais adiante nesta página. A solução ou combinação de soluções adequadas vai depender da arquitetura da instância do Looker:
Se a instância hospedada pelo cliente não for resolvida pelo Hub de ações do Looker, ou seja, se o Hub de ações do Looker não puder receber solicitações da instância do Looker, os administradores do Looker poderão entrar em contato com um especialista de vendas do Google Cloud para ativar o recurso de licença
public_host_url
. Esse recurso de licença revela a opção de inicialização--public-host-url
, que permite que os administradores especifiquem um nome de host<public_host_url>
solucionável diferente da instância<host_looker_url>
. Opublic_host_url
substitui o nome do host de alguns URLs de callback específicos do Looker Action Hub e os encaminha por um proxy reverso que tem opublic_host_url
como um nome publicamente solucionável. Esse proxy reverso aceita solicitações apenas dos endereços IP de saída estáticos do Hub de ações do Looker. Os administradores do Looker que usam esse método precisam adicionar à lista de permissões os endereços IP de saída de onde o Hub de ações do Looker faz solicitações para a instância do Looker:35.153.89.114
,104.196.138.163
e35.169.42.87
.Se o URL da instância hospedada pelo cliente for resolvido pela instância do Looker, mas o Hub de ações do Looker não conseguir enviar solicitações para a instância, os usuários não poderão configurar ou usar ações que ofereçam suporte a resultados transmitidos em streaming ou que usem OAuth. Para resolver esse problema, os administradores do Looker precisam adicionar à lista de permissões os endereços IP de saída de onde o Hub de ações do Looker faz solicitações para a instância do Looker:
35.153.89.114
,104.196.138.163
e35.169.42.87
.Se nenhuma das soluções mencionadas for adequada para a arquitetura da instância do Looker, os administradores do Looker poderão implantar um hub de ações hospedado pelo cliente para todas as ações ou apenas para aquelas que oferecem suporte a resultados transmitidos em streaming ou que usam OAuth.
Para implantar um hub de ações hospedado pelo cliente, é necessário garantir que o arquivo JAR seja hospedado em um servidor público para que o hub de ações do Looker possa se comunicar com ele. No entanto, essa solução não é recomendada.
Além disso, as ações de OAuth e streaming podem não ser usadas em uma instância do Looker hospedada pelo cliente se ela usar um certificado SSL emitido por uma autoridade certificadora (AC) que não está nesta lista de certificados raiz.
Como criar uma ação personalizada
Esta seção descreve as etapas a seguir para escrever e testar uma ação personalizada usando o código-fonte do Looker Action Hub. Para conferir exemplos de código funcional, verifique as ações no repositório looker-open-source/actions
no GitHub.
Para criar uma ação personalizada, faça o seguinte:
- Configurar um repositório de desenvolvimento
- Como escrever sua ação
- Como testar sua ação
- Publicar e ativar sua ação no Hub de ações da Looker ou no seu próprio servidor privado
Como em qualquer ação, talvez seja necessário configurar seus modelos do LookML com parâmetros específicos antes de usar a ação para entregar seus dados.
Como configurar um repositório de desenvolvimento
O Hub de ações do Looker é um servidor Node.js escrito em TypeScript, uma pequena camada sobre o JavaScript moderno que adiciona informações de tipo para ajudar a detectar erros de programação. Se você já conhece o JavaScript, a maioria do TypeScript também será familiar.
Para executar a central de ações do Looker, é necessário ter o seguinte software:
- Node.js
- Gerenciador de versões de nó (NVM, para selecionar a versão correta do Node.js)
- Yarn (para gerenciar dependências)
Depois de instalar o software necessário, você já pode configurar seu ambiente de desenvolvimento. O exemplo a seguir usa o Git.
Clone o repositório
looker-open-source/actions
localmente:git clone git@github.com:looker-open-source/actions.git
Crie um diretório com o nome da ação no diretório
actions/src/actions
. Exemplo:mkdir actions/src/actions/my_action
Comece a preencher o diretório com os arquivos necessários para executar a ação. Consulte o repositório do GitHub de ações para conferir um exemplo de estrutura de arquivos.
O Looker recomenda que você também adicione o seguinte:
- Um README para explicar o propósito e os meios de autenticação da ação
- Um ícone PNG para exibição no Hub de ações do Looker (ou Hub de ações particular na sua instância do Looker) e nas janelas de envio de dados do Looker
- Qualquer arquivo de testes que você quer executar no código de ação. Isso é diferente de testar sua ação.
Como gravar uma ação
Um requisito de design para o servidor do Looker Action Hub é que ele permaneça completamente sem estado. Portanto, não é permitido armazenar informações no aplicativo ou serviço de ação. Todas as informações necessárias para realizar a ação precisam ser fornecidas nas chamadas de solicitação do arquivo de ação.
O conteúdo exato do arquivo de ação varia de acordo com o serviço, o tipo ou o nível em que a ação opera e quais formatos de dados ou visualização precisam ser especificados. A ação também pode ser configurada para fluxos de autorização do OAuth 2.0.
Os arquivos de ação são baseados no método da API /execute
. As solicitações da API do Looker são transmitidas a um DataActionRequest
sempre que um usuário executa a ação no Looker. O DataActionRequest
contém todos os dados e metadados necessários para executar a ação. Um método /form
também está disponível e pode ser usado para coletar mais informações do usuário antes que ele execute a ação. Os campos especificados em /form
vão aparecer no pop-up Enviar ou Programar quando os usuários selecionarem a ação como destino para a entrega de dados.
Ao escrever o arquivo de ação, inclua pelo menos os seguintes parâmetros marcados como Obrigatório na definição de ação:
Parâmetro | Obrigatório | Descrição | Tipo de dado |
---|---|---|---|
name |
Sim | Um nome exclusivo para a ação. Ele precisa ser exclusivo em todas as ações no Hub de Ações do Looker. | string |
url |
Sim | Um URL absoluto do endpoint /execute para essa ação. |
string |
label |
Sim | Um rótulo legível para a ação. | string |
supportedActionTypes |
Sim | Uma lista de tipos de ações com suporte. Os valores válidos são "cell" , "query" e "dashboard" . |
string |
formURL |
Não | Um URL absoluto do endpoint /form para essa ação. |
string |
description |
Não | Descrição da ação. | string |
params |
Não | Matriz de parameters para a ação. Inclua o nome, o rótulo e a descrição em formato de string para cada parâmetro. Estes são os campos que aparecem na página de ativação da ação no painel Administrador. Para gerenciar como os usuários podem enviar dados para um destino de ação, especifique um atributo do usuário em que o usuário precisa ter um valor definido. |
parameters |
supportedFormats |
Não | Uma lista de formatos de dados aceitos pela ação. Os valores válidos são "txt" , "csv" , "inline_json" , "json" e "json_detail" . |
string |
supportedFormattings |
Não | Uma lista de opções de formatação compatíveis com a ação. Os valores válidos são: "formatted" e "unformatted" . |
string |
supportedVisualizationFormattings |
Não | Uma lista de opções de formatação de visualização compatíveis com a ação. Os valores válidos são: "apply" e "noapply" . |
string |
iconName |
Não | Um URI de dados que representa uma imagem de ícone para a ação. | string |
requiredFields |
Não | Uma lista de descrições dos campos obrigatórios compatíveis com essa ação. Se houver várias entradas nessa lista, a ação vai exigir mais de um campo. | RequiredField |
supportedDownloadSettings |
Não | Um booleano que determina se a ação vai receber um URL de download de uso único para facilitar o streaming ilimitado de dados. O parâmetro é definido pelo parâmetro usesStreaming , que é um booleano true/false . Se usesStreaming = true , então supportedDownloadSettings = url . Se usesStreaming = false , então supportedDownloadSettings = push . |
Booleano |
usesOAuth |
Não | Um booleano que determina se a ação é uma ação OAuth. Isso vai determinar se a ação vai receber um link de uso único para definir state para um usuário específico. |
Booleano |
usesStreaming |
Não | Um booleano que determina se a ação oferece suporte a resultados de consulta transmitidos. Marque a coluna Usar streaming de dados (Sim/Não) na lista de serviços integrados. As ações que transmitem resultados podem exigir a configuração de um servidor de hub de ações local. Consulte a página de práticas recomendadas Configurar um hub de ações local para ações que usam OAuth ou streaming para mais informações. | Booleano |
minimumSupportedVersion |
Não | A versão mínima do Looker em que a ação vai aparecer na lista do Action Hub do painel Administrador. | string |
Exemplos das ações do Looker Action Hub estão no GitHub para referência.
Tipos de ação com suporte
O Looker oferece suporte a três tipos de ações, conforme especificado no parâmetro supportedActionTypes
da ação: consulta, célula e painel.
- Uma ação no nível da consulta:é uma ação que envia uma consulta inteira. A ação de segmento, por exemplo, é uma ação no nível da consulta.
- Uma ação no nível da célula:uma ação no nível da célula envia o valor de uma única célula específica em uma tabela de dados. Esse tipo de ação é diferente das ações de dados, que podem ser definidas para dimensões ou medidas usando o parâmetro
action
. Para enviar informações de uma célula específica em uma tabela, o Looker usa tags para mapear ações para as células correspondentes. As ações precisam especificar quais tags são compatíveis emrequiredFields
. Para mapear ações e campos, os campos no LookML precisam especificar as tags a que eles são mapeados com o parâmetrotags
do LookML. Por exemplo, a ação de mensagem do Twilio usa uma tagphone
para que os desenvolvedores do LookML possam controlar em quais campos de número de telefone a ação do Twilio vai aparecer. - Uma ação no nível do painel:uma ação no nível do painel aceita o envio de uma imagem do painel. Por exemplo, a ação do SendGrid envia imagens do painel por e-mail.
Adicionar atributos do usuário a ações personalizadas
Para ações personalizadas, adicione atributos do usuário no parâmetro params
do arquivo de ação. Se o parâmetro for obrigatório, cada usuário precisa ter um valor definido para esse atributo na conta de usuário ou em um grupo de usuários ao qual ele pertence, além da permissão send_to_integration
, para que a ação apareça como uma opção de destino ao enviar ou programar conteúdo.
Para adicionar um atributo do usuário à sua ação:
- Um administrador do Looker pode precisar criar o atributo do usuário correspondente ao
user_attribute_param
, se ele ainda não existir. - Defina um valor válido para o atributo de usuário dos usuários ou grupos de usuários que precisam enviar conteúdo para o destino da ação. Esses usuários também precisam ter permissões
send_to_integration
. - O parâmetro
params
representa os campos do formulário que um administrador do Looker precisa configurar na página de ativação da ação na lista Ações do painel Administrador. No parâmetroparams
do arquivo de ação, inclua o seguinte:
params = [{
description: "A description of the param.",
label: "A label for the param.",
name: "action_param_name",
user_attribute_name: "user_attribute_name",
required: true,
sensitive: true,
}]
em que user_attribute_name
é o atributo do usuário definido no campo Nome na página Atributos do usuário na seção Usuários do painel Administrador. required: true
significa que um usuário precisa ter um valor válido e não nulo definido para esse atributo para ver a ação quando os dados estão sendo enviados. sensitive: true
significa que o atributo do usuário é criptografado e nunca é mostrado na interface do Looker depois de ser inserido. É possível especificar vários subatributos de atributo do usuário.
- Implante as atualizações no servidor do Action Hub.
- Se você estiver adicionando uma nova ação, um administrador do Looker vai precisar ativar a ação clicando no botão Ativar ao lado dela na página Ações no painel Administrador.
- Se você estiver atualizando uma ação, atualize a lista de ações clicando no botão Atualizar. Em seguida, clique no botão Configurações.
- Na página de configurações/ativação da ação, um administrador do Looker precisa configurar os campos do formulário da ação para extrair informações do atributo do usuário. Para isso, clique no ícone do atributo do usuário à direita do campo apropriado e selecione o atributo desejado.
Parâmetros requiredField
em ações no nível da célula
Para ações no nível da célula, é possível configurar os campos do LookML do modelo para enviar dados ao destino da ação especificando quais tags são compatíveis com a ação no parâmetro requiredFields
do arquivo de ação.
Parâmetro | Obrigatório | Descrição | Tipo de dados |
---|---|---|---|
tag |
Não | Se presente, corresponde a um campo que tem essa tag. | string |
any_tag |
Não | Se presente, substitui tag e corresponde a um campo que tem qualquer uma das tags fornecidas. |
string |
all_tags |
Não | Se presente, substitui tag e corresponde a um campo com todas as tags fornecidas. |
string |
Formatos de dados compatíveis
A classe DataActionRequest
define qual formato de entrega de dados está disponível para a ação. Para ações no nível da consulta, a solicitação vai conter um anexo que pode estar em vários formatos. A ação pode especificar um ou mais supportedFormats
ou permitir que o usuário escolha o formato especificando todos os formatos possíveis. Para ações no nível da célula, o valor da célula vai estar presente em DataActionRequest
.
Como configurar uma ação para o OAuth
É possível configurar a ação para que os usuários possam fazer a autenticação com o OAuth. Embora o Looker Action Hub precise permanecer sem estado, é possível aplicar um estado usando uma solicitação de formulário da API Looker Action.
Fluxo OAuth da ação do Looker
Para ações no Hub de Ações do Looker, você pode estender um OAuthAction
em vez de um Hub.Action
para definir um booleano que indique quais métodos OAuth são necessários para autenticar um usuário em uma ação. Para cada ação ativada pelo OAuth ou pelo estado, o Looker armazena um estado por usuário e por ação, para que cada combinação de ação e usuário tenha um evento OAuth independente.
O fluxo para criar ações geralmente envolve uma solicitação /form
seguida por uma /execute
. Para o OAuth, a solicitação /form
precisa ter um método para determinar se o usuário está autenticado no serviço de destino. Se o usuário já estiver autenticado, a ação vai retornar um /form
normal de acordo com o que a solicitação /execute
exigir. Se o usuário não estiver autenticado, a ação vai retornar um link que inicializará um fluxo OAuth.
Como salvar o estado com o URL do OAuth
O Looker vai enviar uma solicitação POST HTTP com um corpo vazio para o endpoint ActionList
. Se a ação retornar uses_oauth: true
na definição, uma state_url
de uso único será enviada em cada solicitação /form
do Looker. O state_url
é um URL especial de uso único que define o estado de um usuário para uma determinada ação.
Se o usuário não for autenticado com o endpoint, o /form
retornado vai conter um form_field
do tipo oauth_link
que vai para o endpoint /oauth
de uma ação. O state_url
precisa ser criptografado e salvo como um parâmetro state
no oauth_url
retornado. Exemplo:
{
"name": "login",
"type": "oauth_link",
"label": "Log in",
"description": "OAuth Link",
"oauth_url": "ACTIONHUB_URL/actions/my_action/oauth?state=encrypted_state_url"
}
Neste exemplo, o endpoint /oauth
redireciona o usuário para o servidor de autenticação. O endpoint /oauth
constrói o redirecionamento no método oauthUrl(...)
em uma ação OAuth, conforme mostrado no Dropbox OauthUrl.
O parâmetro state
que contém o state_url
criptografado precisa ser transmitido ao Hub de Ações do Looker.
Como salvar o estado com o URI de redirecionamento do hub de ações
No endpoint /oauth
, um redirect_uri
para o hub de ações também é criado e transmitido ao método oauthUrl(...)
da ação. Esse redirect_uri
é do tipo /actions/src/actions/my_maction/oauth_redirect
e é o endpoint usado se a autenticação retornar um resultado.
Esse endpoint vai chamar o método oauthFetchInfo(...)
, que precisa ser implementado pelo método OauthAction
para extrair as informações necessárias e tentar receber ou salvar qualquer estado ou auth
recebido do servidor de autenticação.
O state
descriptografa o state_url
criptografado e o usa para enviar state
por POST de volta ao Looker. Na próxima vez que um usuário fizer uma solicitação para essa ação, o estado recém-salvo será enviado ao Hub de Ações do Looker.
Como adicionar arquivos de ação ao repositório do hub de ações do Looker
Depois que o arquivo de ação for escrito, no repositório do Looker Action Hub:
Adicione o arquivo de ação (por exemplo,
my_action.ts
) aactions/src/actions/index.ts
.import "./my_action/my_action.ts"
Adicione todos os requisitos de pacotes do Node.js que você usou na redação da ação. Exemplo:
yarn add aws-sdk yarn add express
Instale as dependências do Node.js do servidor do hub de ações do Looker.
yarn install
Execute todos os testes que você escreveu.
yarn test
Como testar uma ação
Para testes completos, hospede um servidor de hub de ações particular e teste sua ação na instância do Looker. Esse servidor precisa estar na Internet pública com um certificado SSL válido e ser capaz de iniciar e receber conexões ou solicitações HTTPS de e para o Looker. Para isso, você pode usar uma plataforma baseada na nuvem, como a Heroku, conforme mostrado no exemplo a seguir. Se preferir, use qualquer plataforma que atenda aos requisitos mencionados acima.
Como configurar um servidor local do hub de ações
Neste exemplo, vamos realizar a ação desenvolvida no repositório do GitHub looker-open-source/actions/src/actions
e confirmar o código em um novo branch do Git. Recomendamos que você trabalhe em recursos usando ramificações para acompanhar seu código com facilidade e, se quiser, criar uma PR com o Looker.
Para começar, crie sua ramificação e, em seguida, prepare e confirme seu trabalho. Exemplo:
git checkout -b my-branch-name git add file-names git commit -m commit-message
Neste exemplo, para enviar uma ramificação ao Heroku, configure o repositório do Git com o Heroku como uma opção remota na linha de comando:
heroku login heroku create git push heroku
O Heroku vai retornar o URL público que hospeda o hub de ações para você usar. Acesse o URL ou execute
heroku logs
para confirmar se o hub de ações está em execução. Se você esquecer o URL público, execute o seguinte na linha de comando:heroku info -s | grep web_url
O Heroku vai retornar seu URL público. Por exemplo:
https://my-heroku-action-server-1234.herokuapp.com
Na linha de comando, defina o URL base do hub de ações:
heroku config:set ACTION_HUB_BASE_URL="https://my-heroku-action-server-1234.herokuapp.com"
Defina o rótulo do hub de ações:
heroku config:set ACTION_HUB_LABEL="Your Action Hub"
O Looker usa um token de autorização para se conectar ao hub de ações. Gere o token na linha de comando:
heroku run yarn generate-api-key
Se você não estiver usando o Heroku, como neste exemplo, use:
yarn generate-api-key
O Heroku vai retornar seu token de autorização. Por exemplo:
Authorization: Token token="abcdefg123456789"
Defina o secret do Action Hub usando a chave secreta:
heroku config:set ACTION_HUB_SECRET="abcdefg123456789"
As implantações hospedadas pelo cliente podem exigir a configuração de outras variáveis de ambiente não documentadas aqui.
Para adicionar uma ação à sua instância local do Looker, acesse Administrador > Ações.
- Na parte de baixo da lista de ações, clique em Adicionar hub de ações.
- Insira o URL do Action Hub e, opcionalmente, uma chave secreta.
- Encontre a ação na lista Ações do menu Administrador do Looker.
- Clique em Ativar.
Se a ação exigir que tipos específicos de dados sejam transmitidos do Looker, configure os modelos para incluir o parâmetro tags
adequado.
Agora está tudo pronto para testar a ação.
Testar ações no nível do painel e da consulta
Na instância do Looker, configure o modelo do LookML com tags, se necessário. Crie e salve um visual. No visual salvo, clique no menu no canto superior direito e selecione Enviar com sua ação como destino. Se você tiver um formulário para entrega, o Looker vai renderizá-lo na janela Enviada.
Clique em Enviar teste para enviar os dados. O status da ação vai aparecer no Histórico do Programador no painel Administrador. Se a ação encontrar um erro, ela será mostrada no painel Administrador, e o Looker vai enviar um e-mail com a mensagem de erro para o usuário que enviou a ação.
Como testar ações no nível da célula
Configure um campo do LookML com as tags adequadas para sua ação. Na instância do Looker, execute uma consulta que inclua esse campo. Encontre o campo na tabela de dados. Clique no … na célula e selecione Enviar no menu suspenso. Se você receber erros, será necessário atualizar completamente a tabela de dados depois de corrigir esses erros.
- Se a ação for entregue sem erros, você poderá publicá-la.
- Se você quiser continuar hospedando sua ação de forma privada, publique no seu hub de ações particular.
- Se você quiser publicar sua ação para uso por todos os clientes do Looker, consulte a seção Publicação no hub de ações do Looker.
Publicar e ativar uma ação personalizada
Há duas opções de publicação para ações personalizadas:
- Publicação no hub de ações do Looker: sua ação fica disponível para qualquer pessoa que use o Looker.
- Publicação em um servidor privado do Action Hub: a ação fica disponível apenas na sua instância do Looker.
Depois que a ação for publicada, você poderá ativá-la na página Ações no painel Administrador.
Como publicar na central de ações do Looker
Essa abordagem é a mais fácil e funciona para qualquer ação que você queira disponibilizar para quem usa o Looker.
Depois que sua ação for testada, você poderá enviar uma PR para o repositório looker-open-source/actions
no GitHub.
Digite este comando:
git push <your fork> <your development branch>
Crie sua solicitação de envio com o repositório
looker-open-source/actions
como destino.Preencha o formulário de envio do Marketplace do Looker e do Action Hub. Para mais informações sobre os requisitos do formulário, consulte Como enviar conteúdo para o Marketplace do Looker.
O Looker vai analisar seu código de ação. Reservamos o direito de recusar sua RP, mas podemos ajudar com qualquer problema que você tiver e oferecer sugestões de melhoria. Em seguida, mesclamos o código no repositório
looker-open-source/actions
e o implantamos noactions.looker.com
. Depois que o código for implantado, ele vai estar disponível para todos os clientes do Looker.Ative a ação na sua instância do Looker para que ela apareça como uma opção de envio de dados.
Publicação em um servidor particular do Action Hub
Se você tiver ações personalizadas que são particulares para sua empresa ou caso de uso, não adicione a ação ao repositório looker-open-source/actions
. Em vez disso, crie um hub de ações particular usando o mesmo framework Node.js usado para testar sua ação.
É possível configurar o servidor do hub de ações interno na sua própria infraestrutura ou usando uma plataforma de aplicativos baseada na nuvem (nosso exemplo usou a Heroku). Não se esqueça de bifurcar o Action Hub do Looker para seu servidor de Action Hub privado antes da implantação.
Como configurar um modelo do LookML para uso com uma ação
Para ações personalizadas e ações disponíveis no Hub de ações do Looker, é necessário identificar os campos de dados relevantes usando o parâmetro tags
no modelo do LookML. A página Ações no painel Administrador mostra informações sobre as tags necessárias para o serviço, se houver.
Por exemplo, uma integração do Twilio Send Message envia uma mensagem para uma lista de números de telefone. Na página Ações do painel Administrador, a integração mostra o subtexto "Ação pode ser usada com consultas que têm um campo marcado como phone
".
Isso significa que o serviço Twilio Send Message exige uma consulta que inclua um campo de número de telefone e que use o parâmetro tags
para identificar qual campo na consulta contém números de telefone. Para identificar um campo de número de telefone no LookML, especifique tags: ["phone"]
para esse campo. O LookML para um campo de número de telefone pode ficar assim:
dimension: phone {
tags: ["phone"]
type: string
sql: ${TABLE}.phone ;;
}
Uma integração que não exige tags mostra o subtexto "Ação pode ser usada com qualquer consulta" na página Ações do painel Administrador.
Identifique todos os campos obrigatórios no modelo do LookML com o parâmetro tags
para que os usuários possam usar o serviço para enviar dados.
A seguir
Saiba como enviar o conteúdo de um Look ou uma Análise detalhada ou de um painel para um serviço integrado.