Blue suporta Webhooks de saída para enviar dados a outros sistemas.


Um webhook é uma mensagem automatizada enviada de uma aplicação para outra quando algo acontece. Por exemplo, quando um novo registro é criado no Blue, um webhook pode ser configurado para enviar dados sobre esse registro para outro sistema.

Os webhooks do Blue são acionados instantaneamente, dentro de milissegundos após a ocorrência do evento. Essa natureza em tempo real os torna inestimáveis para integrar o Blue com outros sistemas empresariais.

Webhooks

  • Sincronização de dados em tempo real entre sistemas
  • Capacidade de responder e agir sobre eventos do Blue
  • Sem necessidade de consultar repetidamente por mudanças; enviado instantaneamente
  • Criação de integrações e fluxos de trabalho personalizados

Controle Sem Precedentes

Os webhooks do Blue oferecem controle detalhado sobre:

  • Exatamente quais eventos devem acionar o webhook e de qual projeto
  • Filtros para restringir o escopo dos registros
  • Validação de assinatura para maior segurança

Criando um Webhook

No Blue, Administradores de Projetos podem criar webhooks nas configurações pessoais. Você especifica:

  • Nome do webhook
  • URL de payload para enviar dados
  • Segredo opcional para assinatura

Gatilhos

Os webhooks podem ser acionados por uma ampla variedade de eventos do Blue, incluindo:

  • Registro criado/atualizado/excluído
  • Comentário adicionado/editado
  • Responsável alterado
  • Status da lista de verificação alterado
  • Valor de campo personalizado alterado
  • E muitos mais

Payload do Webhook

Quando acionado, o Blue envia um payload JSON contendo todos os detalhes do evento para a URL especificada.

Aqui está um exemplo de payload:

{
  "event": "RECORD_CREATED",
  "record": {
    "id": "1234",
    "title": "New record"
    ...
  },
  "company": {
    "id": "5678"  
  },
  "project": {
    "id": "91011"
  },
  "user": {
    "id": "1213" 
  }
}

Assinatura

Para validar que os payloads são genuinamente do Blue, uma assinatura opcional pode ser verificada. Semelhante ao OAuth, a assinatura é criada ao hash do conteúdo do payload com sua chave secreta escolhida.

Validação de Exemplo em Node.js

const crypto = require('crypto');
const key = 'secret'; 
const body = {...webhookPayload} 
const hash = crypto.createHmac('sha256', key).update(body);
const signature = hash.digest('hex');

Integrações Adicionais

Além de webhooks personalizados, o Blue também oferece integrações com ferramentas como Zapier e Pabbly Connect para simplificar a conexão dos dados do Blue com centenas de aplicativos populares.

Exemplo de resposta do Webhook

{

  "event": "TODO_CREATED",

  "webhook": {

    "id": "clb4qaopy0000vt24mlp28v03",

    "uid": "edb5b5d51dc9461a952160dbe72153b4",

    "name": "Testing webhook",

    "url": "https://httpdump.app/dumps/7cc66eda-8e83-4039-ba49-4c36db14d508",

    "secret": "",

    "status": "HEALTHY",

    "enabled": true,

    "metadata": {

      "events": [

        "TODO_CREATED",

        "TODO_DELETED",

        "TODO_MOVED",

        "TODO_NAME_CHANGED",

        "TODO_CHECKLIST_CREATED",

        "TODO_CHECKLIST_NAME_CHANGED",

        "TODO_CHECKLIST_DELETED",

        "TODO_CHECKLIST_ITEM_CREATED",

        "TODO_LIST_CREATED",

        "TODO_LIST_DELETED",

        "TODO_LIST_NAME_CHANGED",

        "COMMENT_CREATED",

        "COMMENT_DELETED",

        "COMMENT_UPDATED"

      ],

      "projectIds": [

        "clakt90vu000bvt64hhffqleq",

        "claulnu1y0000vtrcjurjgds4",

        "clb4gay0y000qvtzs8smaays8"

      ]

    },

    "createdById": "claksl2ye0000vtas0h0ln71e",

    "createdAt": "2022-12-01T07:01:25.014Z",

    "updatedAt": "2022-12-01T11:23:00.661Z"

  },

  "currentValue": {

    "id": "clb4zna6x0000vt1swuwso25f",

    "uid": "11021cb836f34732b31e5ebd5dd5eb27",

    "title": "GGGG",

    "html": null,

    "text": null,

    "position": "32767.5",

    "archived": false,

    "done": false,

    "startedAt": null,

    "duedAt": null,

    "timezone": null,

    "createdAt": "2022-12-01T11:23:09.000Z",

    "updatedAt": "2022-12-01T11:23:09.241Z",

    "createdById": "claksl2ye0000vtas0h0ln71e",

    "todoListId": "clakt9v5t000kvt64f563l90l",

    "todoCustomFields": [],

    "todoUsers": [],

    "todoTags": [],

    "todoList": {

      "id": "clakt9v5t000kvt64f563l90l",

      "uid": "df0e931e6e8f4fc2905ece9da167d2d3",

      "createdAt": "2022-11-17T08:29:22.000Z",

      "updatedAt": "2022-11-17T08:29:22.050Z",

      "title": "ETEST",

      "position": 131070,

      "createdById": "claksl2ye0000vtas0h0ln71e",

      "projectId": "clakt90vu000bvt64hhffqleq",

      "project": {

        "id": "clakt90vu000bvt64hhffqleq",

        "uid": "d7db469a8908496f8e5f5e68030fe4c8",

        "slug": "teest",

        "name": "TEEST",

        "description": "",

        "archived": false,

        "createdAt": "2022-11-17T08:28:43.000Z",

        "updatedAt": "2022-11-17T08:28:42.811Z",

        "isTemplate": false,

        "isOfficialTemplate": false,

        "category": "GENERAL",

        "companyId": "clakt8jud0002vt64205yyj10",

        "imageId": null,

        "hideEmailFromRoles": null,

        "company": {

          "id": "clakt8jud0002vt64205yyj10",

          "uid": "400eb3f8238c486caf40957618be9662",

          "slug": "rogue",

          "name": "Rogue",

          "description": null,

          "createdAt": "2022-11-17T08:28:21.000Z",

          "updatedAt": "2022-11-17T08:28:20.726Z",

          "freeTrialExpiredAt": "2022-12-01T08:28:15.000Z",

          "freeTrialStartedAt": "2022-11-17T08:28:15.000Z",

          "subscribedAt": null,

          "imageId": null,

          "subscriptionPlanId": "clakt8jue0003vt64e40q2prj",

          "freeTrialExtendedById": null,

          "freeTrialExtendedAt": null

        }

      }

    }

  }

}
Suporte ao Desenvolvedor


Se você tiver alguma dúvida, entre em contato conosco em [support@blue.cc](support@blue.cc), e podemos ajudar. Também oferecemos serviços profissionais para suporte à integração.

Assistente de IA

As respostas são geradas usando IA e podem conter erros.

Como posso ajudá-lo?

Pergunte-me qualquer coisa sobre o Blue ou esta documentação.

Digite para enviar • Shift+Enter para nova linha • ⌘I para abrir