Messaging¶
This endpoint provides access to event messages sent for a specific target. Where:
- target_type- The type of the target object. The supported target types are:
- xform
- project
- user
 
 
- target_id- The unique identifier of the target object.
- verb- A specific action that has occured on the object. The supported verbs are:
- message
- submission_created
- submission_edited
- submission_deleted
- submission_reviewed
- form_updated
 
 
GET All event messages that have been sent for a form¶
Lists the events messages that have been sent for a specific form.
GET /api/v1/messaging?target_type={type}&target_id={form_id}Example¶
curl -X GET https://api.ona.io/api/v1/messaging?target_type=xform&target_id=1Response¶
[ { "id": 16485370, "verb": "message", "message": "Hey there", "user": "bob", "timestamp": "2021-02-26T03:32:57.799647-05:00" }, { "id": 16484965, "verb": "submission_deleted", "message": "{\"id\": [\"71470149\"]}", "user": "bob", "timestamp": "2021-02-26T03:28:19.512875-05:00" }, { "id": 12778522, "verb": "submission_edited", "message": "{\"id\": [71472574]}", "user": "bob", "timestamp": "2020-12-14T02:57:23.454169-05:00" }, { "id": 12778520, "verb": "submission_created", "message": "{\"id\": [71472574]}", "user": "bob", "timestamp": "2020-12-14T02:57:23.264655-05:00" } ]
GET List of events that have occured on a form for a specific verb¶
Lists out all messages sent for a specific verb.
GET /api/v1/messaging?target_type={type}&target_id={form_id}&verb={message}
Example¶
curl -X GET https://api.ona.io/api/v1/messaging?target_type=xform&target_id=1&verb=message
Response¶
[
    {
        "id": 16485370,
        "verb": "message",
        "message": "Hey there",
        "user": "bob",
        "timestamp": "2021-02-26T03:32:57.799647-05:00"
    },
    {
        "id": 16485370,
        "verb": "message",
        "message": "lorem ipsum",
        "user": "bob",
        "timestamp": "2021-02-26T03:49:57.799647-05:00"
    }
]
GET Paginate events messages for a specific verb¶
Lists out event messages using page number and the number of items per page. Use the page parameter to specify page number and page_size parameter is used to set the custom page size.
- page- Integer representing the page.
- page_size- Integer representing the number of records that should be returned in a single page.
There are a few important facts to note about retrieving paginated data:
- The maximum number of items that can be requested in a page via the - page_sizequery param is 10,000
- Information regrading transversal of the paginated responses can be found in the Link header returned in the response. Note: Some relational links may not be present depending on the page accessed i.e the ``first`` relational page link won’t be present on the first page response 
Example¶
curl -X GET https://api.ona.io/api/v1/messaging?target_type=xform&target_id=1&verb=message&page=1&page_size=1
Sample response with link header¶
Response Header:
...
Link: <https://api.ona.io/api/v1/messaging?target_type=xform&target_id=1&verb=message&page=2&page_size=1>; rel="next", <https://api.ona.io/api/v1/messaging?target_type=xform&target_id=1&verb=message&page=3&page_size=1>; rel="last"
Response:
[
    {
        "id": 16485370,
        "verb": "message",
        "message": "Hey there",
        "user": "bob",
        "timestamp": "2021-02-26T03:32:57.799647-05:00"
    }
]
Query events of a target using timestamp¶
Filter messages using the timestamp field. To filter messages by their timestamp, the timestamp parameter is appended to the messaging endpoint URL. This allows for precise retrieval of events that occurred within specific time frames or ranges.
Example¶
curl -X GET https://api.ona.io/api/v1/messaging?target_type=xform&target_id=1&verb=submission_edited×tamp__lte=2024-06-20T00:00
Where:
- target_type=xform- The target object type is xform
- target_id=1- The target object unique id, in this case the xform ID
- verb=submission_edited- The action occured on the xform, in this case a submission in the xform has been edited
- timestamp__lte=2024-06-20T00:00- Filters the events/messages to include only those that occurred on or before June 20, 2024, at 00:00 (midnight).
Timestamp field Filters Options
| Filter | Description | 
|---|---|
| timestamp__year | Exact year e.g. 2024 | 
| timestamp__year__lt | Year Less than | 
| timestamp__year__lte | Year Less than or Equal to | 
| timestamp__year__gt | Year Greater than | 
| timestamp__year__gte | Year Greater than or Equal to | 
| timestamp__month | Exact month e.g. 10 | 
| timestamp__month__lt | Month Less than | 
| timestamp__month__lte | Month Less than or Equal to | 
| timestamp__month__gt | Month Greater than | 
| timestamp__month__gte | Month Greater than or Equal to | 
| timestamp__day | Exact day e.g. 12 | 
| timestamp__day__lt | Day Less than | 
| timestamp__day__lte | Day Less than or Equal to | 
| timestamp__day__gt | Day Greater than | 
| timestamp__day__gte | Day Greater than or Equal to |