← All webhook events

Subscribe to grant.created

A new grant - foundation, government, CSR - is recorded in the grant pipeline.

When does grant.created fire?

A new row lands in the grants table with sanction details: funder, amount, programme, tranche schedule, sanctioned_at.

What developers build with it

  • Mirror into finance ERP (Tally, Zoho, SAP)
  • Update board-reporting MIS
  • Trigger compliance kick-off workflow (PFMS registration, etc.)
  • Alert finance team via Slack / email

Sample payload

The full envelope (with HMAC-SHA256 signature, delivery UUID and headers) is documented on the webhooks hub page. Below is the per-event data block for grant.created:

{
    "grant_id": 33,
    "ngo_id": 7,
    "funder_name": "Tata Trusts",
    "sanction_reference": "TT/2026-27/EDU/045",
    "sanction_amount": 2500000,
    "currency": "INR",
    "sanctioned_at": "2026-05-10T00:00:00+05:30",
    "programme": "Girl Child Education",
    "tranches": 4,
    "created_at": "2026-05-15T11:00:00+05:30"
}

Subscribe to this event

From your NGO dashboard, head to System · Webhooks · Add new. Paste your HTTPS endpoint, copy the signing secret, tick grant.created in the events list, save. The first matching event fires within seconds. Verify the X-Donateazy-Signature header on every request.

// PHP example - drop into your webhook receiver
$raw = file_get_contents('php://input');
$expected = hash_hmac('sha256', $raw, $WEBHOOK_SECRET);
if (! hash_equals($expected, $_SERVER['HTTP_X_DONATEAZY_SIGNATURE'] ?? '')) {
    http_response_code(401); exit;
}

$payload = json_decode($raw, true);
if ($payload['event'] !== 'grant.created') {
    http_response_code(202); exit; // not for this handler
}

// $payload['data'] is the block documented above.
handleGrantCreated($payload['data'], $payload['id']);
http_response_code(200);

Build your first integration in 10 minutes.

Webhooks ship on Pro and above. Full API reference, signature verification and idempotency on the hub.

Read the full reference See pricing
Chat with us