sandglass

WebJar for sandglass

License

License

MIT
GroupId

GroupId

org.webjars.npm
ArtifactId

ArtifactId

sandglass
Last Version

Last Version

1.0.0
Release Date

Release Date

Type

Type

jar
Description

Description

sandglass
WebJar for sandglass
Project URL

Project URL

http://webjars.org
Source Code Management

Source Code Management

https://github.com/airtoxin/sandglass

Download sandglass

How to add to project

<!-- https://jarcasting.com/artifacts/org.webjars.npm/sandglass/ -->
<dependency>
    <groupId>org.webjars.npm</groupId>
    <artifactId>sandglass</artifactId>
    <version>1.0.0</version>
</dependency>
// https://jarcasting.com/artifacts/org.webjars.npm/sandglass/
implementation 'org.webjars.npm:sandglass:1.0.0'
// https://jarcasting.com/artifacts/org.webjars.npm/sandglass/
implementation ("org.webjars.npm:sandglass:1.0.0")
'org.webjars.npm:sandglass:jar:1.0.0'
<dependency org="org.webjars.npm" name="sandglass" rev="1.0.0">
  <artifact name="sandglass" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.webjars.npm', module='sandglass', version='1.0.0')
)
libraryDependencies += "org.webjars.npm" % "sandglass" % "1.0.0"
[org.webjars.npm/sandglass "1.0.0"]

Dependencies

compile (2)

Group / Artifact Type Version
org.webjars.npm : eventemitter2 jar [0.4.14,0.5)
org.webjars.npm : lodash jar [3.3.1,4)

Project Modules

There are no modules declared in this project.

#sandglass npm version Build Status

Aggregates data stream timeline as time window.

#Install

NPM

#Usage

var Sandglass = require( 'sandglass' );
var sandglass = new Sandglass();

#Sandglass Instance Methods

##emit( data );

Send data to all SandStreams.

##absoluteSlice( timespan );

Slices data stream timeline with timespan and aggregates each slice of data stream. Next aggregation starts after one aggregation ends, and another one starts again and again.

absoluteSlice

Arguments

  1. timespan(Number): slice size (millisecond).

Returns

(sandStream): Fires aggregate event after stream aggregation. emitter.on( 'aggregate', callback ); callback gets an array of streaming data.

Example

var sandStream = sandglass.absoluteSlice( 1000 );

setTimeout( function() { sandglass.emit( 1 ) }, 500 );
setTimeout( function() { sandglass.emit( 2 ) }, 800 );
setTimeout( function() { sandglass.emit( 3 ) }, 1700 );
setTimeout( function() { sandglass.emit( 4 ) }, 2100 );
setTimeout( function() { sandglass.emit( 5 ) }, 2300 );
setTimeout( function() { sandglass.emit( 6 ) }, 5000 );

sandStream.on( 'aggregate', function ( agg ) {
    console.log( '@agg:', agg );
    // => [ 1, 2, 3 ] (1 second later)
    // => [ 4, 5 ] (2 second later)
    // => [ 6 ] (3 second later)
    // => [] (6 second later)
    // ...
} );

##relativeSlice( timespan );

Slices data stream timeline with timespan and aggregates each slice of data stream. The aggregation starts at each incoming data, and it ends after it takes the timespan. (Same as delayedCount)

relativeSlice

Arguments

  1. timespan(Number): slice size (millisecond).

Returns

(sandStream): Fires aggregate event after stream aggregation. emitter.on( 'aggregate', callback ); callback gets an array of streaming data.

Example

var sandStream = sandglass.absoluteSlice( 1000 );

setTimeout( function() { sandglass.emit( 1 ) }, 500 );
setTimeout( function() { sandglass.emit( 2 ) }, 800 );
setTimeout( function() { sandglass.emit( 3 ) }, 1700 );
setTimeout( function() { sandglass.emit( 4 ) }, 2100 );
setTimeout( function() { sandglass.emit( 5 ) }, 2300 );
setTimeout( function() { sandglass.emit( 6 ) }, 5000 );

sandStream.on( 'aggregate', function ( agg ) {
    console.log( '@agg:', agg );
    // => [ 1, 2 ] ( 1.5 second later )
    // => [ 2, 3 ] ( 1.8 second later )
    // => [ 3, 4, 5 ] ( 2.7 second later )
    // => [ 4, 5 ] ( 3.1 second later )
    // => [ 5 ] ( 3.3 second later )
    // => [ 6 ] ( 6 second later )
} );

##liveCount( timespan );

When data incomes, 'liveCount' reserve the data. At the same time 'liveCount' sends data as aggregation which was reserved untill at that time. Each data is disposed after it takes timespan.

liveCount

Arguments

  1. timespan(Number): slice size (millisecond).

Returns

(sandStream): Fires aggregate event after stream aggregation. emitter.on( 'aggregate', callback ); callback gets an array of reserved streaming data.

##delayedCount( timespan );

Aliase of relativeSlice (Same as relativeSlice). When data incomes, 'delayedCount' reserve the data. After it takes timespan, 'delayedCount' sends data as aggregation which was reserved untill at that time, and then the data is disposed.

#SandStream Instance Methods

##on( event, listener );

Set event listener. sandStream.on( 'aggregate', function( agg ) {...} )

##off( event, listener );

Remove event listener.

##stop(); Stop aggregation. GC works.

##other methods see EventEmitter2

Versions

Version
1.0.0