Blue supporta webhook in uscita per inviare dati ad altri sistemi.


Un webhook è un messaggio automatizzato inviato da un'applicazione a un'altra quando accade qualcosa. Ad esempio, quando viene creato un nuovo record in Blue, è possibile configurare un webhook per inviare dati su quel record a un altro sistema.

I webhook di Blue vengono attivati istantaneamente, entro millisecondi dall'evento che si verifica. Questa natura in tempo reale li rende inestimabili per integrare Blue con altri sistemi aziendali.

Webhook

  • Sincronizzazione dei dati in tempo reale tra i sistemi
  • Capacità di rispondere e intraprendere azioni sugli eventi di Blue
  • Nessun bisogno di controllare ripetutamente le modifiche; inviati istantaneamente
  • Creare integrazioni e flussi di lavoro personalizzati

Controllo Senza Precedenti

I webhook di Blue ti offrono un controllo dettagliato su:

  • Esattamente quali eventi dovrebbero attivare il webhook e da quale progetto
  • Filtri per restringere l'ambito dei record
  • Validazione della firma per una maggiore sicurezza

Creazione di un Webhook

In Blue, gli Amministratori di Progetto possono creare webhook nelle impostazioni personali. Devi specificare:

  • Nome del webhook
  • URL del payload per inviare dati
  • Segreto opzionale per la firma

Attivatori

I webhook possono essere attivati da una vasta gamma di eventi di Blue, tra cui:

  • Record creati/aggiornati/cancellati
  • Commento aggiunto/modificato
  • Assegnatario cambiato
  • Stato della checklist cambiato
  • Valore del campo personalizzato cambiato
  • E molti altri

Payload del Webhook

Quando attivato, Blue invia un payload JSON contenente tutti i dettagli dell'evento al tuo URL specificato.

Ecco un esempio di payload:

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

Firma

Per convalidare che i payload provengano realmente da Blue, è possibile controllare una firma opzionale. Simile a OAuth, la firma viene creata hashando il contenuto del payload con la chiave segreta scelta.

Esempio di Validazione in 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');

Integrazioni Aggiuntive

Oltre ai webhook personalizzati, Blue offre anche integrazioni con strumenti come Zapier e Pabbly Connect per semplificare la connessione dei dati di Blue con centinaia di app popolari.

Esempio di risposta del 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

        }

      }

    }

  }

}
Supporto per Sviluppatori


Se hai domande, ti preghiamo di contattarci all'indirizzo [support@blue.cc](support@blue.cc), e possiamo assisterti. Offriamo anche servizi professionali per il supporto all'integrazione.

Assistente AI

Le risposte sono generate utilizzando l'IA e potrebbero contenere errori.

Come posso aiutarti?

Chiedimi qualsiasi cosa su Blue o su questa documentazione.

Invia per inviare • Maiusc+Invio per una nuova riga • ⌘I per aprire