-
Notifications
You must be signed in to change notification settings - Fork 216
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #276 from RSamaium/v4.2.0
V4.2.0
- Loading branch information
Showing
76 changed files
with
33,572 additions
and
2,147 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,119 @@ | ||
# `auth` Hook Documentation | ||
|
||
## Overview | ||
|
||
The `auth` hook in RPGJS is a authenticating players in your game. This document provides a comprehensive guide on how to implement and use the `auth` hook in the RPGJS project. | ||
|
||
::: tip Info | ||
Authentication in RPGJS is agnostic, in the sense that you can make it work with any authentication system. It's not tied to any database or third-party system. You're free to implement your own logic. This is useful for MMORPGs. | ||
Below is an example with a JWT. | ||
::: | ||
|
||
## Implementation | ||
|
||
In your `main/server.ts` file, follow these steps to set up the `auth` hook: | ||
|
||
### Step 1: Import Required Modules | ||
|
||
Import the necessary modules from `@rpgjs/server`: | ||
|
||
```typescript | ||
import { RpgServerEngineHooks, RpgServerEngine } from '@rpgjs/server'; | ||
``` | ||
|
||
### Step 2: Define the `auth` Hook | ||
|
||
Implement the `auth` hook within the `RpgServerEngineHooks`: | ||
|
||
```typescript | ||
const server: RpgServerEngineHooks = { | ||
auth(server: RpgServerEngine, socket) { | ||
// Authentication logic goes here | ||
} | ||
}; | ||
|
||
export default server; | ||
``` | ||
|
||
#### Functionality | ||
|
||
- The `auth` hook must return a `Promise<string>`, a `string`, or throw an error. | ||
- If a `string` is returned, and the ID **public** matches, the player is considered connected. | ||
- If the hook throws an error, it indicates that the player is not authenticated. | ||
|
||
#### Parameters | ||
|
||
- `server`: An instance of `RpgServerEngine`. | ||
- `socket`: The `socket.io` object. You can access various request headers using `socket.handshake.headers`. | ||
|
||
## Client-Side Error Handling | ||
|
||
To handle errors on the client side, such as those thrown during the authentication process, implement the `onConnectError` hook in your `main/client.ts` file. | ||
|
||
### Step 1: Import Required Modules | ||
|
||
Import the necessary modules from `@rpgjs/client`: | ||
|
||
```typescript | ||
import { RpgClientEngineHooks, RpgClientEngine } from "@rpgjs/client"; | ||
``` | ||
|
||
### Step 2: Define the `onConnectError` Hook | ||
|
||
Implement the `onConnectError` hook within the `RpgClientEngineHooks` to handle connection errors: | ||
|
||
```typescript | ||
const client: RpgClientEngineHooks = { | ||
onConnectError(engine: RpgClientEngine, err: Error) { | ||
console.log("Connection Error:", err.message); | ||
} | ||
}; | ||
|
||
export default client; | ||
``` | ||
|
||
## JWT Example | ||
|
||
### Step 1: Import Required Modules | ||
|
||
Import necessary modules from `@rpgjs/server` and any other required libraries (like `jsonwebtoken` for decoding JWT): | ||
|
||
```typescript | ||
import { RpgServerEngineHooks, RpgServerEngine } from '@rpgjs/server'; | ||
import jwt from 'jsonwebtoken'; | ||
``` | ||
|
||
> Install `jsonwebtoken` using `npm install jsonwebtoken`. | ||
### Step 2: Define the `auth` Hook with JWT Logic | ||
|
||
Implement the `auth` hook to handle JWT verification: | ||
|
||
```typescript | ||
const server: RpgServerEngineHooks = { | ||
auth(server: RpgServerEngine, socket) { | ||
const token = socket.handshake.headers.authorization; | ||
if (!token) { | ||
throw 'No token provided'; | ||
} | ||
|
||
// Replace 'YOUR_SECRET_KEY' with your actual secret key used to sign the JWT | ||
const decoded = jwt.verify(token, 'YOUR_SECRET_KEY'); | ||
if (!decoded) { | ||
throw 'Invalid token'; | ||
} | ||
|
||
// Assuming 'decoded' contains a property 'id' representing the user ID | ||
return decoded.id; | ||
} | ||
}; | ||
|
||
export default server; | ||
``` | ||
|
||
::: tip Notes | ||
- Ensure you replace `'YOUR_SECRET_KEY'` with the secret key you used to sign your JWTs. | ||
- The JWT is expected to be in the `authorization` header of the socket handshake. Make sure this aligns with how your client is sending the token. | ||
- The example assumes the JWT contains an `id` field representing the user ID. Adjust this according to your JWT structure. | ||
- Proper error handling is crucial to inform the client about authentication failures. | ||
::: |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
# React Hooks | ||
|
||
## Introduction | ||
|
||
React hooks are a powerful feature in React that allow you to use state and other React features without writing a class. In the context of RPGJS, a framework for creating RPG games, React hooks can be particularly useful for managing game state and interactions. | ||
|
||
## 1. `useEventPropagator()` | ||
|
||
This hook is used to propagate events within the canvas element of your RPGJS game. | ||
|
||
### Importing | ||
|
||
```javascript | ||
import { useEventPropagator } from '@rpgjs/client/react'; | ||
``` | ||
|
||
### Usage | ||
|
||
```javascript | ||
export default function Test() { | ||
const propagate = useEventPropagator(); | ||
|
||
return <div ref={propagate}>test</div>; | ||
} | ||
``` | ||
|
||
In this example, the `useEventPropagator` hook is used to create a `propagate` function. This function is then passed to a `div` element as a reference (`ref`). This setup allows events within the `div` to be propagated through the RPGJS game canvas. | ||
|
||
--- | ||
|
||
## 2. `RpgReactContext` | ||
|
||
This hook provides access to the RPGJS context, allowing you to interact with various game states like the current player's health points (HP). | ||
|
||
### Importing | ||
|
||
```javascript | ||
import { RpgReactContext } from '@rpgjs/client/react'; | ||
import { useContext, useEffect, useState } from 'react'; | ||
``` | ||
|
||
### Usage | ||
|
||
```javascript | ||
export default function MyGUI({ foo }) { | ||
const { rpgCurrentPlayer } = useContext(RpgReactContext); | ||
const [hp, setHp] = useState(0); | ||
|
||
useEffect(() => { | ||
const subscription = rpgCurrentPlayer.subscribe(({ object }) => { | ||
setHp(object.hp); | ||
}); | ||
|
||
return () => { | ||
subscription.unsubscribe(); | ||
}; | ||
}, []); | ||
|
||
return ( | ||
<div> | ||
<h1>{hp}</h1> | ||
</div> | ||
); | ||
} | ||
``` | ||
|
||
In this example, `RpgReactContext` is used to access the current player's state. The `useContext` hook retrieves the `rpgCurrentPlayer` from `RpgReactContext`. We then use `useState` to manage the player's HP locally. The `useEffect` hook is used to subscribe to changes in the player's HP, updating the local state accordingly. When the component unmounts, the subscription is unsubscribed. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
# Directive for VueJS | ||
|
||
## `v-propagate` | ||
|
||
The `v-propagate` directive is straightforward to use. Simply add it to any element in your VueJS template to enable event propagation for that element within the RPGJS canvas. | ||
|
||
### Example | ||
|
||
```vue | ||
<template> | ||
<div v-propagate> | ||
Test | ||
</div> | ||
</template> | ||
``` | ||
|
||
In this example, the `v-propagate` directive is attached to a `div` element. Any events that occur within this `div` will be propagated through the RPGJS game canvas. This is particularly useful for integrating VueJS-based GUI elements with the RPGJS game canvas, allowing for seamless interaction between the GUI and the game. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
# Using `inject` in RPGJS | ||
|
||
The `inject` function in RPGJS is a powerful feature for dependency injection, allowing you to retrieve instances of various classes in both client and server environments. | ||
|
||
## Client-Side Injection | ||
|
||
To use `inject` on the client side, import it from `@rpgjs/client`. This allows you to retrieve singleton instances of classes such as `RpgClientEngine`, `KeyboardControls`, and `RpgRenderer`. | ||
|
||
### Retrieving the `RpgClientEngine` | ||
|
||
```typescript | ||
import { inject, RpgClientEngine } from '@rpgjs/client' | ||
|
||
const client = inject(RpgClientEngine) | ||
``` | ||
|
||
This code imports `inject` and `RpgClientEngine` from `@rpgjs/client` and then uses `inject` to retrieve the `RpgClientEngine` instance. | ||
|
||
### Injecting Other Classes | ||
|
||
Similarly, you can inject other classes like `KeyboardControls` and `RpgRenderer`: | ||
|
||
```typescript | ||
import { inject, KeyboardControls, RpgRenderer } from '@rpgjs/client' | ||
|
||
const controls = inject(KeyboardControls) | ||
const renderer = inject(RpgRenderer) | ||
``` | ||
|
||
## Server-Side Injection | ||
|
||
For server-side injection, import `inject` from `@rpgjs/server`. This is typically used to retrieve the `RpgServerEngine`. | ||
|
||
### Retrieving the `RpgServerEngine` | ||
|
||
```typescript | ||
import { inject, RpgServerEngine } from '@rpgjs/server' | ||
|
||
const server = inject(RpgServerEngine) | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.