Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Harmony node.js sugar full-async framework
Type into console:
npm install jin
Then you need to run your script with --harmony parameter:
node --harmony myscript.js
Connect autoloader:
$= require( 'jin' ).loader()
Then use this pattern to work with modules:
var app= $.connect( $.connect.static( 'public' ) )
$.http.createServer( app ).listen( 80 )
Instead of:
var connect= require( 'connect' )
var http= require( 'http' )
var app= connect( connect.static( 'public' ) )
http.createServer( app ).listen( 80 )
You can use customized loaders:
$my= $.jin.loader( './' )
$my.init() // loads ./init.js
If module is not installed, $.jin.loader tries to install that by npm. But this feature uses fibers! Wrap your application to fiber:
require( 'jin' ).application( function( $ ){
var app= $.connect( $.connect.static( 'public' ) )
$.http.createServer( app ).listen( 8080 )
} )
This code may autoinstall "connect" module if needed and then run the server.
When your application has crashed or when its files has updated, you need to restart application. This is monkey job. To reduce it, wrap your application to $.jin.persistent instead of $.jin.application:
require( 'jin' ).persistent( function( $ ){
$.connect()
.use( function( req, res ){
res.end( 'hello world!' )
} )
.listen( 80 )
} )
That is all :) How it works? $.jin.persistent forks main module and run callback in child process. And restart it when needed. Example of console output while i editing this simple application:
>node --harmony .
$.jin.persistent: Starting application...
$.jin.persistent: Some files changed!
$.jin.persistent: Starting application...
C:\OpenServer\domains\node.test\index.js:5
res.end( 'hello world!! )
^^^^^^^^^^^^^^^^
SyntaxError: Unexpected token ILLEGAL
at Module._compile (module.js:437:25)
at Object.Module._extensions..js (module.js:467:10)
at Module.load (module.js:356:32)
at Function.Module._load (module.js:312:12)
at Module.runMain (module.js:492:10)
at process.startup.processNextTick.process._tickCallback (node.js:244:9)
$.jin.persistent: Application halted (1)
$.jin.persistent: Some files changed!
$.jin.persistent: Starting application...
SOD - Syncronization On Demand. Use fibers transparent to client code. This is full sync-like api, but with full async backend.
console.log( $.fs.readFileSync( 'data.tree' ).toString() )
This is really sync code that stops the world until file will be loaded. But inside fiber, this stops only current fiber and only when result really needed! See another example:
require( 'jin' ).application( function( $ ){
function get( ){
return $.request.getSync( "http://example.org/?" + Math.random() )
}
console.time( 'serial' )
console.log( get().statusCode )
console.log( get().statusCode )
console.timeEnd( 'serial' )
console.time( 'parallel' )
var resp1= get()
var resp2= get()
console.log( resp1.statusCode )
console.log( resp2.statusCode )
console.timeEnd( 'parallel' )
} )
This code outputs something like this:
200
200
serial: 2418ms
200
200
parallel: 1189ms
The "request" module is not provide "getSync" method, but this is some magic from $.jin.loader that wrap all modules to $.jin.fiberizer proxy. This proxy traps all [name]Sync methods and returns method [name] wrapped to $.jin.async2sync. $.jin.async2sync converts regular async-function to sync-function returns future-proxy that stops current fiber when result of async-task will be accessed. It preserves $.fs.readFileSync sync-api but uses async $.fs.readFile instead.
If you needs for stopping fiber immediately - use [name]SyncNow method instead. See some cut from $.jin.loader that initializing npm and installing some module:
$.npm.loadSyncNow( {} )
$.npm.commands.installSyncNow([ path ])
Tree - new format for representing of tree structures. This is two-dimension format like YAML but collection-oriented like XML. This is very simple and very fast format (i.e. this implementation ~15x faster than "yaml-js", but ~10x slover than native json-parser).
Basic example (like INI):
name =Jin
sex =male
profession =developer
This is 3 struct-nodes with 1 value-node in each of them. All symbols after "=" is raw value without any escaping. For multiline text use multiple values:
about
=Hello, i am javascript developer.
=My e-mail is nin-jin@ya.ru.
=You can use = and any other symbols here.
This is tree with 1 struct-node and 3 value-nodes.
Important! You must use only one symbol (tab or space) for each indent.
Let us make more deep tree:
company
employee
programmer
name =Jin
You can simplify this tree to any of variants like this:
company employee programmer name =Jin
company employee
programmer name =Jin
company
employee programmer
name =Jin
And then you select programmers by this code:
companyTree.select(' company / employee / programmer ')
You will get this tree:
programmer name =Jin
That will be serialized to empty string ( structure-nodes are igrored! ). But if you use "lines" method, that returns tree-object with lines in tree-format:
=programmer name =Jin
That will be serialized right:
programmer name =Jin
See the complex example of using tree-objects:
var treeSource=
[ 'company employee'
, ' programmer name =Jin'
, ' programmer name =Nin'
].join( '\n' )
var company= $.jin.tree([ treeSource ]).parse().select(' company ')
var programmers= company.select(' / employee / programmer ')
console.log( programmers )
//programmer name =Jin
//programmer name =Nin
programmers
.forEach( function( programmer, index ){
console.log( String( programmer.select(' name / ') ) )
} )
//Jin
//Nin
FAQs
Harmoy node.js sugar full-async framework
The npm package jin receives a total of 1 weekly downloads. As such, jin popularity was classified as not popular.
We found that jin demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.