RANDSTREAM
A stream that sprays out random bytes at whoever's read()
-ing it or listening to
its data
. The implementation is surprisingly trivial thanks to
isaacs/readable-stream so I didn't have any tests but you should just take a good
look at the code if you are not sure.
API
The exported RandStream
class accepts a single option hash which is passed along as an
option to the inherited Readable
class with an exception of a few extra parameters:
var RandStream = ; var firehose = mode: 'alpha' defaultSize: 4096 ; firehose;
The mode
option maybe one of the following value:
0
- A zero-filled streams. Essentially no longer random.01
- A zero-one stream. Useful to use as test streams that is a bit less boring :prandom
- Default mode, usingcrypto.randomBytes
to generate data. The buffer is then pushed any reading clients untouched.pseudo
- Usescrypto.pseudoRandomBytes
instead.alpha
- A stream of lowercase alphabets. Useful if you want to see the bytes being piped. The original sequence is generated usingcrypto.randomBytes
.num
- Likealpha
but generate a stream of digits.pregenerated
- Likerandom
but reads from a random start position in a pregenerated buffer of data.
The defaultSize
is the default size of the buffer to allocate when the underlying
_read
implementation is not given a size.
CLI
This module can also be used from the command line if you install globally with -g
$ npm install -g randstream$ rand | hexdump -v
or with different mode and throttling rate:
$ rand alpha 16mcrqijnorspunxrkkeyehapnpfgqfbkzjfvkctxfdkm^C
LICENSE
public domain.