Merge remote-tracking branch 'origin/master'

# Conflicts:
#	server/src/index.ts
#	server/src/types.ts
This commit is contained in:
Danya H 2024-06-11 02:50:29 +01:00
commit fa4c218a7a
2 changed files with 29 additions and 31 deletions

View File

@ -7,17 +7,19 @@ import {
RageFW_ServerEventCallback,
} from './types.js'
import { nativeEvents } from './native.events'
import type { RageFW_ICustomServerEvent } from 'rage-fw-shared-types'
class Server {
private isNativeEvent(eventName: string): eventName is keyof IServerEvents {
return nativeEvents.includes(eventName)
}
private isCustomEvent(
eventName: string,
): eventName is keyof RageFW_ICustomServerEvent {
return !nativeEvents.includes(eventName)
public testRegister(
event: string,
callback: (player: PlayerMp, ...args: unknown[]) => void,
) {
rpc.register(event, async (data, info) => {
callback(info.player as PlayerMp, ...data)
})
}
public register<EventName extends RageFW_ServerEvent>(
@ -26,29 +28,30 @@ class Server {
): void {
if (this.isNativeEvent(eventName)) {
mp.events.add(eventName, callback)
} else if (this.isCustomEvent(eventName)) {
rpc.register(eventName, callback as rpc.ProcedureListener)
} else {
rpc.register(eventName, async (data: any[], info) => {
return callback(info.player as PlayerMp, data)
})
}
}
public registerMany<EventName extends RageFW_ServerEvent>(events: {
[event in EventName]: RageFW_ServerEventCallback<event>
}): void {
Object.entries<RageFW_ServerEventCallback<EventName>>(events).map(
([eventName, callback]) => {
if (this.isNativeEvent(eventName)) {
mp.events.add(eventName, callback)
} else if (this.isCustomEvent(eventName)) {
rpc.register(eventName, (args: unknown[]) => {
return Array.isArray(args)
? (callback as (...arg: typeof args) => void)(
...args,
)
: (callback as (arg: typeof args) => void)(args)
})
}
},
)
Object.entries(events).map(([eventName, callback]) => {
if (nativeEvents.includes(eventName)) {
mp.events.add(
eventName as keyof IServerEvents,
callback as (...arg: unknown[]) => void,
)
} else {
rpc.register(eventName, (args: unknown[]) => {
return Array.isArray(args)
? (callback as (...arg: typeof args) => void)(...args)
: (callback as (arg: typeof args) => void)(args)
})
}
})
}
}
@ -67,9 +70,8 @@ export const fw = {
player: new Player(),
}
fw.event.register('ggfdgfd', player => {})
fw.event.registerMany({
playerDeath: (player, arg, killer) => undefined,
customServerEvent(player, rofls) {
return true
},
trailerAttached: player => {},
})

View File

@ -5,8 +5,6 @@ import type {
RageFW_ICustomClientEvent,
} from 'rage-fw-shared-types'
// SERVER
export type RageFW_ServerEvent =
| keyof RageFW_ICustomServerEvent
| keyof IServerEvents
@ -18,11 +16,9 @@ export type RageFW_ServerEventCallback<K extends RageFW_ServerEvent> =
...args: Parameters<RageFW_ICustomServerEvent[K]>
) => ReturnType<RageFW_ICustomServerEvent[K]>
: K extends keyof IServerEvents
? IServerEvents[K]
? ThisifyServerEvents[K]
: never
// CLIENT
export type RageFW_ClientEvent = keyof RageFW_ICustomClientEvent
export type RageFW_ClientEventArguments<K extends RageFW_ClientEvent> =