matrix-spec/data/api/client-server/relations.yaml

171 lines
6.8 KiB
YAML
Raw Normal View History

2022-05-18 05:43:47 +02:00
# Copyright 2022 The Matrix.org Foundation C.I.C.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
swagger: '2.0'
info:
title: "Matrix Client-Server Relations API"
version: "1.0.0"
host: localhost:8008
schemes:
- https
- http
basePath: /_matrix/client/v1
consumes:
- application/json
produces:
- application/json
securityDefinitions:
$ref: definitions/security.yaml
paths:
"/rooms/{roomId}/relations/{eventId}/{relType}/{eventType}":
get:
summary: Get the child events for a given parent event, with optional filter.
2022-05-18 05:43:47 +02:00
description: |-
Retrieve all of the child events for a given parent event, optionally filtering
2022-05-18 05:43:47 +02:00
down by relationship type and related event type.
Note that while this endpoint indicates `relType` and `eventType` being
required, they can be individually omitted to retrieve all matching events.
When omitting the path parameters, a trailing slash must not be included
(otherwise the search will be for an empty string).
2022-05-27 05:00:10 +02:00
When combining the use of `relType` and `eventType`, the server will return
child events which match *both* conditions rather than *either*.
operationId: getRelatingEvents
2022-05-18 05:43:47 +02:00
security:
- accessToken: []
parameters:
- in: path
type: string
name: roomId
description: The ID of the room containing the parent event.
2022-05-18 05:43:47 +02:00
required: true
x-example: "!636q39766251:matrix.org"
- in: path
type: string
name: eventId
description: The ID of the parent event whose child events are to be returned.
2022-05-18 05:43:47 +02:00
required: true
x-example: "$asfDuShaf7Gafaw"
- in: path
type: string
name: relType
description: |-
The [relationship type](/client-server-api/#relationship-types) to search
2022-05-27 05:00:10 +02:00
for, if any. Exclude to find all child events which point to the supposed parent
2022-05-18 05:43:47 +02:00
event with any `rel_type`.
required: true # we can't say false, annoyingly
x-example: "org.example.my_relation"
- in: path
type: string
name: eventType
description: |-
2022-05-27 05:00:10 +02:00
The event type of child events to search for, if any. Exclude to find all
child events of any type which point to the supposed parent event.
2022-05-18 05:43:47 +02:00
Note that in encrypted rooms this will typically always be `m.room.encrypted`
regardless of the event type contained within the encrypted payload.
required: true # we can't say false, annoyingly
x-example: "m.room.message"
- in: query
type: string
name: from
description: |-
The pagination token to start returning results from. If not supplied, results
start at the earliest topological event known to the server.
Can be a `next_batch` or `prev_batch` token from a previous call, or an equivalent
token from [`/messages`](/client-server-api/#get_matrixclientv3roomsroomidmessages)
or [`/sync`](/client-server-api/#get_matrixclientv3sync) to limit results to the
events returned by that section of timeline.
required: false
x-example: "page2_token"
- in: query
type: string
name: to
description: |-
The pagination token to stop returning results at. If not supplied, results
continue up to `limit` or until there are no more events.
Like `from`, this can be a previous token from a prior call to this endpoint
or from `/messages` or `/sync` to limit to a section of timeline.
required: false
x-example: "page3_token"
- in: query
type: integer
name: limit
description: |-
The maximum number of results to return in a single `chunk`. The server can
and should apply a maximum value to this parameter to avoid large responses.
Similarly, the server should apply a default value when not supplied.
required: false
x-example: 20
responses:
# note: this endpoint deliberately does not support rate limiting, therefore a
# 429 error response is not included.
200:
description: |-
2022-05-27 05:00:10 +02:00
The paginated child events which point to the supposed parent. If no events are
pointing to the parent, an empty `chunk` is returned.
2022-05-18 05:43:47 +02:00
examples:
application/json: {
"chunk": [{
"room_id": "!636q39766251:matrix.org",
"$ref": "../../event-schemas/examples/m.room.message$m.text.yaml",
"content": {
"m.relates_to": {
"rel_type": "org.example.my_relation",
"event_id": "$asfDuShaf7Gafaw"
}
}
}],
"next_batch": "page2_token",
"prev_batch": "page1_token"
}
schema:
type: object
properties:
chunk:
2022-05-27 05:00:10 +02:00
title: "ChildEventsChunk"
2022-05-18 05:43:47 +02:00
type: array
description: |-
2022-05-27 05:00:10 +02:00
The child events which point to the parent event, after applicable filters.
2022-05-18 05:43:47 +02:00
items:
allOf:
- "$ref": "definitions/client_event.yaml"
next_batch:
type: string
description: |-
An opaque string representing a pagination token. The absence of this token
means there are no more results to fetch and the client should stop paginating.
prev_batch:
type: string
description: |-
An opaque string representing a pagination token. The absence of this token
means there are no prior results to fetch, i.e. this is the first batch.
404:
2022-05-27 05:00:10 +02:00
description: |-
The parent event was not found or the user does not have permission to read
2022-05-27 05:00:10 +02:00
this event (it might be contained in history that is not accessible to the user).
2022-05-18 05:43:47 +02:00
examples:
application/json: {
"errcode": "M_NOT_FOUND",
"error": "Event not found."
}
schema:
"$ref": "definitions/errors/error.yaml"
tags:
- Event relationships