implemented frontend including separate message system; started to implement backend
This commit is contained in:
97
yjs-poll/node_modules/lib0/bin/0serve.js
generated
vendored
Normal file
97
yjs-poll/node_modules/lib0/bin/0serve.js
generated
vendored
Normal file
@@ -0,0 +1,97 @@
|
||||
#!/usr/bin/env node
|
||||
|
||||
/**
|
||||
* Simple http server implementation.
|
||||
* Optionally, you may set `DEBUG_BROWSER` environment variable to use a different browser to debug
|
||||
* web apps.
|
||||
*/
|
||||
|
||||
import * as http from 'http'
|
||||
import * as path from 'path'
|
||||
import * as fs from 'fs'
|
||||
import * as env from '../environment.js'
|
||||
import * as number from '../number.js'
|
||||
import * as logging from 'lib0/logging'
|
||||
|
||||
const host = env.getParam('--host', 'localhost')
|
||||
const port = number.parseInt(env.getParam('--port', '8000'))
|
||||
const paramOpenFile = env.getParam('-o', '')
|
||||
const debugBrowser = env.getConf('DEBUG_BROWSER')
|
||||
|
||||
/**
|
||||
* @type {Object<string,string>}
|
||||
*/
|
||||
const types = {
|
||||
html: 'text/html',
|
||||
css: 'text/css',
|
||||
js: 'application/javascript',
|
||||
mjs: 'application/javascript',
|
||||
png: 'image/png',
|
||||
jpg: 'image/jpeg',
|
||||
jpeg: 'image/jpeg',
|
||||
gif: 'image/gif',
|
||||
json: 'application/json',
|
||||
xml: 'application/xml',
|
||||
wasm: 'application/wasm'
|
||||
}
|
||||
|
||||
const root = path.normalize(path.resolve('./'))
|
||||
|
||||
const server = http.createServer((req, res) => {
|
||||
const url = (req.url || '/index.html').split('?')[0]
|
||||
logging.print(logging.ORANGE, logging.BOLD, req.method || '', ' ', logging.GREY, logging.UNBOLD, url)
|
||||
const extension = path.extname(url).slice(1)
|
||||
/**
|
||||
* @type {string}
|
||||
*/
|
||||
const type = (extension && types[extension]) || types.html
|
||||
const supportedExtension = Boolean(type)
|
||||
if (!supportedExtension) {
|
||||
res.writeHead(404, { 'Content-Type': 'text/html' })
|
||||
res.end('404: File not found')
|
||||
return
|
||||
}
|
||||
let fileName = url
|
||||
if (url === '/') fileName = 'index.html'
|
||||
else if (!extension) {
|
||||
try {
|
||||
fs.accessSync(path.join(root, url + '.html'), fs.constants.F_OK)
|
||||
fileName = url + '.html'
|
||||
} catch (e) {
|
||||
fileName = path.join(url, 'index.html')
|
||||
}
|
||||
}
|
||||
|
||||
const filePath = path.join(root, fileName)
|
||||
const isPathUnderRoot = path
|
||||
.normalize(path.resolve(filePath))
|
||||
.startsWith(root)
|
||||
|
||||
if (!isPathUnderRoot) {
|
||||
res.writeHead(404, { 'Content-Type': 'text/html' })
|
||||
res.end('404: File not found')
|
||||
logging.print(logging.RED, logging.BOLD, 'Not Found: ', logging.GREY, logging.UNBOLD, url)
|
||||
return
|
||||
}
|
||||
|
||||
fs.readFile(filePath, (err, data) => {
|
||||
if (err) {
|
||||
logging.print(logging.RED, logging.BOLD, 'Cannot read file: ', logging.GREY, logging.UNBOLD, url)
|
||||
res.writeHead(404, { 'Content-Type': 'text/html' })
|
||||
res.end('404: File not found')
|
||||
} else {
|
||||
res.writeHead(200, { 'Content-Type': type })
|
||||
res.end(data)
|
||||
}
|
||||
})
|
||||
})
|
||||
|
||||
server.listen(port, host, () => {
|
||||
logging.print(logging.BOLD, logging.ORANGE, `Server is running on http://${host}:${port}`)
|
||||
if (paramOpenFile) {
|
||||
const start = debugBrowser || (process.platform === 'darwin' ? 'open' : process.platform === 'win32' ? 'start' : 'xdg-open')
|
||||
import('child_process').then(cp => {
|
||||
cp.exec(`${start} http://${host}:${port}/${paramOpenFile}`)
|
||||
})
|
||||
}
|
||||
})
|
||||
Reference in New Issue
Block a user