Add custom proxy selection (#53)
* Add custom proxy selection * Remove request dependency * Remove duplicate font
This commit is contained in:
parent
04b8ef2b68
commit
edf12cea69
4 changed files with 27 additions and 64 deletions
Binary file not shown.
27
index.js
27
index.js
|
@ -1,4 +1,5 @@
|
|||
/* global THREE, prompt */
|
||||
const net = require('net')
|
||||
|
||||
// Workaround for process.versions.node not existing in the browser
|
||||
process.versions.node = '14.0.0'
|
||||
|
@ -31,13 +32,35 @@ async function statusRunner () {
|
|||
async function main () {
|
||||
statusRunner()
|
||||
const viewDistance = 6
|
||||
const host = prompt('Host', '95.111.249.143')
|
||||
const port = parseInt(prompt('Port', '10000'))
|
||||
const hostprompt = prompt('Host:port', '95.111.249.143:10000')
|
||||
const proxyprompt = prompt('Proxy:port (blank for default)', '')
|
||||
const username = prompt('Username', 'pviewer' + (Math.floor(Math.random() * 1000)))
|
||||
let password = prompt('Password (blank for offline)', '')
|
||||
password = password === '' ? undefined : password
|
||||
|
||||
let host, port, proxy, proxyport
|
||||
if (!hostprompt.includes(':')) {
|
||||
host = hostprompt
|
||||
port = 25565
|
||||
} else {
|
||||
[host, port] = hostprompt.split(':')
|
||||
port = parseInt(port, 10)
|
||||
}
|
||||
|
||||
if (!proxyprompt.includes(':')) {
|
||||
proxy = proxyprompt
|
||||
proxyport = undefined
|
||||
} else {
|
||||
[proxy, proxyport] = proxyprompt.split(':')
|
||||
proxyport = parseInt(proxyport, 10)
|
||||
}
|
||||
console.log(`connecting to ${host} ${port} with ${username}`)
|
||||
|
||||
if (proxy) {
|
||||
console.log(`using proxy ${proxy} ${proxyport}`)
|
||||
net.setProxy({ hostname: proxy, port: proxyport })
|
||||
}
|
||||
|
||||
status = 'Logging in'
|
||||
|
||||
document.getElementById('loading-text').requestFullscreen()
|
||||
|
|
|
@ -42,8 +42,7 @@
|
|||
"dependencies": {
|
||||
"compression": "^1.7.4",
|
||||
"express": "^4.17.1",
|
||||
"net-browserify": "^0.2.4",
|
||||
"request": "^2.88.2"
|
||||
"net-browserify": "PrismarineJS/net-browserify"
|
||||
},
|
||||
"devDependencies": {
|
||||
"assert": "^2.0.0",
|
||||
|
|
61
server.js
61
server.js
|
@ -2,76 +2,17 @@
|
|||
|
||||
const express = require('express')
|
||||
const netApi = require('net-browserify')
|
||||
const request = require('request')
|
||||
const compression = require('compression')
|
||||
const path = require('path')
|
||||
|
||||
// Create our app
|
||||
const app = express()
|
||||
|
||||
app.use(function (req, res, next) {
|
||||
res.header('Access-Control-Allow-Origin', req.get('Origin') || '*')
|
||||
res.header('Access-Control-Allow-Credentials', 'true')
|
||||
res.header('Access-Control-Allow-Methods', 'GET,HEAD,PUT,PATCH,POST,DELETE')
|
||||
res.header('Access-Control-Expose-Headers', 'Content-Length')
|
||||
res.header(
|
||||
'Access-Control-Allow-Headers',
|
||||
'Accept, Authorization, Content-Type, X-Requested-With, Range'
|
||||
)
|
||||
if (req.method === 'OPTIONS') {
|
||||
return res.send(200)
|
||||
} else {
|
||||
return next()
|
||||
}
|
||||
})
|
||||
|
||||
app.use(compression())
|
||||
app.use(netApi())
|
||||
app.use(netApi({ allowOrigin: '*' }))
|
||||
app.use(express.static(path.join(__dirname, './public')))
|
||||
|
||||
app.use(express.json({ limit: '100kb' }))
|
||||
|
||||
app.all('*', function (req, res, next) {
|
||||
// Set CORS headers: allow all origins, methods, and headers: you may want to lock this down in a production environment
|
||||
res.header('Access-Control-Allow-Origin', '*')
|
||||
res.header('Access-Control-Allow-Methods', 'GET, PUT, PATCH, POST, DELETE')
|
||||
res.header(
|
||||
'Access-Control-Allow-Headers',
|
||||
req.header('access-control-request-headers')
|
||||
)
|
||||
|
||||
if (req.method === 'OPTIONS') {
|
||||
// CORS Preflight
|
||||
res.send()
|
||||
} else {
|
||||
const targetURL = req.header('Target-URL')
|
||||
if (!targetURL) {
|
||||
res.status(404).send({ error: '404 Not Found' })
|
||||
return
|
||||
}
|
||||
const newHeaders = req.headers
|
||||
newHeaders.host = targetURL
|
||||
.replace('https://', '')
|
||||
.replace('http://', '')
|
||||
.split('/')[0]
|
||||
request(
|
||||
{
|
||||
url: targetURL + req.url,
|
||||
method: req.method,
|
||||
json: req.body,
|
||||
headers: req.headers
|
||||
},
|
||||
function (error, response, body) {
|
||||
if (error) {
|
||||
console.error(error)
|
||||
console.error('error: ' + response.statusCode)
|
||||
}
|
||||
// console.log(body);
|
||||
}
|
||||
).pipe(res)
|
||||
}
|
||||
})
|
||||
|
||||
// Start the server
|
||||
const server = app.listen(process.argv[2] === undefined ? 8080 : process.argv[2], function () {
|
||||
console.log('Server listening on port ' + server.address().port)
|
||||
|
|
Loading…
Reference in a new issue