@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 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 = new MessageEmitter<Message, MessageData>;
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 call `MessageEmitter.addSerializer()`. Messages will not work if you don't do this.
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
- type BaseMessage = number | string;
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
- addSerializer<Kind extends Message>(message: Kind, meta?: Modding.Many<SerializerMetadata<MessageData[Kind]>>): void;
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 Message>(message: Kind, callback: ServerMessageCallback<MessageData[Kind]>): () => void;
17
- onClientMessage<Kind extends Message>(message: Kind, callback: ClientMessageCallback<MessageData[Kind]>): () => void;
18
- emitServer<Kind extends Message>(message: Kind, data: MessageData[Kind], unreliable?: boolean): void;
19
- emitClient<Kind extends Message>(player: Player, message: Kind, data: MessageData[Kind], unreliable?: boolean): void;
20
- emitAllClients<Kind extends Message>(message: Kind, data: MessageData[Kind], unreliable?: boolean): void;
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.2",
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.7.3"
35
+ "typescript": "^5.5.3"
35
36
  },
36
37
  "dependencies": {
37
38
  "@flamework/core": "^1.2.3",