You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
64 lines
2.3 KiB
Plaintext
64 lines
2.3 KiB
Plaintext
{
|
|
"$schema": "http://json-schema.org/draft-04/schema#",
|
|
"definitions": {
|
|
"event": {
|
|
"title": "Event",
|
|
"description": "The basic set of fields all events must have.",
|
|
"type": "object",
|
|
"properties": {
|
|
"event_id": {
|
|
"type": "string",
|
|
"description": "The globally unique event identifier."
|
|
},
|
|
"user_id": {
|
|
"type": "string",
|
|
"description": "Contains the fully-qualified ID of the user who *sent* this event."
|
|
},
|
|
"content": {
|
|
"type": "object",
|
|
"description": "The fields in this object will vary depending on the type of event. When interacting with the REST API, this is the HTTP body."
|
|
},
|
|
"type": {
|
|
"type": "string",
|
|
"description": "The type of event. This SHOULD be namespaced similar to Java package naming conventions e.g. 'com.example.subdomain.event.type'"
|
|
}
|
|
},
|
|
"required": ["event_id", "user_id", "content", "type"]
|
|
},
|
|
"room_event": {
|
|
"type": "object",
|
|
"title": "Room Event",
|
|
"description": "In addition to the Event fields, Room Events MUST have the following additional field.",
|
|
"allOf":[{
|
|
"$ref": "#/definitions/event"
|
|
}],
|
|
"properties": {
|
|
"room_id": {
|
|
"type": "string",
|
|
"description": "The ID of the room associated with this event."
|
|
}
|
|
},
|
|
"required": ["room_id"]
|
|
},
|
|
"state_event": {
|
|
"type": "object",
|
|
"title": "State Event",
|
|
"description": "In addition to the Room Event fields, State Events have the following additional fields.",
|
|
"allOf":[{
|
|
"$ref": "#/definitions/room_event"
|
|
}],
|
|
"properties": {
|
|
"state_key": {
|
|
"type": "string",
|
|
"description": "A unique key which defines the overwriting semantics for this piece of room state. This value is often a zero-length string. The presence of this key makes this event a State Event."
|
|
},
|
|
"prev_content": {
|
|
"type": "object",
|
|
"description": "Optional. The previous ``content`` for this event. If there is no previous content, this key will be missing."
|
|
}
|
|
},
|
|
"required": ["state_key"]
|
|
}
|
|
}
|
|
}
|