@rbxts/tether 1.0.2 → 1.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +3 -5
- package/out/index.d.ts +12 -9
- package/out/init.luau +60 -4
- package/package.json +4 -3
package/README.md
CHANGED
|
@@ -3,9 +3,9 @@ A message-based networking solution for Roblox with automatic binary serializati
|
|
|
3
3
|
|
|
4
4
|
### In `shared/messaging.ts`
|
|
5
5
|
```ts
|
|
6
|
-
import { DataType } from "@rbxts/flamework-binary-serializer";
|
|
6
|
+
import type { DataType } from "@rbxts/flamework-binary-serializer";
|
|
7
7
|
|
|
8
|
-
export const messageEmitter =
|
|
8
|
+
export const messageEmitter = MessageEmitter.create<MessageData>();
|
|
9
9
|
messageEmitter.initialize();
|
|
10
10
|
|
|
11
11
|
export const enum Message {
|
|
@@ -18,12 +18,10 @@ export interface MessageData {
|
|
|
18
18
|
readonly n: DataType.u8;
|
|
19
19
|
};
|
|
20
20
|
}
|
|
21
|
-
|
|
22
|
-
messageEmitter.addSerializer<Message.TOGGLE_MOVEMENT>(Message.TOGGLE_MOVEMENT);
|
|
23
21
|
```
|
|
24
22
|
|
|
25
23
|
> [!CAUTION]
|
|
26
|
-
> Every single message kind must implement an interface for it's data (in the example that would be the object with the `foo` and `bar` fields) as well as
|
|
24
|
+
> Every single message kind must implement an interface for it's data (in the example that would be the object with the `foo` and `bar` fields). Message serialization (as well as your message itself) will not work if you don't do this.
|
|
27
25
|
|
|
28
26
|
### Server
|
|
29
27
|
```ts
|
package/out/index.d.ts
CHANGED
|
@@ -2,22 +2,25 @@ import { Modding } from "@flamework/core";
|
|
|
2
2
|
import { type SerializerMetadata } from "@rbxts/flamework-binary-serializer";
|
|
3
3
|
type ClientMessageCallback<T = unknown> = (data: T) => void;
|
|
4
4
|
type ServerMessageCallback<T = unknown> = (player: Player, data: T) => void;
|
|
5
|
-
|
|
6
|
-
export declare class MessageEmitter<Message extends BaseMessage, MessageData extends Record<Message, unknown>> {
|
|
5
|
+
export declare class MessageEmitter<MessageData> {
|
|
7
6
|
private readonly clientCallbacks;
|
|
8
7
|
private readonly serverCallbacks;
|
|
9
8
|
private readonly serializers;
|
|
10
9
|
private readonly serverEvents;
|
|
11
10
|
private readonly clientEvents;
|
|
12
|
-
constructor();
|
|
13
11
|
/** @metadata macro */
|
|
14
|
-
|
|
12
|
+
static create<MessageData>(metaForEachMessage?: Modding.Many<{
|
|
13
|
+
[Kind in keyof MessageData]: Modding.Many<SerializerMetadata<MessageData[Kind]>>;
|
|
14
|
+
}>): MessageEmitter<MessageData>;
|
|
15
|
+
private constructor();
|
|
16
|
+
/** @metadata macro */
|
|
17
|
+
addSerializer<Kind extends keyof MessageData>(message: Kind, meta?: Modding.Many<SerializerMetadata<MessageData[Kind]>>): void;
|
|
15
18
|
initialize(): RBXScriptConnection;
|
|
16
|
-
onServerMessage<Kind extends
|
|
17
|
-
onClientMessage<Kind extends
|
|
18
|
-
emitServer<Kind extends
|
|
19
|
-
emitClient<Kind extends
|
|
20
|
-
emitAllClients<Kind extends
|
|
19
|
+
onServerMessage<Kind extends keyof MessageData>(message: Kind, callback: ServerMessageCallback<MessageData[Kind]>): () => void;
|
|
20
|
+
onClientMessage<Kind extends keyof MessageData>(message: Kind, callback: ClientMessageCallback<MessageData[Kind]>): () => void;
|
|
21
|
+
emitServer<Kind extends keyof MessageData>(message: Kind, data: MessageData[Kind], unreliable?: boolean): void;
|
|
22
|
+
emitClient<Kind extends keyof MessageData>(player: Player, message: Kind, data: MessageData[Kind], unreliable?: boolean): void;
|
|
23
|
+
emitAllClients<Kind extends keyof MessageData>(message: Kind, data: MessageData[Kind], unreliable?: boolean): void;
|
|
21
24
|
private getPacket;
|
|
22
25
|
/** @metadata macro */
|
|
23
26
|
private createMessageSerializer;
|
package/out/init.luau
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
-- Compiled with roblox-ts v3.0.0
|
|
2
2
|
local TS = _G[script]
|
|
3
|
+
local t = TS.import(script, TS.getModule(script, "@rbxts", "t").lib.ts).t
|
|
3
4
|
local Networking = TS.import(script, TS.getModule(script, "@flamework", "networking").out).Networking
|
|
4
5
|
local createBinarySerializer = TS.import(script, TS.getModule(script, "@rbxts", "flamework-binary-serializer").out).createBinarySerializer
|
|
5
6
|
local RunService = TS.import(script, TS.getModule(script, "@rbxts", "services")).RunService
|
|
6
|
-
local GlobalEvents = Networking.createEvent()
|
|
7
|
+
local GlobalEvents = Networking.createEvent("@rbxts/tether:init@GlobalEvents")
|
|
7
8
|
local MessageEmitter
|
|
8
9
|
do
|
|
9
10
|
MessageEmitter = setmetatable({}, {
|
|
@@ -21,11 +22,66 @@ do
|
|
|
21
22
|
self.serverCallbacks = {}
|
|
22
23
|
self.serializers = {}
|
|
23
24
|
if RunService:IsServer() then
|
|
24
|
-
self.serverEvents = GlobalEvents:createServer({}
|
|
25
|
+
self.serverEvents = GlobalEvents:createServer({}, {
|
|
26
|
+
incomingIds = { "sendServerMessage", "sendUnreliableServerMessage" },
|
|
27
|
+
incoming = {
|
|
28
|
+
sendServerMessage = { { t.union(t.string, t.number), t.interface({
|
|
29
|
+
buffer = t.typeof("buffer"),
|
|
30
|
+
blobs = t.array(t.any),
|
|
31
|
+
}) }, nil },
|
|
32
|
+
sendUnreliableServerMessage = { { t.union(t.string, t.number), t.interface({
|
|
33
|
+
buffer = t.typeof("buffer"),
|
|
34
|
+
blobs = t.array(t.any),
|
|
35
|
+
}) }, nil },
|
|
36
|
+
},
|
|
37
|
+
incomingUnreliable = {
|
|
38
|
+
sendUnreliableServerMessage = true,
|
|
39
|
+
},
|
|
40
|
+
outgoingIds = { "sendClientMessage", "sendUnreliableClientMessage" },
|
|
41
|
+
outgoingUnreliable = {
|
|
42
|
+
sendUnreliableClientMessage = true,
|
|
43
|
+
},
|
|
44
|
+
namespaceIds = {},
|
|
45
|
+
namespaces = {},
|
|
46
|
+
})
|
|
25
47
|
else
|
|
26
|
-
self.clientEvents = GlobalEvents:createClient({}
|
|
48
|
+
self.clientEvents = GlobalEvents:createClient({}, {
|
|
49
|
+
incomingIds = { "sendClientMessage", "sendUnreliableClientMessage" },
|
|
50
|
+
incoming = {
|
|
51
|
+
sendClientMessage = { { t.union(t.string, t.number), t.interface({
|
|
52
|
+
buffer = t.typeof("buffer"),
|
|
53
|
+
blobs = t.array(t.any),
|
|
54
|
+
}) }, nil },
|
|
55
|
+
sendUnreliableClientMessage = { { t.union(t.string, t.number), t.interface({
|
|
56
|
+
buffer = t.typeof("buffer"),
|
|
57
|
+
blobs = t.array(t.any),
|
|
58
|
+
}) }, nil },
|
|
59
|
+
},
|
|
60
|
+
incomingUnreliable = {
|
|
61
|
+
sendUnreliableClientMessage = true,
|
|
62
|
+
},
|
|
63
|
+
outgoingIds = { "sendServerMessage", "sendUnreliableServerMessage" },
|
|
64
|
+
outgoingUnreliable = {
|
|
65
|
+
sendUnreliableServerMessage = true,
|
|
66
|
+
},
|
|
67
|
+
namespaceIds = {},
|
|
68
|
+
namespaces = {},
|
|
69
|
+
})
|
|
27
70
|
end
|
|
28
71
|
end
|
|
72
|
+
function MessageEmitter:create(metaForEachMessage)
|
|
73
|
+
if metaForEachMessage == nil then
|
|
74
|
+
warn("[Tether]: Failed to generate serializer metadata for MessageEmitter")
|
|
75
|
+
end
|
|
76
|
+
local emitter = MessageEmitter.new()
|
|
77
|
+
if metaForEachMessage == nil then
|
|
78
|
+
return emitter
|
|
79
|
+
end
|
|
80
|
+
for kind, meta in pairs(metaForEachMessage) do
|
|
81
|
+
emitter:addSerializer(kind, meta)
|
|
82
|
+
end
|
|
83
|
+
return emitter
|
|
84
|
+
end
|
|
29
85
|
function MessageEmitter:addSerializer(message, meta)
|
|
30
86
|
self.serializers[message] = self:createMessageSerializer(meta)
|
|
31
87
|
end
|
|
@@ -148,7 +204,7 @@ do
|
|
|
148
204
|
return createBinarySerializer(meta)
|
|
149
205
|
end
|
|
150
206
|
function MessageEmitter:getSerializer(message)
|
|
151
|
-
return self.serializers[message]
|
|
207
|
+
return self.serializers[tostring(message)]
|
|
152
208
|
end
|
|
153
209
|
end
|
|
154
210
|
return {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rbxts/tether",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.4",
|
|
4
4
|
"main": "out/init.lua",
|
|
5
5
|
"scripts": {
|
|
6
6
|
"build": "rbxtsc",
|
|
@@ -14,7 +14,7 @@
|
|
|
14
14
|
"message"
|
|
15
15
|
],
|
|
16
16
|
"repository": {
|
|
17
|
-
"url": "https://github.com/R-unic/tether.git"
|
|
17
|
+
"url": "git+https://github.com/R-unic/tether.git"
|
|
18
18
|
},
|
|
19
19
|
"author": "runicly",
|
|
20
20
|
"license": "ISC",
|
|
@@ -30,8 +30,9 @@
|
|
|
30
30
|
"devDependencies": {
|
|
31
31
|
"@rbxts/compiler-types": "^3.0.0-types.0",
|
|
32
32
|
"@rbxts/types": "^1.0.835",
|
|
33
|
+
"rbxts-transformer-flamework": "latest",
|
|
33
34
|
"roblox-ts": "^3.0.0",
|
|
34
|
-
"typescript": "^5.
|
|
35
|
+
"typescript": "^5.5.3"
|
|
35
36
|
},
|
|
36
37
|
"dependencies": {
|
|
37
38
|
"@flamework/core": "^1.2.3",
|