forked from heroiclabs/nakama
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrealtime.proto
432 lines (391 loc) · 13.5 KB
/
realtime.proto
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
// Copyright 2018 The Nakama Authors
//
// 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.
/**
* The realtime protocol for Nakama server.
*/
syntax = "proto3";
package nakama.realtime;
import "google/protobuf/timestamp.proto";
import "google/protobuf/wrappers.proto";
import "github.com/heroiclabs/nakama/api/api.proto";
option go_package = "rtapi";
option java_multiple_files = true;
option java_outer_classname = "NakamaRealtime";
option java_package = "com.heroiclabs.nakama.rtapi";
option csharp_namespace = "Nakama";
option objc_class_prefix = "NKPB";
// An envelope for a realtime message.
message Envelope {
string cid = 1;
oneof message {
// A response fron a channel join operation.
Channel channel = 2;
// Join a realtime chat channel.
ChannelJoin channel_join = 3;
// Leave a realtime chat channel.
ChannelLeave channel_leave = 4;
// An incoming message on a realtime chat channel.
api.ChannelMessage channel_message = 5;
// An acknowledgement received in response to sending a message on a chat channel.
ChannelMessageAck channel_message_ack = 6;
// Send a message to a realtime chat channel.
ChannelMessageSend channel_message_send = 7;
// Update a message previously sent to a realtime chat channel.
ChannelMessageUpdate channel_message_update = 8;
// Remove a message previously sent to a realtime chat channel.
ChannelMessageRemove channel_message_remove = 9;
// Presence update for a particular realtime chat channel.
ChannelPresenceEvent channel_presence_event = 10;
// Describes an error which occurred on the server.
Error error = 11;
// Incoming information about a realtime match.
Match match = 12;
// A client to server request to create a realtime match.
MatchCreate match_create = 13;
// Incoming realtime match data delivered from the server.
MatchData match_data = 14;
// A client to server request to send data to a realtime match.
MatchDataSend match_data_send = 15;
// A client to server request to join a realtime match.
MatchJoin match_join = 16;
// A client to server request to leave a realtime match.
MatchLeave match_leave = 17;
// Presence update for a particular realtime match.
MatchPresenceEvent match_presence_event = 18;
// Submit a new matchmaking process request.
MatchmakerAdd matchmaker_add = 19;
// A successful matchmaking result.
MatchmakerMatched matchmaker_matched = 20;
// Cancel a matchmaking process using a ticket.
MatchmakerRemove matchmaker_remove = 21;
// A response from starting a new matchmaking process.
MatchmakerTicket matchmaker_ticket = 22;
// Notifications send by the server.
Notifications notifications = 23;
// RPC call or response.
api.Rpc rpc = 24;
// An incoming status snapshot for some set of users.
Status status = 25;
// Start following some set of users to receive their status updates.
StatusFollow status_follow = 26;
// An incoming status update.
StatusPresenceEvent status_presence_event = 27;
// Stop following some set of users to no longer receive their status updates.
StatusUnfollow status_unfollow = 28;
// Set the user's own status.
StatusUpdate status_update = 29;
// A data message delivered over a stream.
StreamData stream_data = 30;
// Presence update for a particular stream.
StreamPresenceEvent stream_presence_event = 31;
}
}
// A realtime chat channel.
message Channel {
// The ID of the channel.
string id = 1;
// The users currently in the channel.
repeated UserPresence presences = 2;
// A reference to the current user's presence in the channel.
UserPresence self = 3;
}
// Join operation for a realtime chat channel.
message ChannelJoin {
// The type of chat channel.
enum Type {
// Default case. Assumed as ROOM type.
TYPE_UNSPECIFIED = 0;
// A room which anyone can join to chat.
ROOM = 1;
// A private channel for 1-on-1 chat.
DIRECT_MESSAGE = 2;
// A channel for group chat.
GROUP = 3;
}
// The user ID to DM with, group ID to chat with, or room channel name to join.
string target = 1;
// The type of the chat channel.
int32 type = 2; // one of "ChannelId.Type".
// Whether messages sent on this channel should be persistent.
google.protobuf.BoolValue persistence = 3;
// Whether the user should appear in the channel's presence list and events.
google.protobuf.BoolValue hidden = 4;
}
// Leave a realtime channel.
message ChannelLeave {
// The ID of the channel to leave.
string channel_id = 1;
}
// A receipt reply from a channel message send operation.
message ChannelMessageAck {
// The channel the message was sent to.
string channel_id = 1;
// The unique ID assigned to the message.
string message_id = 2;
// The code representing a message type or category.
google.protobuf.Int32Value code = 3;
// Username of the message sender.
string username = 4;
// The UNIX time when the message was created.
google.protobuf.Timestamp create_time = 5;
// The UNIX time when the message was last updated.
google.protobuf.Timestamp update_time = 6;
// True if the message was persisted to the channel's history, false otherwise.
google.protobuf.BoolValue persistent = 7;
}
// Send a message to a realtime channel.
message ChannelMessageSend {
// The channel to sent to.
string channel_id = 1;
// Message content.
string content = 2;
}
// Update a message previously sent to a realtime channel.
message ChannelMessageUpdate {
// The channel the message was sent to.
string channel_id = 1;
// The ID assigned to the message to update.
string message_id = 2;
// New message content.
string content = 3;
}
// Remove a message previously sent to a realtime channel.
message ChannelMessageRemove {
// The channel the message was sent to.
string channel_id = 1;
// The ID assigned to the message to update.
string message_id = 2;
}
// A set of joins and leaves on a particular channel.
message ChannelPresenceEvent {
// The channel identifier this event is for.
string channel_id = 1;
// Presences joining the channel as part of this event, if any.
repeated UserPresence joins = 2;
// Presences leaving the channel as part of this event, if any.
repeated UserPresence leaves = 3;
}
// A logical error which may occur on the server.
message Error {
// The selection of possible error codes.
enum Code {
// An unexpected result from the server.
RUNTIME_EXCEPTION = 0;
// The server received a message which is not recognised.
UNRECOGNIZED_PAYLOAD = 1;
// A message was expected but contains no content.
MISSING_PAYLOAD = 2;
// Fields in the message have an invalid format.
BAD_INPUT = 3;
// The match id was not found.
MATCH_NOT_FOUND = 4;
// The match join was rejected.
MATCH_JOIN_REJECTED = 5;
// The runtime function does not exist on the server.
RUNTIME_FUNCTION_NOT_FOUND = 6;
// The runtime function executed with an error.
RUNTIME_FUNCTION_EXCEPTION = 7;
}
// The error code which should be one of "Error.Code" enums.
int32 code = 1;
// A message in English to help developers debug the response.
string message = 2;
// Additional error details which may be different for each response.
map<string, string> context = 3;
}
// A realtime match.
message Match {
// The match unique ID.
string match_id = 1;
// True if it's an server-managed authoritative match, false otherwise.
bool authoritative = 2;
// Match label, if any.
google.protobuf.StringValue label = 3;
// The number of users currently in the match.
int32 size = 4;
// The users currently in the match.
repeated UserPresence presences = 5;
// A reference to the current user's presence in the match.
UserPresence self = 6;
}
// Create a new realtime match.
message MatchCreate {}
// Realtime match data received from the server.
message MatchData {
// The match unique ID.
string match_id = 1;
// A reference to the user presence that sent this data, if any.
UserPresence presence = 2;
// Op code value.
int64 op_code = 3;
// Data payload, if any.
bytes data = 4;
}
// Send realtime match data to the server.
message MatchDataSend {
// The match unique ID.
string match_id = 1;
// Op code value.
int64 op_code = 2;
// Data payload, if any.
bytes data = 3;
// List of presences in the match to deliver to, if filtering is required. Otherwise deliver to everyone in the match.
repeated UserPresence presences = 4;
}
// Join an existing realtime match.
message MatchJoin {
oneof id {
// The match unique ID.
string match_id = 1;
// A matchmaking result token.
string token = 2;
}
// An optional set of key-value metadata pairs to be passed to the match handler, if any.
map<string, string> metadata = 3;
}
// Leave a realtime match.
message MatchLeave {
// The match unique ID.
string match_id = 1;
}
// A set of joins and leaves on a particular realtime match.
message MatchPresenceEvent {
// The match unique ID.
string match_id = 1;
// User presences that have just joined the match.
repeated UserPresence joins = 2;
// User presences that have just left the match.
repeated UserPresence leaves = 3;
}
// Start a new matchmaking process.
message MatchmakerAdd {
// Minimum total user count to match together.
int32 min_count = 1;
// Maximum total user count to match together.
int32 max_count = 2;
// Filter query used to identify suitable users.
string query = 3;
// String properties.
map<string, string> string_properties = 4;
// Numeric properties.
map<string, double> numeric_properties = 5;
}
// A successful matchmaking result.
message MatchmakerMatched {
message MatchmakerUser {
// User info.
UserPresence presence = 1;
// String properties.
map<string, string> string_properties = 5;
// Numeric properties.
map<string, double> numeric_properties = 6;
}
// The matchmaking ticket that has completed.
string ticket = 1;
// The match token or match ID to join.
oneof id {
// Match ID.
string match_id = 2;
// Match join token.
string token = 3;
}
// The users that have been matched together, and information about their matchmaking data.
repeated MatchmakerUser users = 4;
// A reference to the current user and their properties.
MatchmakerUser self = 5;
}
// Cancel an existing ongoing matchmaking process.
message MatchmakerRemove {
// The ticket to cancel.
string ticket = 1;
}
// A ticket representing a new matchmaking process.
message MatchmakerTicket {
// The ticket that can be used to cancel matchmaking.
string ticket = 1;
}
// A collection of zero or more notifications.
message Notifications {
// Collection of notifications.
repeated api.Notification notifications = 1;
}
// A snapshot of statuses for some set of users.
message Status {
// User statuses.
repeated UserPresence presences = 1;
}
// Start receiving status updates for some set of users.
message StatusFollow {
// Users to follow.
repeated string user_ids = 1;
}
// A batch of status updates for a given user.
message StatusPresenceEvent {
// New statuses for the user.
repeated UserPresence joins = 2;
// Previous statuses for the user.
repeated UserPresence leaves = 3;
}
// Stop receiving status updates for some set of users.
message StatusUnfollow {
// Users to unfollow.
repeated string user_ids = 1;
}
// Set the user's own status.
message StatusUpdate {
// Status string to set, if not present the user will appear offline.
google.protobuf.StringValue status = 1;
}
// Represents identifying information for a stream.
message Stream {
// Mode identifies the type of stream.
int32 mode = 1;
// Subject is the primary identifier, if any.
string subject = 2;
// Subcontext is a secondary identifier, if any.
string subcontext = 3;
// The label is an arbitrary identifying string, if the stream has one.
string label = 4;
}
// A data message delivered over a stream.
message StreamData {
// The stream this data message relates to.
Stream stream = 1;
// The sender, if any.
UserPresence sender = 2;
// Arbitrary contents of the data message.
string data = 3;
}
// A set of joins and leaves on a particular stream.
message StreamPresenceEvent {
// The stream this event relates to.
Stream stream = 1;
// Presences joining the stream as part of this event, if any.
repeated UserPresence joins = 2;
// Presences leaving the stream as part of this event, if any.
repeated UserPresence leaves = 3;
}
// A user session associated to a stream, usually through a list operation or a join/leave event.
message UserPresence {
// The user this presence belongs to.
string user_id = 1;
// A unique session ID identifying the particular connection, because the user may have many.
string session_id = 2;
// The username for display purposes.
string username = 3;
// Whether this presence generates persistent data/messages, if applicable for the stream type.
bool persistence = 4;
// A user-set status message for this stream, if applicable.
google.protobuf.StringValue status = 5;
}