Blue поддерживает исходящие вебхуки для отправки данных в другие системы.


Вебхук — это автоматическое сообщение, отправляемое из одного приложения в другое, когда происходит какое-то событие. Например, когда в Blue создается новая запись, можно настроить вебхук для отправки данных об этой записи в другую систему.

Вебхуки Blue срабатывают мгновенно, в течение миллисекунд после возникновения события. Эта природа в реальном времени делает их неоценимыми для интеграции Blue с другими бизнес-системами.

Вебхуки

  • Синхронизация данных в реальном времени между системами
  • Возможность реагировать и предпринимать действия на события Blue
  • Нет необходимости постоянно опрашивать на предмет изменений; данные отправляются мгновенно
  • Создание пользовательских интеграций и рабочих процессов

Беспрецедентный контроль

Вебхуки Blue предоставляют вам детальный контроль над:

  • Точно какие события должны вызывать вебхук и из какого проекта
  • Фильтры для уточнения объема записей
  • Проверка подписи для повышения безопасности

Создание вебхука

В Blue администраторы проектов могут создавать вебхуки в личных настройках. Вы указываете:

  • Имя вебхука
  • URL для отправки данных
  • Необязательный секрет для подписи

Триггеры

Вебхуки могут срабатывать по самым различным событиям Blue, включая:

  • Запись создана/обновлена/удалена
  • Комментарий добавлен/отредактирован
  • Исполнитель изменен
  • Статус контрольного списка изменен
  • Значение пользовательского поля изменено
  • И многие другие

Полезная нагрузка вебхука

При срабатывании Blue отправляет JSON-полезную нагрузку, содержащую все детали события, на указанный вами URL.

Вот пример полезной нагрузки:

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

Подпись

Чтобы проверить, что полезные нагрузки действительно от Blue, можно проверить необязательную подпись. Подобно OAuth, подпись создается путем хеширования содержимого полезной нагрузки с вашим выбранным секретным ключом.

Пример проверки в 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');

Дополнительные интеграции

Помимо пользовательских вебхуков, Blue также предлагает интеграции с инструментами, такими как Zapier и Pabbly Connect, чтобы упростить соединение данных Blue с сотнями популярных приложений.

Пример ответа вебхука

{

  "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

        }

      }

    }

  }

}
Поддержка разработчиков


Если у вас есть вопросы, пожалуйста, свяжитесь с нами по адресу [support@blue.cc](support@blue.cc), и мы сможем помочь. Мы также предлагаем профессиональные услуги для поддержки интеграции.

AI Ассистент

Ответы генерируются с использованием ИИ и могут содержать ошибки.

Как я могу вам помочь?

Спросите меня о чем угодно, связанном с Blue или этой документацией.

Введите для отправки • Shift+Enter для новой строки • ⌘I для открытия