Compare commits

...

2 Commits

Author SHA1 Message Date
59910303f7 upd core
- moved to rage-fw-rpc
2024-10-28 12:11:24 +00:00
828a3deb33 upd cli
- added rpc tests
- removed git clone
2024-10-28 12:10:58 +00:00
17 changed files with 249 additions and 93 deletions

View File

@ -11,7 +11,7 @@
"build": "tsup" "build": "tsup"
}, },
"dependencies": { "dependencies": {
"ragefw-rpc": "workspace:^" "rage-fw-rpc": "workspace:^"
}, },
"peerDependencies": { "peerDependencies": {
"@ragempcommunity/types-cef": "^2.1.8", "@ragempcommunity/types-cef": "^2.1.8",

View File

@ -1,6 +1,6 @@
import rpc from 'rage-rpc' import { Rpc } from 'rage-fw-rpc'
import { import type {
_CefEventHasArgs, _CefEventHasArgs,
_ClientEventHasArgs, _ClientEventHasArgs,
_ServerEventHasArgs, _ServerEventHasArgs,
@ -18,11 +18,18 @@ import {
class Cef { class Cef {
private _debugMode: boolean = false private _debugMode: boolean = false
private _rpc: Rpc = new Rpc()
constructor() {}
set debug(debug: boolean) { set debug(debug: boolean) {
this._debugMode = debug this._debugMode = debug
} }
get rpc(): Rpc {
return this._rpc
}
public register<EventName extends keyof RageFW_ICustomCefEvent>( public register<EventName extends keyof RageFW_ICustomCefEvent>(
eventName: EventName, eventName: EventName,
callback: RageFW_CefCallback<EventName>, callback: RageFW_CefCallback<EventName>,
@ -32,11 +39,11 @@ class Cef {
} }
if ('mp' in window) { if ('mp' in window) {
rpc.register(eventName, callback) this._rpc.register(eventName, callback)
} }
} }
public trigger<EventName extends keyof RageFW_ICustomCefEvent>( public async trigger<EventName extends keyof RageFW_ICustomCefEvent>(
eventName: EventName, eventName: EventName,
...args: _CefEventHasArgs<EventName> extends true ...args: _CefEventHasArgs<EventName> extends true
? [RageFW_CefArgs<EventName>] ? [RageFW_CefArgs<EventName>]
@ -47,7 +54,7 @@ class Cef {
} }
if ('mp' in window) { if ('mp' in window) {
return rpc.call(eventName, args) return await this._rpc.call(eventName, args)
} }
return Promise.reject( return Promise.reject(
@ -55,7 +62,9 @@ class Cef {
) )
} }
public triggerServer<EventName extends keyof RageFW_ICustomServerEvent>( public async triggerServer<
EventName extends keyof RageFW_ICustomServerEvent,
>(
eventName: EventName, eventName: EventName,
...args: _ServerEventHasArgs<EventName> extends true ...args: _ServerEventHasArgs<EventName> extends true
? [RageFW_ServerArgs<EventName>] ? [RageFW_ServerArgs<EventName>]
@ -66,7 +75,7 @@ class Cef {
} }
if ('mp' in window) { if ('mp' in window) {
return rpc.callServer(eventName, args) return await this._rpc.callServer(eventName, args)
} }
return Promise.reject( return Promise.reject(
@ -74,7 +83,9 @@ class Cef {
) )
} }
public triggerClient<EventName extends keyof RageFW_ICustomClientEvent>( public async triggerClient<
EventName extends keyof RageFW_ICustomClientEvent,
>(
eventName: EventName, eventName: EventName,
...args: _ClientEventHasArgs<EventName> extends true ...args: _ClientEventHasArgs<EventName> extends true
? [RageFW_ClientArgs<EventName>] ? [RageFW_ClientArgs<EventName>]
@ -85,7 +96,7 @@ class Cef {
} }
if ('mp' in window) { if ('mp' in window) {
return rpc.callClient(eventName, args) return await this._rpc.callClient(eventName, args)
} }
return Promise.reject( return Promise.reject(

View File

@ -16,13 +16,11 @@
], ],
"dependencies": { "dependencies": {
"@inquirer/prompts": "^5.0.5", "@inquirer/prompts": "^5.0.5",
"axios": "^1.7.2", "ky": "^1.7.2",
"chalk": "4.1.2", "chalk": "4.1.2",
"git-clone": "^0.2.0",
"yargs": "^17.7.2" "yargs": "^17.7.2"
}, },
"devDependencies": { "devDependencies": {
"@types/git-clone": "^0.2.4",
"@types/node": "^20.14.2", "@types/node": "^20.14.2",
"@types/yargs": "^17.0.32", "@types/yargs": "^17.0.32",
"prettier": "^3.3.2", "prettier": "^3.3.2",

View File

@ -1,7 +1,7 @@
import c from 'chalk' import c from 'chalk'
import { input, select } from '@inquirer/prompts' import { input, select } from '@inquirer/prompts'
import clone from 'git-clone'
import path from 'node:path' import path from 'node:path'
import { cloneBranch } from '../utils/cloner'
export async function initProject() { export async function initProject() {
let folder let folder
@ -10,7 +10,7 @@ export async function initProject() {
if (!folder) { if (!folder) {
folder = await input({ folder = await input({
message: c.gray('Enter project name:'), message: c.gray('Enter project name:'),
default: 'rage-fw', default: 'rage-fw-example',
}) })
} else { } else {
console.log(c.gray('Project name:'), folder) console.log(c.gray('Project name:'), folder)
@ -19,19 +19,14 @@ export async function initProject() {
if (!framework) { if (!framework) {
framework = await select({ framework = await select({
message: c.gray('Select frontend:'), message: c.gray('Select frontend:'),
default: 'react', default: 'react-18',
loop: true, loop: true,
choices: [ choices: [
{ {
name: 'React + TypeScript (Vite)', name: 'React + TypeScript (Vite)',
value: 'react', value: 'react-18',
description: 'React + TypeScript (Vite) as a frontend', description: 'React + TypeScript (Vite) as a frontend',
}, },
// {
// name: 'vue',
// value: 'vue',
// description: 'npm is the most popular package manager',
// },
], ],
}) })
} else { } else {
@ -46,21 +41,20 @@ export async function initProject() {
c.gray('as a frontend..'), c.gray('as a frontend..'),
) )
clone( cloneBranch(
'https://git.entityseven.com/entityseven/rage-framework-example', 'https://git.entityseven.com/entityseven/rage-framework-example',
path.join(process.cwd(), folder), path.join(process.cwd(), folder),
{}, framework,
err => { )
if (err) { .then(() => {
console.log(c.red('Error occured: \n', err))
return
}
console.log(c.gray('Scaffolded project into'), folder) console.log(c.gray('Scaffolded project into'), folder)
console.log( console.log(
c.gray( c.gray(
`Project was created ar dir: ${path.join(process.cwd(), folder)}`, `Project was created ar dir: ${path.join(process.cwd(), folder)}`,
), ),
) )
}, })
) .catch(e => {
console.log(c.red('Error occured: \n', e))
})
} }

View File

@ -1,4 +1,3 @@
import axios from 'axios'
import * as fs from 'node:fs' import * as fs from 'node:fs'
const latestReleases = const latestReleases =
@ -13,25 +12,33 @@ type Asset = {
} }
export async function downloadUpdater(): Promise<void> { export async function downloadUpdater(): Promise<void> {
const ky = await import('ky').then(ky => ky.default)
const id = await getLatestReleaseID() const id = await getLatestReleaseID()
const latestAssets = `https://git.entityseven.com/api/v1/repos/entityseven/rage-server-downloader/releases/${id}/assets?page=1&limit=1` const latestAssets = `https://git.entityseven.com/api/v1/repos/entityseven/rage-server-downloader/releases/${id}/assets?page=1&limit=1`
axios.get<Asset[]>(latestAssets).then(async ({ data }) => { ky.get<Asset[]>(latestAssets)
const downloadURL = data[0].browser_download_url .then(response => response.json())
.then(async data => {
const downloadURL = data[0].browser_download_url
const file = await axios.get(data[0].browser_download_url, { const file = await ky.get(data[0].browser_download_url)
responseType: 'arraybuffer', const fileData = Buffer.from(
file as unknown as WithImplicitCoercion<string>,
'binary',
)
const fileSplit = downloadURL.split('/')
const fileName = fileSplit[fileSplit.length - 1]
fs.writeFileSync(`./${fileName}`, fileData)
}) })
const fileData = Buffer.from(file.data, 'binary')
const fileSplit = downloadURL.split('/')
const fileName = fileSplit[fileSplit.length - 1]
fs.writeFileSync(`./${fileName}`, fileData)
})
} }
async function getLatestReleaseID() { async function getLatestReleaseID() {
return axios.get<Release[]>(latestReleases).then(({ data }) => data[0].id) const ky = await import('ky').then(ky => ky.default)
return ky
.get<Release[]>(latestReleases)
.then(response => response.json())
.then(data => data[0].id)
} }

View File

@ -0,0 +1,67 @@
import c from 'chalk'
import { input, select } from '@inquirer/prompts'
import path from 'node:path'
import { cloneBranch } from '../utils/cloner'
const choices = {
'rpc-react-18': {
name: 'Vite + React 18 + TypeScript',
value: 'rpc-react-18',
description: 'Vite + React 18 + TypeScript as a frontend',
},
'rpc-svelte-5': {
name: 'Vite + Svelte 5 + TypeScript',
value: 'rpc-svelte-5',
description: 'Vite + Svelte 5 + TypeScript as a frontend',
},
} as const
export async function testRpc() {
let folder
let framework
if (!folder) {
folder = await input({
message: c.gray('Enter project name:'),
default: 'rage-fw-rpc-example',
})
} else {
console.log(c.gray('Project name:'), folder)
}
if (!framework) {
framework = await select({
message: c.gray('Select frontend:'),
default: 'rpc-react-18',
loop: true,
choices: Object.values(choices),
})
} else {
console.log(c.gray('Frontend:'), framework)
}
console.log(
c.gray('\nScaffolding template project into'),
folder,
c.gray('with'),
choices[framework].name,
c.gray('as a frontend..'),
)
cloneBranch(
'https://git.entityseven.com/entityseven/rage-framework-example',
path.join(process.cwd(), folder),
framework,
)
.then(() => {
console.log(c.gray('Scaffolded project into'), folder)
console.log(
c.gray(
`Project was created at dir: ${path.join(process.cwd(), folder)}`,
),
)
})
.catch(e => {
console.log(c.red('Error occured: \n', e))
})
}

View File

@ -1,40 +1,57 @@
import c from 'chalk' import c from 'chalk'
import { select } from '@inquirer/prompts' import { select } from '@inquirer/prompts'
import { checkForUpdate } from './utils/update' import { checkForUpdates } from './utils/update'
import { initProject } from './commands/create' import { initProject } from './commands/create'
import { downloadUpdater } from './commands/download-updater' import { downloadUpdater } from './commands/download-updater'
import { testRpc } from './commands/test-rpc'
enum Actions { enum Actions {
INIT_PROJECT = 'INIT_PROJECT', INIT_PROJECT = 'INIT_PROJECT',
TEST_RPC = 'TEST_RPC',
UPDATER = 'UPDATER', UPDATER = 'UPDATER',
} }
;(async () => { ;(async () => {
await checkForUpdate() await checkForUpdates()
console.log( console.log(c.blueBright('Rage FW CLI | Powered by Entity Seven Group <3'))
c.blueBright('Rage FW CLI | Powered by Entity Seven Group <3'),
)
const action = await select({ const action = await select({
message: c.gray('Select action:'), message: c.gray('Select action:'),
choices: [ choices: [
{ {
name: 'Initialize new project', name: 'Initialize a new project',
value: Actions.INIT_PROJECT, value: Actions.INIT_PROJECT,
description: 'Initialize new project and start develop', description: 'Initialize a new project and start developing',
},
{
name: 'Test our RPC',
value: Actions.TEST_RPC,
description:
'Initialize a new skeleton project with our RPC set up',
}, },
{ {
name: 'Install RAGE:MP updater', name: 'Install RAGE:MP updater',
value: Actions.UPDATER, value: Actions.UPDATER,
description: description:
'Use our custom updater to download and update RAGE:MP server files.', 'Use our tool to download or update RAGE:MP server files in two clicks',
}, },
], ],
loop: true, loop: true,
}) })
if (action === Actions.INIT_PROJECT) await initProject() switch (action) {
if (action === Actions.UPDATER) await downloadUpdater() case Actions.INIT_PROJECT:
await initProject()
break
case Actions.TEST_RPC:
await testRpc()
break
case Actions.UPDATER:
await downloadUpdater()
break
default:
console.log(c.red('Something went wrong..'))
}
})() })()

24
cli/src/utils/cloner.ts Normal file
View File

@ -0,0 +1,24 @@
import { exec } from 'child_process'
export async function cloneBranch(link: string, path: string, branch: string) {
return new Promise((resolve, reject) => {
const args = ['--single-branch', '-b', branch, '--', link, path]
const proc = exec('git clone ' + args.join(' '))
proc.on('close', (status: number) => {
if (status == 0) {
resolve(true)
} else if (status == 128) {
reject(
`Folder already exists. 'git clone' from branch ${branch} failed with status ` +
status,
)
} else {
reject(
`'git clone' from branch ${branch} failed with status ` +
status,
)
}
})
})
}

View File

@ -1,4 +1,3 @@
import axios from 'axios'
import c from 'chalk' import c from 'chalk'
import yargs from 'yargs' import yargs from 'yargs'
@ -10,12 +9,15 @@ type Version = {
message: string message: string
} }
export async function checkForUpdate(): Promise<void> { export async function checkForUpdates(): Promise<void> {
const ky = await import('ky').then(ky => ky.default)
return new Promise(res => { return new Promise(res => {
yargs.showVersion(version => yargs.showVersion(version =>
axios ky
.get<Version[]>(latestVersionURL) .get<Version[]>(latestVersionURL)
.then(({ data }) => { .then(response => response.json<Version[]>())
.then(data => {
const latestVersion = data[0].name const latestVersion = data[0].name
if (latestVersion !== `v${version}`) if (latestVersion !== `v${version}`)

View File

@ -11,7 +11,7 @@
"build": "tsup" "build": "tsup"
}, },
"dependencies": { "dependencies": {
"ragefw-rpc": "workspace:^" "rage-fw-rpc": "workspace:^"
}, },
"peerDependencies": { "peerDependencies": {
"@ragempcommunity/types-client": "^2.1.8", "@ragempcommunity/types-client": "^2.1.8",

View File

@ -1,20 +1,33 @@
import rpc from 'rage-rpc' import { Rpc } from 'rage-fw-rpc'
import { RageFW_ClientCallback, RageFW_ClientEvent } from '../types' import type {
RageFW_ClientArgs,
RageFW_ClientCallback,
RageFW_ClientEvent,
} from '../types'
export class Client { export class Client {
private _rpc: Rpc = new Rpc()
get rpc(): Rpc {
return this._rpc
}
public register<EventName extends RageFW_ClientEvent>( public register<EventName extends RageFW_ClientEvent>(
eventName: EventName, eventName: EventName,
callback: RageFW_ClientCallback<EventName>, callback: RageFW_ClientCallback<EventName>,
): void { ): void {
rpc.register(eventName, async data => { this._rpc.register(
return await callback(data) eventName,
}) async (data: RageFW_ClientArgs<EventName>) => {
return await callback(data)
},
)
} }
public unregister<EventName extends RageFW_ClientEvent>( public unregister<EventName extends RageFW_ClientEvent>(
eventName: EventName, eventName: EventName,
): void { ): void {
rpc.unregister(eventName) this._rpc.unregister(eventName)
} }
} }

View File

@ -1,4 +1,4 @@
import rpc from 'rage-rpc' import { Rpc } from 'rage-fw-rpc'
import type { RageFW_ICustomClientEvent } from 'rage-fw-shared-types' import type { RageFW_ICustomClientEvent } from 'rage-fw-shared-types'
import { import {
@ -16,15 +16,19 @@ import {
} from '../types' } from '../types'
export class Player { export class Player {
private _rpc: Rpc = new Rpc()
public browser: BrowserMp | undefined public browser: BrowserMp | undefined
get rpc(): Rpc {
return this._rpc
}
public trigger<EventName extends keyof RageFW_ICustomClientEvent>( public trigger<EventName extends keyof RageFW_ICustomClientEvent>(
eventName: EventName, eventName: EventName,
...args: _ClientEventHasArgs<EventName> extends true ...args: _ClientEventHasArgs<EventName> extends true
? [RageFW_ClientArgs<EventName>] ? [RageFW_ClientArgs<EventName>]
: [] : []
): Promise<RageFW_ClientReturn<EventName>> { ): Promise<RageFW_ClientReturn<EventName>> {
return rpc.call<RageFW_ClientReturn<EventName>>(eventName, args) return this._rpc.call(eventName, args)
} }
public triggerServer<EventName extends RageFW_ClientServerEvent>( public triggerServer<EventName extends RageFW_ClientServerEvent>(
@ -33,7 +37,7 @@ export class Player {
? [RageFW_ClientServerArgs<EventName>] ? [RageFW_ClientServerArgs<EventName>]
: [] : []
): Promise<RageFW_ClientServerReturn<EventName>> { ): Promise<RageFW_ClientServerReturn<EventName>> {
return rpc.callServer(eventName, args) return this._rpc.callServer(eventName, args)
} }
public triggerBrowser<EventName extends RageFW_CefEvent>( public triggerBrowser<EventName extends RageFW_CefEvent>(
@ -44,6 +48,6 @@ export class Player {
): Promise<RageFW_CefReturn<EventName>> { ): Promise<RageFW_CefReturn<EventName>> {
if (!this.browser) if (!this.browser)
throw new Error('You need to initialize browser first') throw new Error('You need to initialize browser first')
return rpc.callBrowser(this.browser, eventName, args) return this._rpc.callBrowser(this.browser, eventName, args)
} }
} }

32
pnpm-lock.yaml generated
View File

@ -53,27 +53,27 @@ importers:
'@ragempcommunity/types-cef': '@ragempcommunity/types-cef':
specifier: ^2.1.8 specifier: ^2.1.8
version: 2.1.8 version: 2.1.8
rage-fw-rpc:
specifier: workspace:^
version: link:../rpc
rage-fw-shared-types: rage-fw-shared-types:
specifier: workspace:^ specifier: workspace:^
version: link:../shared-types version: link:../shared-types
rage-trpc:
specifier: workspace:^
version: link:../rpc
cli: cli:
dependencies: dependencies:
'@inquirer/prompts': '@inquirer/prompts':
specifier: ^5.0.5 specifier: ^5.0.5
version: 5.0.5 version: 5.0.5
axios:
specifier: ^1.7.2
version: 1.7.2
chalk: chalk:
specifier: 4.1.2 specifier: 4.1.2
version: 4.1.2 version: 4.1.2
git-clone: git-clone:
specifier: ^0.2.0 specifier: ^0.2.0
version: 0.2.0 version: 0.2.0
ky:
specifier: ^1.7.2
version: 1.7.2
yargs: yargs:
specifier: ^17.7.2 specifier: ^17.7.2
version: 17.7.2 version: 17.7.2
@ -99,17 +99,17 @@ importers:
'@ragempcommunity/types-client': '@ragempcommunity/types-client':
specifier: ^2.1.8 specifier: ^2.1.8
version: 2.1.8 version: 2.1.8
rage-fw-rpc:
specifier: workspace:^
version: link:../rpc
rage-fw-shared-types: rage-fw-shared-types:
specifier: workspace:^ specifier: workspace:^
version: link:../shared-types version: link:../shared-types
rage-trpc:
specifier: workspace:^
version: link:../rpc
rpc: rpc:
dependencies: dependencies:
typescript: typescript:
specifier: ^5.0.0 specifier: ^5
version: 5.4.5 version: 5.4.5
devDependencies: devDependencies:
'@microsoft/api-extractor': '@microsoft/api-extractor':
@ -127,12 +127,12 @@ importers:
'@ragempcommunity/types-server': '@ragempcommunity/types-server':
specifier: ^2.1.8 specifier: ^2.1.8
version: 2.1.8 version: 2.1.8
rage-fw-rpc:
specifier: workspace:^
version: link:../rpc
rage-fw-shared-types: rage-fw-shared-types:
specifier: workspace:^ specifier: workspace:^
version: link:../shared-types version: link:../shared-types
rage-trpc:
specifier: workspace:^
version: link:../rpc
shared-types: {} shared-types: {}
@ -2269,6 +2269,10 @@ packages:
kuler@2.0.0: kuler@2.0.0:
resolution: {integrity: sha512-Xq9nH7KlWZmXAtodXDDRE7vs6DU1gTU8zYDHDiWLSip45Egwq3plLHzPn27NgvzL2r1LMPC1vdqh98sQxtqj4A==} resolution: {integrity: sha512-Xq9nH7KlWZmXAtodXDDRE7vs6DU1gTU8zYDHDiWLSip45Egwq3plLHzPn27NgvzL2r1LMPC1vdqh98sQxtqj4A==}
ky@1.7.2:
resolution: {integrity: sha512-OzIvbHKKDpi60TnF9t7UUVAF1B4mcqc02z5PIvrm08Wyb+yOcz63GRvEuVxNT18a9E1SrNouhB4W2NNLeD7Ykg==}
engines: {node: '>=18'}
lerna@8.1.3: lerna@8.1.3:
resolution: {integrity: sha512-Dg/r1dGnRCXKsOUC3lol7o6ggYTA6WWiPQzZJNKqyygn4fzYGuA3Dro2d5677pajaqFnFA72mdCjzSyF16Vi2Q==} resolution: {integrity: sha512-Dg/r1dGnRCXKsOUC3lol7o6ggYTA6WWiPQzZJNKqyygn4fzYGuA3Dro2d5677pajaqFnFA72mdCjzSyF16Vi2Q==}
engines: {node: '>=18.0.0'} engines: {node: '>=18.0.0'}
@ -5797,6 +5801,8 @@ snapshots:
kuler@2.0.0: {} kuler@2.0.0: {}
ky@1.7.2: {}
lerna@8.1.3(encoding@0.1.13): lerna@8.1.3(encoding@0.1.13):
dependencies: dependencies:
'@lerna/create': 8.1.3(encoding@0.1.13)(typescript@5.4.5) '@lerna/create': 8.1.3(encoding@0.1.13)(typescript@5.4.5)

View File

@ -1,5 +1,5 @@
{ {
"name": "ragefw-rpc", "name": "rage-fw-rpc",
"description": "RageFW RPC", "description": "RageFW RPC",
"version": "0.2.1", "version": "0.2.1",
"scripts": { "scripts": {

View File

@ -11,7 +11,7 @@
"build": "tsup" "build": "tsup"
}, },
"dependencies": { "dependencies": {
"ragefw-rpc": "workspace:^" "rage-fw-rpc": "workspace:^"
}, },
"peerDependencies": { "peerDependencies": {
"@ragempcommunity/types-server": "^2.1.8", "@ragempcommunity/types-server": "^2.1.8",

View File

@ -1,6 +1,6 @@
import rpc from 'rage-rpc' import { Rpc } from 'rage-fw-rpc'
import { import type {
_CefEventHasArgs, _CefEventHasArgs,
_ClientEventHasArgs, _ClientEventHasArgs,
RageFW_CefArgs, RageFW_CefArgs,
@ -12,6 +12,12 @@ import {
} from '../types' } from '../types'
export class Player { export class Player {
private _rpc: Rpc = new Rpc()
get rpc(): Rpc {
return this._rpc
}
public triggerClient<EventName extends RageFW_ClientEvent>( public triggerClient<EventName extends RageFW_ClientEvent>(
player: PlayerMp, player: PlayerMp,
eventName: EventName, eventName: EventName,
@ -19,7 +25,7 @@ export class Player {
? [RageFW_ServerClientArgs<EventName>] ? [RageFW_ServerClientArgs<EventName>]
: [] : []
): Promise<RageFW_ServerClientReturn<EventName>> { ): Promise<RageFW_ServerClientReturn<EventName>> {
return rpc.callClient(player, eventName, args) return this._rpc.callClient(player, eventName, args)
} }
public triggerBrowser<EventName extends RageFW_CefEvent>( public triggerBrowser<EventName extends RageFW_CefEvent>(
@ -29,6 +35,6 @@ export class Player {
? [RageFW_CefArgs<EventName>] ? [RageFW_CefArgs<EventName>]
: [] : []
): Promise<RageFW_CefReturn<EventName>> { ): Promise<RageFW_CefReturn<EventName>> {
return rpc.callBrowsers(player, eventName, args) return this._rpc.callBrowser(player, eventName, args)
} }
} }

View File

@ -1,8 +1,8 @@
import rpc from 'rage-rpc' import { Rpc } from 'rage-fw-rpc'
import { RageFW_ICustomServerEvent } from 'rage-fw-shared-types' import { RageFW_ICustomServerEvent } from 'rage-fw-shared-types'
import { nativeEvents } from '../native.events' import { nativeEvents } from '../native.events'
import { import type {
_ServerEventHasArgs, _ServerEventHasArgs,
RageFW_ServerArgs, RageFW_ServerArgs,
RageFW_ServerCallback, RageFW_ServerCallback,
@ -13,6 +13,12 @@ import {
} from '../types' } from '../types'
export class Server { export class Server {
private _rpc: Rpc = new Rpc()
get rpc(): Rpc {
return this._rpc
}
private isNativeEvent(eventName: string): eventName is keyof IServerEvents { private isNativeEvent(eventName: string): eventName is keyof IServerEvents {
return nativeEvents.includes(eventName) return nativeEvents.includes(eventName)
} }
@ -21,8 +27,9 @@ export class Server {
eventName: EventName, eventName: EventName,
callback: RageFW_ServerCallbackCustom<EventName>, callback: RageFW_ServerCallbackCustom<EventName>,
): void { ): void {
rpc.register( this._rpc.register(
eventName, eventName,
// fixme
async (args: RageFW_ServerArgs<EventName>, info) => { async (args: RageFW_ServerArgs<EventName>, info) => {
await callback([info.player as PlayerMp, ...args]) await callback([info.player as PlayerMp, ...args])
}, },
@ -80,7 +87,7 @@ export class Server {
private unregisterCustom<EventName extends keyof RageFW_ICustomServerEvent>( private unregisterCustom<EventName extends keyof RageFW_ICustomServerEvent>(
eventName: EventName, eventName: EventName,
): void { ): void {
rpc.unregister(eventName) this._rpc.unregister(eventName)
} }
private unregisterNative<EventName extends keyof IServerEvents>( private unregisterNative<EventName extends keyof IServerEvents>(
@ -105,6 +112,6 @@ export class Server {
? [RageFW_ServerArgs<EventName>] ? [RageFW_ServerArgs<EventName>]
: [] : []
): Promise<RageFW_ServerReturn<EventName>> { ): Promise<RageFW_ServerReturn<EventName>> {
return rpc.call<RageFW_ServerReturn<EventName>>(eventName, args) return this._rpc.call(eventName, args)
} }
} }