Blue obsługuje wychodzące webhooki do przesyłania danych do innych systemów.


Webhook to zautomatyzowana wiadomość wysyłana z jednej aplikacji do drugiej, gdy coś się wydarzy. Na przykład, gdy nowy rekord zostanie utworzony w Blue, można skonfigurować webhook do przesyłania danych o tym rekordzie do innego systemu.

Webhooki Blue są uruchamiane natychmiast, w ciągu milisekund od wystąpienia zdarzenia. Ta natura w czasie rzeczywistym czyni je nieocenionymi do integracji Blue z innymi systemami biznesowymi.

Webhooki

  • Synchronizacja danych w czasie rzeczywistym między systemami
  • Możliwość reagowania i podejmowania działań na zdarzenia w Blue
  • Brak potrzeby wielokrotnego sprawdzania zmian; przesyłane natychmiast
  • Tworzenie niestandardowych integracji i przepływów pracy

Bezprecedensowa Kontrola

Webhooki Blue dają Ci szczegółową kontrolę nad:

  • Dokładnie, które zdarzenia powinny uruchamiać webhook i z którego projektu
  • Filtry w celu zawężenia zakresu rekordów
  • Walidacja podpisu dla zwiększonego bezpieczeństwa

Tworzenie Webhooka

W Blue, administratorzy projektów mogą tworzyć webhooki w ustawieniach osobistych. Musisz określić:

  • Nazwę webhooka
  • URL ładunku do przesyłania danych
  • Opcjonalny sekret do podpisu

Wyzwalacze

Webhooki mogą być uruchamiane przez szeroki wachlarz zdarzeń w Blue, w tym:

  • Rekord utworzony/zaktualizowany/usunięty
  • Komentarz dodany/edytowany
  • Zmieniony przypisany
  • Zmieniony status listy kontrolnej
  • Zmieniona wartość pola niestandardowego
  • I wiele innych

Ładunek Webhooka

Po uruchomieniu, Blue wysyła ładunek JSON zawierający wszystkie szczegóły zdarzenia do określonego URL.

Oto przykład ładunku:

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

Podpis

Aby zweryfikować, że ładunki pochodzą rzeczywiście z Blue, można sprawdzić opcjonalny podpis. Podobnie jak w przypadku OAuth, podpis jest tworzony przez haszowanie zawartości ładunku za pomocą wybranego klucza sekretnego.

Przykład Walidacji w 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');

Dodatkowe Integracje

Oprócz niestandardowych webhooków, Blue oferuje również integracje z narzędziami takimi jak Zapier i Pabbly Connect, aby uprościć łączenie danych Blue z setkami popularnych aplikacji.

Przykład odpowiedzi Webhooka

{

  "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

        }

      }

    }

  }

}
Wsparcie dla Programistów


Jeśli masz jakiekolwiek pytania, skontaktuj się z nami pod adresem [support@blue.cc](support@blue.cc), a my możemy pomóc. Oferujemy również usługi profesjonalne w zakresie wsparcia integracji.

Asystent AI

Odpowiedzi są generowane przy użyciu sztucznej inteligencji i mogą zawierać błędy.

Jak mogę Ci pomóc?

Zapytaj mnie o cokolwiek dotyczącego Blue lub tej dokumentacji.

Wciśnij Enter, aby wysłać • Shift+Enter, aby dodać nową linię • ⌘I, aby otworzyć