mirror of
https://github.com/matrix-org/matrix-spec
synced 2025-12-24 01:58:36 +01:00
According the the openapi spec, examples for responses and schemas should be raw objects rather than being json strings. (It's unclear what non-json examples should look like...). The swagger UI used to support json strings, but no longer does. In short, let's turn the json strings into their raw formats.
101 lines
3.5 KiB
YAML
101 lines
3.5 KiB
YAML
# Copyright 2016 OpenMarket Ltd
|
|
#
|
|
# 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 Room Joining API"
|
|
version: "1.0.0"
|
|
host: localhost:8008
|
|
schemes:
|
|
- https
|
|
- http
|
|
basePath: /_matrix/client/%CLIENT_MAJOR_VERSION%
|
|
consumes:
|
|
- application/json
|
|
produces:
|
|
- application/json
|
|
securityDefinitions:
|
|
$ref: definitions/security.yaml
|
|
paths:
|
|
# With an extra " " to disambiguate from the 3pid invite endpoint
|
|
# The extra space makes it sort first for what I'm sure is a good reason.
|
|
"/rooms/{roomId}/invite ":
|
|
post:
|
|
summary: Invite a user to participate in a particular room.
|
|
description: |-
|
|
.. _invite-by-user-id-endpoint:
|
|
|
|
*Note that there are two forms of this API, which are documented separately.
|
|
This version of the API requires that the inviter knows the Matrix
|
|
identifier of the invitee. The other is documented in the*
|
|
`third party invites section`_.
|
|
|
|
This API invites a user to participate in a particular room.
|
|
They do not start participating in the room until they actually join the
|
|
room.
|
|
|
|
Only users currently in a particular room can invite other users to
|
|
join that room.
|
|
|
|
If the user was invited to the room, the homeserver will append a
|
|
``m.room.member`` event to the room.
|
|
|
|
.. _third party invites section: `invite-by-third-party-id-endpoint`_
|
|
security:
|
|
- accessToken: []
|
|
parameters:
|
|
- in: path
|
|
type: string
|
|
name: roomId
|
|
description: The room identifier (not alias) to which to invite the user.
|
|
required: true
|
|
x-example: "!d41d8cd:matrix.org"
|
|
- in: body
|
|
name: body
|
|
required: true
|
|
schema:
|
|
type: object
|
|
example: {
|
|
"user_id": "@cheeky_monkey:matrix.org"
|
|
}
|
|
properties:
|
|
user_id:
|
|
type: string
|
|
description: The fully qualified user ID of the invitee.
|
|
required: ["user_id"]
|
|
responses:
|
|
200:
|
|
description: The user has been invited to join the room.
|
|
examples:
|
|
application/json: {
|
|
}
|
|
schema:
|
|
type: object
|
|
403:
|
|
description: |-
|
|
You do not have permission to invite the user to the room. A meaningful ``errcode`` and description error text will be returned. Example reasons for rejections are:
|
|
|
|
- The invitee has been banned from the room.
|
|
- The invitee is already a member of the room.
|
|
- The inviter is not currently in the room.
|
|
- The inviter's power level is insufficient to invite users to the room.
|
|
examples:
|
|
application/json: {
|
|
"errcode": "M_FORBIDDEN", "error": "@cheeky_monkey:matrix.org is banned from the room"}
|
|
429:
|
|
description: This request was rate-limited.
|
|
schema:
|
|
"$ref": "definitions/error.yaml"
|
|
tags:
|
|
- Room membership
|