mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-18 10:52:26 +00:00
b2acb54d6a
* feat: new rest api based on the current store json-rpc api and following the same structure as the current relay rest api. * feat: the store api attend GET requests to retrieve historical messages * feat: unit tests. * feat: allow return message to rest-client in case error (4XX or 5XX) * chore: always allow to call the store api endpoints (only rest) without explicit storenode (#1575) * feat: always mounting the current node as storenode client
204 lines
5.9 KiB
YAML
204 lines
5.9 KiB
YAML
openapi: 3.0.3
|
|
info:
|
|
title: Waku V2 node REST API
|
|
version: 1.0.0
|
|
contact:
|
|
name: VAC Team
|
|
url: https://forum.vac.dev/
|
|
|
|
tags:
|
|
- name: store
|
|
description: Store REST API for WakuV2 node
|
|
|
|
paths:
|
|
/store/v1/messages:
|
|
get:
|
|
summary: Gets message history
|
|
description: >
|
|
Retrieves WakuV2 message history. The returned history
|
|
can be potentially filtered by optional request parameters.
|
|
operationId: getMessageHistory
|
|
tags:
|
|
- store
|
|
parameters:
|
|
- name: peerAddr
|
|
in: query
|
|
schema:
|
|
type: string
|
|
required: true
|
|
description: >
|
|
P2P fully qualified peer multiaddress
|
|
in the format `(ip4|ip6)/tcp/p2p/$peerId` and URL-encoded.
|
|
example: '%2Fip4%2F127.0.0.1%2Ftcp%2F60001%2Fp2p%2F16Uiu2HAmVFXtAfSj4EiR7mL2KvL4EE2wztuQgUSBoj2Jx2KeXFLN'
|
|
|
|
- name: pubsubTopic
|
|
in: query
|
|
schema:
|
|
type: string
|
|
description: >
|
|
The pubsub topic on which a WakuMessage is published.
|
|
If left empty, no filtering is applied.
|
|
It is also intended for pagination purposes.
|
|
It should be a URL-encoded string.
|
|
example: 'my%20pubsub%20topic'
|
|
|
|
- name: contentTopics
|
|
in: query
|
|
schema: string
|
|
description: >
|
|
Comma-separated list of content topics. When specified,
|
|
only WakuMessages that are linked to any of the given
|
|
content topics will be delivered in the get response.
|
|
It should be a URL-encoded-comma-separated string.
|
|
example: 'my%20first%20content%20topic%2Cmy%20second%20content%20topic%2Cmy%20third%20content%20topic'
|
|
|
|
- name: startTime
|
|
in: query
|
|
schema:
|
|
type: string
|
|
description: >
|
|
The inclusive lower bound on the timestamp of
|
|
queried WakuMessages. This field holds the
|
|
Unix epoch time in nanoseconds as a 64-bits
|
|
integer value.
|
|
example: '1680590945000000000'
|
|
|
|
- name: endTime
|
|
in: query
|
|
schema:
|
|
type: string
|
|
description: >
|
|
The inclusive upper bound on the timestamp of
|
|
queried WakuMessages. This field holds the
|
|
Unix epoch time in nanoseconds as a 64-bits
|
|
integer value.
|
|
example: '1680590945000000000'
|
|
|
|
- name: senderTime
|
|
in: query
|
|
schema:
|
|
type: string
|
|
description: >
|
|
Cursor field intended for pagination purposes.
|
|
Represents the Unix time in nanoseconds at which a message was generated.
|
|
It could be empty for retrieving the first page,
|
|
and will be returned from the GET response so that
|
|
it can be part of the next page request.
|
|
example: '1680590947000000000'
|
|
|
|
- name: storeTime
|
|
in: query
|
|
schema:
|
|
type: string
|
|
description: >
|
|
Cursor field intended for pagination purposes.
|
|
Represents the Unix time in nanoseconds at which a message was stored.
|
|
It could be empty for retrieving the first page,
|
|
and will be returned from the GET response so that
|
|
it can be part of the next page request.
|
|
example: '1680590945000000000'
|
|
|
|
- name: digest
|
|
in: query
|
|
schema:
|
|
type: string
|
|
description: >
|
|
Cursor field intended for pagination purposes.
|
|
URL-base64-encoded string computed as a hash of the
|
|
a message content topic plus a message payload.
|
|
It could be empty for retrieving the first page,
|
|
and will be returned from the GET response so that
|
|
it can be part of the next page request.
|
|
example: 'Gc4ACThW5t2QQO82huq3WnDv%2FapPPJpD%2FwJfxDxAnR0%3D'
|
|
|
|
- name: pageSize
|
|
in: query
|
|
schema:
|
|
type: string
|
|
description: >
|
|
Number of messages to retrieve per page
|
|
example: '5'
|
|
|
|
- name: ascending
|
|
in: query
|
|
schema:
|
|
type: string
|
|
description: >
|
|
"true" for paging forward, "false" for paging backward
|
|
example: "true"
|
|
|
|
responses:
|
|
'200':
|
|
description: WakuV2 message history.
|
|
content:
|
|
application/json:
|
|
schema:
|
|
$ref: '#/components/schemas/StoreResponse'
|
|
'400':
|
|
description: Bad request error.
|
|
content:
|
|
text/plain:
|
|
type: string
|
|
'412':
|
|
description: Precondition failed.
|
|
content:
|
|
text/plain:
|
|
type: string
|
|
'500':
|
|
description: Internal server error.
|
|
content:
|
|
text/plain:
|
|
type: string
|
|
|
|
components:
|
|
schemas:
|
|
StoreResponse:
|
|
type: object
|
|
properties:
|
|
messages:
|
|
type: array
|
|
items:
|
|
$ref: '#/components/schemas/WakuMessage'
|
|
cursor:
|
|
$ref: '#/components/schemas/HistoryCursor'
|
|
error_message:
|
|
type: string
|
|
required:
|
|
- messages
|
|
|
|
HistoryCursor:
|
|
type: object
|
|
properties:
|
|
pubsub_topic:
|
|
type: string
|
|
sender_time:
|
|
type: string
|
|
store_time:
|
|
type: string
|
|
digest:
|
|
type: string
|
|
required:
|
|
- pubsub_topic
|
|
- sender_time
|
|
- store_time
|
|
- digest
|
|
|
|
WakuMessage:
|
|
type: object
|
|
properties:
|
|
payload:
|
|
type: string
|
|
content_topic:
|
|
type: string
|
|
version:
|
|
type: integer
|
|
format: int32
|
|
timestamp:
|
|
type: integer
|
|
format: int64
|
|
ephemeral:
|
|
type: boolean
|
|
required:
|
|
- payload
|
|
- content_topic
|