summaryrefslogtreecommitdiff
Commit message (Collapse)AuthorAgeFilesLines
...
* src/web.mjs: Move the "starting-server" logging into hero when .listen()EuAndreh2024-03-172-12/+15
|
* src/hero.mjs: Include "timestamp" in the logged data objectsEuAndreh2024-03-172-29/+51
|
* src/hero.mjs: Explicitly inject "headers" key in reqEuAndreh2024-03-161-0/+2
|
* src/hero.mjs: Add makeUpgradeListener() (again, now rewritten)EuAndreh2024-03-162-0/+92
|
* src/hero.mjs: use empty object as default value for renderHeaders()EuAndreh2024-03-162-1/+2
|
* src/hero.mjs: validateUpgrade(): Add note on 405 caseEuAndreh2024-03-161-0/+3
|
* src/web.mjs: Add "WEBSOCKET" routeEuAndreh2024-03-161-7/+8
|
* src/hero.mjs: Move interceptors.contentType() closer to the end of the listEuAndreh2024-03-161-1/+1
|
* tests/js/hero.mjs: Add upgrade case to handleRequest() testEuAndreh2024-03-161-2/+35
|
* src/hero.mjs: Add writeHead() and its helper functionsEuAndreh2024-03-162-0/+93
|
* src/hero.mjs: Remove current makeUpgradeListener() and its helpersEuAndreh2024-03-162-233/+0
|
* src/hero.mjs: findHandler(): learn how to find upgrade routesEuAndreh2024-03-162-32/+73
|
* src/hero.mjs: Add interceptors.websocketHandshake()EuAndreh2024-03-162-2/+95
|
* src/hero.mjs: Remove WEBSOCKET_* constantsEuAndreh2024-03-161-9/+3
|
* src/hero.mjs: Add validateUpgrade(), computeHash() and their helper functionsEuAndreh2024-03-162-2/+268
|
* src/hero.mjs: Add "upgrade" and "socket" keys to `req`EuAndreh2024-03-162-13/+29
| | | | Also log on "in-request" the value of "upgrade".
* src/hero.mjs: interceptors.contentType(): Generate body from status when missingEuAndreh2024-03-162-13/+44
|
* src/hero.mjs: Include stacktrace in 500 log entryEuAndreh2024-03-152-2/+5
|
* src/hero.mjs: Add makeUpgradeListener()EuAndreh2024-03-152-0/+80
|
* src/hero.mjs: Add handlerForConnection()EuAndreh2024-03-152-0/+56
|
* src/hero.mjs: Add support for "WEBSOCKET" type of routeEuAndreh2024-03-152-2/+12
|
* src/hero.mjs: Add buildHttpPayload()EuAndreh2024-03-152-0/+67
|
* src/hero.mjs: Add emitHeaders()EuAndreh2024-03-152-0/+30
|
* src/hero.mjs: Add comboForLabel()EuAndreh2024-03-152-0/+25
|
* src/hero.mjs: Add isValidLabel()EuAndreh2024-03-152-0/+28
|
* src/hero.mjs: Destructure handler arguments in handleRequest()EuAndreh2024-03-151-4/+4
|
* tests/lighttpd.conf: add the upgrade header without replacing existing onesEuAndreh2024-03-141-1/+1
|
* Makefile: Use TCP port 6001EuAndreh2024-03-141-1/+1
|
* tests/lighttpd.conf: Forward "enable" header to allow connection upgradeEuAndreh2024-03-141-0/+3
|
* src/hero.mjs: Include "headers" and "ref" in request paramEuAndreh2024-03-142-11/+55
|
* Makefile: Add "run-binder" to expose lighttpd's unix socket to a TCP portEuAndreh2024-03-141-1/+7
|
* src/web.mjs: Add trailing newline to bodyEuAndreh2024-03-141-2/+2
|
* src/hero.mjs: Add timing data to "in-response" log entryEuAndreh2024-03-082-2/+14
|
* src/utils.mjs: Add dissoc()EuAndreh2024-03-082-0/+24
|
* src/web.mjs: Move logging and interceptors to the beginning of the fileEuAndreh2024-03-082-595/+595
|
* src/hero.mjs: Make sure globalInceptors are used even when we get a 404EuAndreh2024-03-082-8/+30
|
* src/hero.mjs: Add buildTable()EuAndreh2024-03-082-1/+21
|
* src/hero.mjs: server.listen() -> server.start(); server.close() -> server.stop()EuAndreh2024-03-073-7/+7
|
* src/hero.mjs: Add makeReopeningPipeReader()EuAndreh2024-03-072-29/+130
| | | | | This addresses point nº 2 from commit 40118a188fb05219d1188ff775ce71f66c8cb56a.
* src/hero.mjs: makePipeReader() now returns a function for closing itEuAndreh2024-03-072-21/+23
|
* tests/js/hero.mjs: Better names for pipes and sockets created by testsEuAndreh2024-03-072-22/+29
|
* rm -rf tools/EuAndreh2024-03-073-319/+0
|
* src/hero.mjs: Better handling of default values for argumentsEuAndreh2024-03-061-20/+10
| | | | | Now one can give a partial specification of the object and still get the other attributes to have their default values.
* src/hero.mjs: Add minimalistic "ping" action for doing smoke tests in productionEuAndreh2024-03-062-0/+20
|
* src/hero.mjs: Add simplified implementation of `makePipeReader()`EuAndreh2024-03-062-2/+26
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | There are a few limitations of the current approach that I didn't figure out how to solve yet: 1. when stopping the server, mainly for shutting down the Node.js process when running the tests, we need to open and close the pipe in write mode at least once, otherwise it hangs forever. After opening and closing it, the "autoClose" functionality of the `fs.createReadStream()` kicks in, and it closes, otherwise the test hangs forever as Node.js still has open handles. That's why the `server.close()` function has a gratuitous call to `fs.createWriteStream(pipe).end()`: so that when stopping the server, the pipe is always closed at least once; 2. when actually running the application, if one tries an IPC command like: $ echo '{ "action": "config-dump" }' > web.pipe It works, but only for the first time. As this shell line opened the pipe, wrote to it and then closed it, the reader that `makePipeReader()` constructed closed, but didn't open it again. So when running the exact same IPC command for a second time, the shell hangs, as there is no process on the other side listening for the command and consuming the pipe. Shortcoming nº 2 is much more important to be solved, as we can live with shortcoming nª 1 for some time. Both are to be fixed in the near future.
* src/hero.mjs: Change server.listen() to receive no argumentsEuAndreh2024-03-063-13/+35
|
* src/hero.mjs: Add skeleton for makePipeReaderFn()EuAndreh2024-03-062-5/+40
|
* src/hero.mjs: Add makeLineEmitter()EuAndreh2024-03-062-0/+100
|
* src/utils.mjs: Add first(), rest(), butlast() and last()EuAndreh2024-03-062-0/+83
|
* src/hero.mjs: Add rmIf() and mkfifo()EuAndreh2024-03-066-28/+111
|