This endpoint lets you publish data to multiple consumers who are listening on a topic
.
Dapr guarantees at least once semantics for this endpoint.
POST http://localhost:<daprPort>/v1.0/publish/<pubsubname>/<topic>
Code | Description |
---|---|
200 | Message delivered |
500 | Delivery failed |
Parameter | Description |
---|---|
daprPort | the Dapr port |
pubsubname | the name of pubsub component. |
topic | the name of the topic |
Note, all URL parameters are case-sensitive.
curl -X POST http://localhost:3500/v1.0/publish/pubsubName/deathStarStatus \
-H "Content-Type: application/json" \
-d '{
"status": "completed"
}'
Dapr will invoke the following endpoint on user code to discover topic subscriptions:
GET http://localhost:<appPort>/dapr/subscribe
Parameter | Description |
---|---|
appPort | the application port |
A json encoded array of strings.
Example:
[
{
"pubsubname": "pubsub",
"topic": "newOrder",
"route": "/orders"
}
]
Note, all subscription parameters are case-sensitive.
In order to deliver topic events, a POST
call will be made to user code with the route specified in the subscription response.
The following example illustrates this point, considering a subscription for topic newOrder
with route orders
on port 3000: POST http://localhost:3000/orders
POST http://localhost:<appPort>/<path>
Note, all URL parameters are case-sensitive.
Parameter | Description |
---|---|
appPort | the application port |
path | route path from the subscription configuration |
An HTTP 200 response with JSON encoded payload body with the processing status:
{
"status": "<status>"
}
Status | Description |
---|---|
SUCCESS | message is processed successfully |
RETRY | message to be retried by Dapr |
DROP | warning is logged and message is dropped |
For empty payload responses in HTTP 2xx, Dapr assumes SUCCESS
.
The HTTP response might be different from HTTP 2xx, the following are Dapr's behavior in different HTTP statuses:
HTTP Status | Description |
---|---|
2xx | message is processed as per status in payload (SUCCESS if empty; ignored if invalid payload). |
404 | error is logged and message is dropped |
other | warning is logged and message to be retried |
Dapr Pub/Sub adheres to version 1.0 of Cloud Events.