hytopia 0.10.11-prerelease-1 → 0.10.11-prerelease-3
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/bin/buildInject.js +8 -0
- package/bin/inject-dirname.js +8 -0
- package/bin/scripts.js +3 -8
- package/package.json +1 -1
- package/server.mjs +1 -1
@@ -0,0 +1,8 @@
|
|
1
|
+
import { fileURLToPath } from 'url';
|
2
|
+
import { dirname } from 'path';
|
3
|
+
import { createRequire } from 'module';
|
4
|
+
|
5
|
+
// esbuild inject requires global assignments, not exports
|
6
|
+
globalThis.__filename = fileURLToPath(import.meta.url);
|
7
|
+
globalThis.__dirname = dirname(__filename);
|
8
|
+
globalThis.require = createRequire(import.meta.url);
|
@@ -0,0 +1,8 @@
|
|
1
|
+
import { fileURLToPath } from 'url';
|
2
|
+
import { dirname } from 'path';
|
3
|
+
import { createRequire } from 'module';
|
4
|
+
|
5
|
+
// esbuild inject requires global assignments, not exports
|
6
|
+
globalThis.__filename = fileURLToPath(import.meta.url);
|
7
|
+
globalThis.__dirname = dirname(__filename);
|
8
|
+
globalThis.require = createRequire(import.meta.url);
|
package/bin/scripts.js
CHANGED
@@ -76,11 +76,9 @@ async function build() {
|
|
76
76
|
platform: 'node',
|
77
77
|
target: 'node24',
|
78
78
|
sourcemap: 'inline',
|
79
|
+
inject: [path.join(__dirname, 'buildInject.js')],
|
79
80
|
mainFields: ['module', 'main'],
|
80
|
-
conditions: ['import', 'node']
|
81
|
-
banner: {
|
82
|
-
js: 'import { createRequire as __cr } from "module"; const require = __cr(import.meta.url);'
|
83
|
-
}
|
81
|
+
conditions: ['import', 'node']
|
84
82
|
});
|
85
83
|
}
|
86
84
|
|
@@ -112,12 +110,9 @@ function start() {
|
|
112
110
|
platform: 'node',
|
113
111
|
target: 'node24',
|
114
112
|
sourcemap: 'inline',
|
115
|
-
|
113
|
+
inject: [path.join(__dirname, 'buildInject.js')],
|
116
114
|
mainFields: ['module', 'main'],
|
117
115
|
conditions: ['import', 'node'],
|
118
|
-
banner: {
|
119
|
-
js: 'import { createRequire as __cr } from "module"; const require = __cr(import.meta.url);'
|
120
|
-
},
|
121
116
|
plugins: [{
|
122
117
|
name: 'restart-after-build',
|
123
118
|
setup(build) {
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "hytopia",
|
3
|
-
"version": "0.10.11-prerelease-
|
3
|
+
"version": "0.10.11-prerelease-3",
|
4
4
|
"description": "The HYTOPIA SDK makes it easy for developers to create massively multiplayer games using JavaScript or TypeScript.",
|
5
5
|
"type": "module",
|
6
6
|
"main": "./server.mjs",
|
package/server.mjs
CHANGED
@@ -447,7 +447,7 @@ qYGMwU/HBVHkLAn5XvT2a9xM0mzZ558d+ahbw8qAgRxg7BZ+2PW/bf7F2WRBUk1f
|
|
447
447
|
xauhAoGBALEspoxQozwohGQnP7EMF0/0JoKNpdNv0b0qCVvNiMo0+N297lI2mFQp
|
448
448
|
6xYlW/1l9afLokklF/J2IsyBrTCZoY7SaEk/lMMrQSyra+y0z71ogZ8A4ny9fxsj
|
449
449
|
0dDYJZGllL+3E/MQfd7k+KnOM/+A+cPoAnci76+L3vdkUb2P8SJk
|
450
|
-
-----END RSA PRIVATE KEY-----`;var Ef=process.env.PORT??8080,If="0.10.11-prerelease-
|
450
|
+
-----END RSA PRIVATE KEY-----`;var Ef=process.env.PORT??8080,If="0.10.11-prerelease-3",_f;((Y)=>{Y.READY="WEBSERVER.READY";Y.STOPPED="WEBSERVER.STOPPED";Y.ERROR="WEBSERVER.ERROR";Y.UPGRADE="WEBSERVER.UPGRADE"})(_f||={});class F3 extends B0{static instance=new F3;_webserver=WU.default();_internalHttpServer;constructor(){super();this._webserver.use((Z,J,X)=>{J.header("Access-Control-Allow-Origin","*"),X()}),this._webserver.get("/",(Z,J)=>{J.json({status:"OK",version:If,runtime:"node"})}),this._webserver.use(WU.default.static("assets",{dotfiles:"allow"}));try{this._webserver.use(WU.default.static(La1.dirname(g.resolve("/Users/arkdev/Desktop/HYTOPIA/hytopia/assets/release/index.js")),{dotfiles:"allow"}))}catch{}}start(){if(!this._internalHttpServer)this._internalHttpServer=process.env.NODE_ENV==="production"?Ba1.createServer(this._webserver):ja1.createServer({key:KU.existsSync("assets/certs/localhost.key")?KU.readFileSync("assets/certs/localhost.key"):zY0,cert:KU.existsSync("assets/certs/localhost.crt")?KU.readFileSync("assets/certs/localhost.crt"):GY0},this._webserver),this._internalHttpServer.on("upgrade",this._onUpgrade),this._internalHttpServer.on("error",this._onError),this._internalHttpServer.on("close",this._onStopped);else p.warning("WebServer.start(): server already started!");this._internalHttpServer.listen(Ef,this._onStarted),console.info(`WebServer.start(): Server running on port ${Ef}.`)}stop(){if(this._internalHttpServer)return new Promise((Z,J)=>{this._internalHttpServer.close((X)=>{if(X)J(X);else Z(!0)})});else return p.warning("WebServer.stop(): server not started."),Promise.resolve(!1)}_onStarted=()=>{this.emitWithGlobal("WEBSERVER.READY",{})};_onUpgrade=async(Z,J,X)=>{let $=Da1.parse(Z.url??"",!0).query,Y=$.connectionId?.toString(),Q=$.sessionToken?.toString()??"";if(Y&&M7.instance.isValidConnectionId(Y))Z.connectionId=Y;else{let K=await O4.instance.getPlayerSession(Q);if(K?.error){let W=`${K.error.code}: ${K.error.message}`;J.write(`HTTP/1.1 401 Unauthorized\r
|
451
451
|
Content-Type: text/plain\r
|
452
452
|
Content-Length: ${W.length}\r
|
453
453
|
Connection: close\r
|