@push.rocks/smartstream 2.0.3 → 2.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -2,8 +2,8 @@
2
2
  * autocreated commitinfo by @pushrocks/commitinfo
3
3
  */
4
4
  export const commitinfo = {
5
- name: '@pushrocks/smartstream',
6
- version: '2.0.3',
5
+ name: '@push.rocks/smartstream',
6
+ version: '2.0.4',
7
7
  description: 'simplifies access to node streams'
8
8
  };
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMDBfY29tbWl0aW5mb19kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvMDBfY29tbWl0aW5mb19kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3hCLElBQUksRUFBRSx3QkFBd0I7SUFDOUIsT0FBTyxFQUFFLE9BQU87SUFDaEIsV0FBVyxFQUFFLG1DQUFtQztDQUNqRCxDQUFBIn0=
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMDBfY29tbWl0aW5mb19kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvMDBfY29tbWl0aW5mb19kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3hCLElBQUksRUFBRSx5QkFBeUI7SUFDL0IsT0FBTyxFQUFFLE9BQU87SUFDaEIsV0FBVyxFQUFFLG1DQUFtQztDQUNqRCxDQUFBIn0=
@@ -1,3 +1,4 @@
1
+ export * from './smartstream.classes.smartstream.js';
1
2
  export * from './smartstream.classes.streamwrapper.js';
2
3
  export * from './smartstream.classes.streamintake.js';
3
4
  export * from './smartstream.duplex.js';
package/dist_ts/index.js CHANGED
@@ -1,4 +1,5 @@
1
+ export * from './smartstream.classes.smartstream.js';
1
2
  export * from './smartstream.classes.streamwrapper.js';
2
3
  export * from './smartstream.classes.streamintake.js';
3
4
  export * from './smartstream.duplex.js';
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyx5QkFBeUIsQ0FBQyJ9
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHlCQUF5QixDQUFDIn0=
@@ -0,0 +1,12 @@
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ /// <reference types="node" resolution-mode="require"/>
3
+ import * as plugins from './smartstream.plugins.js';
4
+ import { Duplex, type DuplexOptions } from 'stream';
5
+ export declare class SmartStream extends Duplex {
6
+ private observableSubscription?;
7
+ constructor(options?: DuplexOptions);
8
+ _read(size: number): void;
9
+ _write(chunk: any, encoding: string, callback: (error?: Error | null) => void): void;
10
+ static fromBuffer(buffer: Buffer, options?: DuplexOptions): SmartStream;
11
+ static fromObservable(observable: plugins.smartrx.rxjs.Observable<any>, options?: DuplexOptions): SmartStream;
12
+ }
@@ -0,0 +1,48 @@
1
+ import * as plugins from './smartstream.plugins.js';
2
+ import { Duplex } from 'stream';
3
+ export class SmartStream extends Duplex {
4
+ constructor(options) {
5
+ super(options);
6
+ }
7
+ _read(size) {
8
+ // Implement if you need custom behavior, otherwise leave it empty
9
+ }
10
+ _write(chunk, encoding, callback) {
11
+ // Implement if you need custom behavior
12
+ callback();
13
+ }
14
+ static fromBuffer(buffer, options) {
15
+ const smartStream = new SmartStream(options);
16
+ process.nextTick(() => {
17
+ smartStream.push(buffer);
18
+ smartStream.push(null); // Signal the end of the data
19
+ });
20
+ return smartStream;
21
+ }
22
+ static fromObservable(observable, options) {
23
+ const smartStream = new SmartStream(options);
24
+ smartStream.observableSubscription = observable.subscribe({
25
+ next: (data) => {
26
+ if (!smartStream.push(data)) {
27
+ // Pause the observable if the stream buffer is full
28
+ smartStream.observableSubscription?.unsubscribe();
29
+ smartStream.once('drain', () => {
30
+ // Resume the observable when the stream buffer is drained
31
+ smartStream.observableSubscription?.unsubscribe();
32
+ smartStream.observableSubscription = observable.subscribe(data => {
33
+ smartStream.push(data);
34
+ });
35
+ });
36
+ }
37
+ },
38
+ error: (err) => {
39
+ smartStream.emit('error', err);
40
+ },
41
+ complete: () => {
42
+ smartStream.push(null); // Signal the end of the data
43
+ }
44
+ });
45
+ return smartStream;
46
+ }
47
+ }
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzdHJlYW0uY2xhc3Nlcy5zbWFydHN0cmVhbS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0c3RyZWFtLmNsYXNzZXMuc21hcnRzdHJlYW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSwwQkFBMEIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsTUFBTSxFQUFzQixNQUFNLFFBQVEsQ0FBQztBQUVwRCxNQUFNLE9BQU8sV0FBWSxTQUFRLE1BQU07SUFHckMsWUFBWSxPQUF1QjtRQUNqQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztJQUVELEtBQUssQ0FBQyxJQUFZO1FBQ2hCLGtFQUFrRTtJQUNwRSxDQUFDO0lBRUQsTUFBTSxDQUFDLEtBQVUsRUFBRSxRQUFnQixFQUFFLFFBQXdDO1FBQzNFLHdDQUF3QztRQUN4QyxRQUFRLEVBQUUsQ0FBQztJQUNiLENBQUM7SUFFRCxNQUFNLENBQUMsVUFBVSxDQUFDLE1BQWMsRUFBRSxPQUF1QjtRQUN2RCxNQUFNLFdBQVcsR0FBRyxJQUFJLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUM3QyxPQUFPLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUNwQixXQUFXLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3pCLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyw2QkFBNkI7UUFDdkQsQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLFdBQVcsQ0FBQztJQUNyQixDQUFDO0lBRUQsTUFBTSxDQUFDLGNBQWMsQ0FBQyxVQUFnRCxFQUFFLE9BQXVCO1FBQzdGLE1BQU0sV0FBVyxHQUFHLElBQUksV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzdDLFdBQVcsQ0FBQyxzQkFBc0IsR0FBRyxVQUFVLENBQUMsU0FBUyxDQUFDO1lBQ3hELElBQUksRUFBRSxDQUFDLElBQUksRUFBRSxFQUFFO2dCQUNiLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFO29CQUMzQixvREFBb0Q7b0JBQ3BELFdBQVcsQ0FBQyxzQkFBc0IsRUFBRSxXQUFXLEVBQUUsQ0FBQztvQkFDbEQsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsR0FBRyxFQUFFO3dCQUM3QiwwREFBMEQ7d0JBQzFELFdBQVcsQ0FBQyxzQkFBc0IsRUFBRSxXQUFXLEVBQUUsQ0FBQzt3QkFDbEQsV0FBVyxDQUFDLHNCQUFzQixHQUFHLFVBQVUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUU7NEJBQy9ELFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7d0JBQ3pCLENBQUMsQ0FBQyxDQUFDO29CQUNMLENBQUMsQ0FBQyxDQUFDO2lCQUNKO1lBQ0gsQ0FBQztZQUNELEtBQUssRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFO2dCQUNiLFdBQVcsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1lBQ2pDLENBQUM7WUFDRCxRQUFRLEVBQUUsR0FBRyxFQUFFO2dCQUNiLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyw2QkFBNkI7WUFDdkQsQ0FBQztTQUNGLENBQUMsQ0FBQztRQUVILE9BQU8sV0FBVyxDQUFDO0lBQ3JCLENBQUM7Q0FDRiJ9
@@ -1,5 +1,5 @@
1
1
  /// <reference types="node" resolution-mode="require"/>
2
- /// <reference types="node" resolution-mode="require"/>
2
+ /// <reference types="from2" />
3
3
  import * as plugins from './smartstream.plugins.js';
4
4
  export declare class StreamIntake<T> {
5
5
  private signalEndBoolean;
@@ -15,7 +15,7 @@ export declare class StreamIntake<T> {
15
15
  /**
16
16
  * returns an oldstyle readble stream
17
17
  */
18
- getReadableStream(): NodeJS.ReadableStream;
18
+ getReadableStream(): plugins.from2.Stream;
19
19
  pushData(chunkData: T): void;
20
20
  signalEnd(): void;
21
21
  }
@@ -1,6 +1,6 @@
1
1
  import * as plugins from './smartstream.plugins.js';
2
2
  // interfaces
3
- import 'stream';
3
+ import { Transform } from 'stream';
4
4
  /**
5
5
  * class Smartstream handles
6
6
  */
@@ -78,4 +78,4 @@ export let cleanPipe = () => {
78
78
  cb();
79
79
  });
80
80
  };
81
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzdHJlYW0uY2xhc3Nlcy5zdHJlYW13cmFwcGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRzdHJlYW0uY2xhc3Nlcy5zdHJlYW13cmFwcGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sMEJBQTBCLENBQUM7QUFFcEQsYUFBYTtBQUNiLE9BQTBCLFFBQVEsQ0FBQztBQWVuQzs7R0FFRztBQUNILE1BQU0sT0FBTyxhQUFhO0lBS3hCOztPQUVHO0lBQ0gsWUFBWSxjQUFxQjtRQVB6QixnQkFBVyxHQUFpQyxFQUFFLENBQUM7UUFDL0MsMkJBQXNCLEdBQXlCLEVBQUUsQ0FBQztRQUNsRCwwQkFBcUIsR0FBRyxPQUFPLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBTTNELElBQUksQ0FBQyxXQUFXLEdBQUcsY0FBYyxDQUFDO0lBQ3BDLENBQUM7SUFFRDs7T0FFRztJQUNILGFBQWE7UUFDWCxPQUFPLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxPQUFPLENBQUM7SUFDNUMsQ0FBQztJQUVEOztPQUVHO0lBQ0gsYUFBYSxDQUFDLFlBQW9CLEVBQUUsZ0JBQXNDO1FBQ3hFLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxJQUFJLENBQUM7WUFDL0IsU0FBUyxFQUFFLFlBQVk7WUFDdkIsYUFBYSxFQUFFLGdCQUFnQjtTQUNoQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsR0FBRztRQUNELE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFRLENBQUM7UUFFaEQsY0FBYztRQUNkLE1BQU0sb0JBQW9CLEdBQWlDLEVBQUUsQ0FBQztRQUM5RCxLQUFLLE1BQU0sVUFBVSxJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUU7WUFDekMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1NBQ3ZDO1FBRUQscUJBQXFCO1FBQ3JCLElBQUksV0FBVyxHQUFHLElBQUksQ0FBQztRQUN2QixJQUFJLGNBQWMsR0FBWSxJQUFJLENBQUM7UUFDbkMsS0FBSyxNQUFNLE1BQU0sSUFBSSxvQkFBb0IsRUFBRTtZQUN6QyxJQUFJLGNBQWMsS0FBSyxJQUFJLEVBQUU7Z0JBQzNCLFdBQVcsR0FBRyxNQUFNLENBQUM7YUFDdEI7WUFDRCxNQUFNLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFO2dCQUN6QixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ25CLENBQUMsQ0FBQyxDQUFDO1lBQ0gsS0FBSyxNQUFNLGlCQUFpQixJQUFJLElBQUksQ0FBQyxzQkFBc0IsRUFBRTtnQkFDM0QsTUFBTSxDQUFDLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQyxTQUFTLEVBQUUsaUJBQWlCLENBQUMsYUFBYSxDQUFDLENBQUM7YUFDekU7WUFDRCxJQUFJLENBQUMsY0FBYyxFQUFFO2dCQUNuQixXQUFXLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQzthQUN4QztZQUNELGNBQWMsR0FBRyxLQUFLLENBQUM7U0FDeEI7UUFFRCxJQUFJLENBQUMscUJBQXFCLENBQUMsT0FBTyxFQUFFLENBQUM7UUFFckMsV0FBVyxDQUFDLEVBQUUsQ0FBQyxLQUFLLEVBQUUsR0FBRyxFQUFFO1lBQ3pCLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNqQixDQUFDLENBQUMsQ0FBQztRQUNILFdBQVcsQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFLEdBQUcsRUFBRTtZQUMzQixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDakIsQ0FBQyxDQUFDLENBQUM7UUFDSCxXQUFXLENBQUMsRUFBRSxDQUFDLFFBQVEsRUFBRSxHQUFHLEVBQUU7WUFDNUIsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2pCLENBQUMsQ0FBQyxDQUFDO1FBQ0gsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7Q0FDRjtBQUVELE1BQU0sQ0FBQyxJQUFJLFNBQVMsR0FBRyxHQUFHLEVBQUU7SUFDMUIsT0FBTyxPQUFPLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FDekIsQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLEVBQUUsRUFBRSxFQUFFO1FBQ2hCLEVBQUUsRUFBRSxDQUFDO0lBQ1AsQ0FBQyxFQUNELENBQUMsRUFBRSxFQUFFLEVBQUU7UUFDTCxFQUFFLEVBQUUsQ0FBQztJQUNQLENBQUMsQ0FDRixDQUFDO0FBQ0osQ0FBQyxDQUFDIn0=
81
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzdHJlYW0uY2xhc3Nlcy5zdHJlYW13cmFwcGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRzdHJlYW0uY2xhc3Nlcy5zdHJlYW13cmFwcGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sMEJBQTBCLENBQUM7QUFFcEQsYUFBYTtBQUNiLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFlbkM7O0dBRUc7QUFDSCxNQUFNLE9BQU8sYUFBYTtJQUt4Qjs7T0FFRztJQUNILFlBQVksY0FBcUI7UUFQekIsZ0JBQVcsR0FBaUMsRUFBRSxDQUFDO1FBQy9DLDJCQUFzQixHQUF5QixFQUFFLENBQUM7UUFDbEQsMEJBQXFCLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQU0zRCxJQUFJLENBQUMsV0FBVyxHQUFHLGNBQWMsQ0FBQztJQUNwQyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxhQUFhO1FBQ1gsT0FBTyxJQUFJLENBQUMscUJBQXFCLENBQUMsT0FBTyxDQUFDO0lBQzVDLENBQUM7SUFFRDs7T0FFRztJQUNILGFBQWEsQ0FBQyxZQUFvQixFQUFFLGdCQUFzQztRQUN4RSxJQUFJLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUFDO1lBQy9CLFNBQVMsRUFBRSxZQUFZO1lBQ3ZCLGFBQWEsRUFBRSxnQkFBZ0I7U0FDaEMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVEOzs7T0FHRztJQUNILEdBQUc7UUFDRCxNQUFNLElBQUksR0FBRyxPQUFPLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBUSxDQUFDO1FBRWhELGNBQWM7UUFDZCxNQUFNLG9CQUFvQixHQUFpQyxFQUFFLENBQUM7UUFDOUQsS0FBSyxNQUFNLFVBQVUsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ3pDLG9CQUFvQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztTQUN2QztRQUVELHFCQUFxQjtRQUNyQixJQUFJLFdBQVcsR0FBRyxJQUFJLENBQUM7UUFDdkIsSUFBSSxjQUFjLEdBQVksSUFBSSxDQUFDO1FBQ25DLEtBQUssTUFBTSxNQUFNLElBQUksb0JBQW9CLEVBQUU7WUFDekMsSUFBSSxjQUFjLEtBQUssSUFBSSxFQUFFO2dCQUMzQixXQUFXLEdBQUcsTUFBTSxDQUFDO2FBQ3RCO1lBQ0QsTUFBTSxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxHQUFHLEVBQUUsRUFBRTtnQkFDekIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNuQixDQUFDLENBQUMsQ0FBQztZQUNILEtBQUssTUFBTSxpQkFBaUIsSUFBSSxJQUFJLENBQUMsc0JBQXNCLEVBQUU7Z0JBQzNELE1BQU0sQ0FBQyxFQUFFLENBQUMsaUJBQWlCLENBQUMsU0FBUyxFQUFFLGlCQUFpQixDQUFDLGFBQWEsQ0FBQyxDQUFDO2FBQ3pFO1lBQ0QsSUFBSSxDQUFDLGNBQWMsRUFBRTtnQkFDbkIsV0FBVyxHQUFHLFdBQVcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7YUFDeEM7WUFDRCxjQUFjLEdBQUcsS0FBSyxDQUFDO1NBQ3hCO1FBRUQsSUFBSSxDQUFDLHFCQUFxQixDQUFDLE9BQU8sRUFBRSxDQUFDO1FBRXJDLFdBQVcsQ0FBQyxFQUFFLENBQUMsS0FBSyxFQUFFLEdBQUcsRUFBRTtZQUN6QixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDakIsQ0FBQyxDQUFDLENBQUM7UUFDSCxXQUFXLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUU7WUFDM0IsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2pCLENBQUMsQ0FBQyxDQUFDO1FBQ0gsV0FBVyxDQUFDLEVBQUUsQ0FBQyxRQUFRLEVBQUUsR0FBRyxFQUFFO1lBQzVCLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNqQixDQUFDLENBQUMsQ0FBQztRQUNILE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0NBQ0Y7QUFFRCxNQUFNLENBQUMsSUFBSSxTQUFTLEdBQUcsR0FBRyxFQUFFO0lBQzFCLE9BQU8sT0FBTyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQ3pCLENBQUMsSUFBSSxFQUFFLEdBQUcsRUFBRSxFQUFFLEVBQUUsRUFBRTtRQUNoQixFQUFFLEVBQUUsQ0FBQztJQUNQLENBQUMsRUFDRCxDQUFDLEVBQUUsRUFBRSxFQUFFO1FBQ0wsRUFBRSxFQUFFLENBQUM7SUFDUCxDQUFDLENBQ0YsQ0FBQztBQUNKLENBQUMsQ0FBQyJ9
@@ -1,7 +1,7 @@
1
1
  import * as stream from 'stream';
2
2
  export { stream };
3
- import * as smartpromise from '@pushrocks/smartpromise';
4
- import * as smartrx from '@pushrocks/smartrx';
3
+ import * as smartpromise from '@push.rocks/smartpromise';
4
+ import * as smartrx from '@push.rocks/smartrx';
5
5
  export { smartpromise, smartrx };
6
6
  import from2 from 'from2';
7
7
  import through2 from 'through2';
@@ -2,11 +2,11 @@
2
2
  import * as stream from 'stream';
3
3
  export { stream };
4
4
  // pushrocks scope
5
- import * as smartpromise from '@pushrocks/smartpromise';
6
- import * as smartrx from '@pushrocks/smartrx';
5
+ import * as smartpromise from '@push.rocks/smartpromise';
6
+ import * as smartrx from '@push.rocks/smartrx';
7
7
  export { smartpromise, smartrx };
8
8
  // thirdparty
9
9
  import from2 from 'from2';
10
10
  import through2 from 'through2';
11
11
  export { from2, through2 };
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzdHJlYW0ucGx1Z2lucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0c3RyZWFtLnBsdWdpbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYztBQUNkLE9BQU8sS0FBSyxNQUFNLE1BQU0sUUFBUSxDQUFDO0FBRWpDLE9BQU8sRUFBRSxNQUFNLEVBQUUsQ0FBQztBQUVsQixrQkFBa0I7QUFDbEIsT0FBTyxLQUFLLFlBQVksTUFBTSx5QkFBeUIsQ0FBQztBQUN4RCxPQUFPLEtBQUssT0FBTyxNQUFNLG9CQUFvQixDQUFDO0FBRTlDLE9BQU8sRUFBRSxZQUFZLEVBQUUsT0FBTyxFQUFFLENBQUM7QUFFakMsYUFBYTtBQUNiLE9BQU8sS0FBSyxNQUFNLE9BQU8sQ0FBQztBQUMxQixPQUFPLFFBQVEsTUFBTSxVQUFVLENBQUM7QUFFaEMsT0FBTyxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUUsQ0FBQyJ9
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzdHJlYW0ucGx1Z2lucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0c3RyZWFtLnBsdWdpbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYztBQUNkLE9BQU8sS0FBSyxNQUFNLE1BQU0sUUFBUSxDQUFDO0FBRWpDLE9BQU8sRUFBRSxNQUFNLEVBQUUsQ0FBQztBQUVsQixrQkFBa0I7QUFDbEIsT0FBTyxLQUFLLFlBQVksTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEtBQUssT0FBTyxNQUFNLHFCQUFxQixDQUFDO0FBRS9DLE9BQU8sRUFBRSxZQUFZLEVBQUUsT0FBTyxFQUFFLENBQUM7QUFFakMsYUFBYTtBQUNiLE9BQU8sS0FBSyxNQUFNLE9BQU8sQ0FBQztBQUMxQixPQUFPLFFBQVEsTUFBTSxVQUFVLENBQUM7QUFFaEMsT0FBTyxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUUsQ0FBQyJ9
package/npmextra.json CHANGED
@@ -7,10 +7,10 @@
7
7
  "projectType": "npm",
8
8
  "module": {
9
9
  "githost": "gitlab.com",
10
- "gitscope": "pushrocks",
10
+ "gitscope": "push.rocks",
11
11
  "gitrepo": "smartstream",
12
12
  "description": "simplifies access to node streams",
13
- "npmPackagename": "@pushrocks/smartstream",
13
+ "npmPackagename": "@push.rocks/smartstream",
14
14
  "license": "MIT"
15
15
  }
16
16
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@push.rocks/smartstream",
3
- "version": "2.0.3",
3
+ "version": "2.0.5",
4
4
  "private": false,
5
5
  "description": "simplifies access to node streams",
6
6
  "main": "dist_ts/index.js",
@@ -21,18 +21,17 @@
21
21
  },
22
22
  "homepage": "https://gitlab.com/pushrocks/smartstream#README",
23
23
  "devDependencies": {
24
- "@gitzone/tsbuild": "^2.1.63",
25
- "@gitzone/tstest": "^1.0.71",
26
- "@pushrocks/smartfile": "^10.0.0",
27
- "@pushrocks/tapbundle": "^5.0.3",
28
- "tslint": "^6.1.3",
29
- "tslint-config-prettier": "^1.18.0"
24
+ "@git.zone/tsbuild": "^2.1.66",
25
+ "@git.zone/tsrun": "^1.2.44",
26
+ "@git.zone/tstest": "^1.0.77",
27
+ "@push.rocks/smartfile": "^10.0.33",
28
+ "@push.rocks/tapbundle": "^5.0.15"
30
29
  },
31
30
  "dependencies": {
32
- "@pushrocks/smartpromise": "^3.1.7",
33
- "@pushrocks/smartrx": "^2.0.25",
34
- "@types/from2": "^2.3.1",
35
- "@types/through2": "^2.0.36",
31
+ "@push.rocks/smartpromise": "^4.0.3",
32
+ "@push.rocks/smartrx": "^3.0.7",
33
+ "@types/from2": "^2.3.4",
34
+ "@types/through2": "^2.0.40",
36
35
  "from2": "^2.3.0",
37
36
  "through2": "^4.0.2"
38
37
  },
@@ -51,4 +50,4 @@
51
50
  "npmextra.json",
52
51
  "readme.md"
53
52
  ]
54
- }
53
+ }
@@ -2,7 +2,7 @@
2
2
  * autocreated commitinfo by @pushrocks/commitinfo
3
3
  */
4
4
  export const commitinfo = {
5
- name: '@pushrocks/smartstream',
6
- version: '2.0.3',
5
+ name: '@push.rocks/smartstream',
6
+ version: '2.0.5',
7
7
  description: 'simplifies access to node streams'
8
8
  }
package/ts/index.ts CHANGED
@@ -1,3 +1,4 @@
1
+ export * from './smartstream.classes.smartstream.js';
1
2
  export * from './smartstream.classes.streamwrapper.js';
2
3
  export * from './smartstream.classes.streamintake.js';
3
4
  export * from './smartstream.duplex.js';
@@ -0,0 +1,55 @@
1
+ import * as plugins from './smartstream.plugins.js';
2
+ import { Duplex, type DuplexOptions } from 'stream';
3
+
4
+ export class SmartStream extends Duplex {
5
+ private observableSubscription?: plugins.smartrx.rxjs.Subscription;
6
+
7
+ constructor(options?: DuplexOptions) {
8
+ super(options);
9
+ }
10
+
11
+ _read(size: number) {
12
+ // Implement if you need custom behavior, otherwise leave it empty
13
+ }
14
+
15
+ _write(chunk: any, encoding: string, callback: (error?: Error | null) => void) {
16
+ // Implement if you need custom behavior
17
+ callback();
18
+ }
19
+
20
+ static fromBuffer(buffer: Buffer, options?: DuplexOptions): SmartStream {
21
+ const smartStream = new SmartStream(options);
22
+ process.nextTick(() => {
23
+ smartStream.push(buffer);
24
+ smartStream.push(null); // Signal the end of the data
25
+ });
26
+ return smartStream;
27
+ }
28
+
29
+ static fromObservable(observable: plugins.smartrx.rxjs.Observable<any>, options?: DuplexOptions): SmartStream {
30
+ const smartStream = new SmartStream(options);
31
+ smartStream.observableSubscription = observable.subscribe({
32
+ next: (data) => {
33
+ if (!smartStream.push(data)) {
34
+ // Pause the observable if the stream buffer is full
35
+ smartStream.observableSubscription?.unsubscribe();
36
+ smartStream.once('drain', () => {
37
+ // Resume the observable when the stream buffer is drained
38
+ smartStream.observableSubscription?.unsubscribe();
39
+ smartStream.observableSubscription = observable.subscribe(data => {
40
+ smartStream.push(data);
41
+ });
42
+ });
43
+ }
44
+ },
45
+ error: (err) => {
46
+ smartStream.emit('error', err);
47
+ },
48
+ complete: () => {
49
+ smartStream.push(null); // Signal the end of the data
50
+ }
51
+ });
52
+
53
+ return smartStream;
54
+ }
55
+ }
@@ -4,8 +4,8 @@ import * as stream from 'stream';
4
4
  export { stream };
5
5
 
6
6
  // pushrocks scope
7
- import * as smartpromise from '@pushrocks/smartpromise';
8
- import * as smartrx from '@pushrocks/smartrx';
7
+ import * as smartpromise from '@push.rocks/smartpromise';
8
+ import * as smartrx from '@push.rocks/smartrx';
9
9
 
10
10
  export { smartpromise, smartrx };
11
11