Skip to main content
Spark360 publishes lead and widget events from application-layer trigger points after core data writes complete.
EventleadStatusS360 Outbound EventTriggerAvailability
lead.createdaddress_info_providedlead.address_previewLeads INSERTOptional
lead.updatedproject_details_provided(no outbound event)
lead.updatedpersonal_info_and_estimate_providedlead.enrichedEnrichment write-back completeREQUIRED — locked
lead.updatedpersonal_info_and_estimate_provided + ownerOccupied=falselead.rental_alertSame as above, occupancy checkOptional
lead.updatedcontact_info_providedlead.contact_requestedLeads UPDATEOptional
widget.updatedn/awidget.status_changedorganizations.widget_status UPDATEOptional
lead.enriched is mandatory for every webhook subscription and cannot be deselected.

Source tracking — captured per-widget

Every lead event includes a source_tracking block reflecting the specific widget and source that captured the lead. For multi-widget organizations (Ultimate and Premium tiers), the values identify which specific widget produced the lead:
{
  "source_tracking": {
    "widget_version": "02",
    "widget_name": "New Spark 02",
    "source_code": "03",
    "source_label": "Instagram"
  }
}
For single-widget organizations (Starter tier), the values default to the Primary widget and the originating source:
{
  "source_tracking": {
    "widget_version": "01",
    "widget_name": "Primary",
    "source_code": "01",
    "source_label": "Website"
  }
}

Event sequencing notes

  1. lead.address_preview fires first on initial address submission and is address-only (no name or contact info).
  2. lead.enriched fires after enrichment is complete and write-back includes scores, buyer insights, and roof estimate fields.
  3. lead.rental_alert can fire alongside lead.enriched when owner_occupied = false.
  4. lead.contact_requested fires last only if the homeowner completes the optional contact preference step.
lead.contact_requested is optional and only fires when the final contact step is completed. It always arrives after lead.enriched, never before.