Skip to content

File agents to handle writing and reading on Web and NodeJS

Notifications You must be signed in to change notification settings

xutyxd/file-agents

Repository files navigation

File Agents NPM Downloads

The objetive of the repository is to provide classes to read and write with the same interface for Node and Web.

NPM installation

npm install file-agents

Description

There are four "agents", two for Node and another two for web.

Web includes two subagents to allow support propietary implementation on Chromium

This package is distributed with support for MJS and CommonJS

Examples

Web

List files:

// Import reader for web
import { WebReader } from 'file-agents';
// Instance reader
const webReader = new WebReader();
// List files
const files = await webReader.files();

console.log('Files: ', files);

Read from file:

// Import reader for web
import { WebReader } from 'file-agents';
// Instance reader
const webReader = new WebReader();
// List files
const files = await webReader.files();
// Select one, normally user select it
const [ file ] = files;
// Read some portion
const blob = await webReader.read({ start: 0, end: 15 }, file.uuid); // uuid is optional except first time
console.log('Blob: ', blob);

Read from file and write

import { WebReader, WebWriter } from 'file-agents';
// Instance reader
const webReader = new WebReader();
// List files
const files = await webReader.files();
// Select one, normally user select it
const [ file ] = files;
const { uuid, name, size } = file;

const webWriter = new WebWriter({ name, size });
const chunkSize = 1e+7; // 10Mb

// Start reading in a loop
let finished = false;
let cursor = 0;

while(!finished) {
    const chunk = await webReader.read({ start: cursor, end: (cursor + chunkSize) }, uuid);
    await webWriter.write(chunk, cursor);
    cursor += chunk.size;

    finished = cursor >= file.size;
}

webWriter.close();

Node

List files:

// Import reader for node
import { NodeReader } from 'file-agents';
// Instance reader
const nodeReader = new NodeReader();
// List files
const files = await nodeReader.files();

console.log('Files: ', files);

Read from file:

// Import reader for node
import { NodeReader } from 'file-agents';
// Instance reader
const nodeReader = new NodeReader();
// List files
const files = await nodeReader.files();
// Select one, normally user select it
const [ file ] = files;
// Read some portion
const blob = await nodeReader.read({ start: 0, end: 15 }, file.uuid); // uuid is optional except first time
console.log('Blob: ', blob);

Read from file and write

import { NodeReader, NodeWriter } from 'file-agents';
// Instance reader
const nodeReader = new NodeReader();
// List files
const files = await nodeReader.files();
// Select one, normally user select it
const [ file ] = files;
const { uuid, name, size } = file;

const nodeWriter = new NodeWriter({ name });
const chunkSize = 1e+7; // 10Mb

// Start reading in a loop
let finished = false;
let cursor = 0;

while(!finished) {
    const chunk = await nodeReader.read({ start: cursor, end: (cursor + chunkSize) }, uuid);
    await nodeWriter.write(chunk, cursor);
    cursor += chunk.size;

    finished = cursor >= file.size;
}

nodeWriter.close();

Read from file and write using where param on write, allowing to reuse same instance

import { NodeReader, NodeWriter } from 'file-agents';
// Instance reader
const nodeReader = new NodeReader();
// List files
const files = await nodeReader.files();
// Select one, normally user select it
const [ file ] = files;
const { uuid, name, size } = file;

const nodeWriter = new NodeWriter();
const where = { file: name, path: './Downloads' };
const chunkSize = 1e+7; // 10Mb

// Start reading in a loop
let finished = false;
let cursor = 0;

while(!finished) {
    const chunk = await nodeReader.read({ start: cursor, end: (cursor + chunkSize) }, uuid);
    await nodeWriter.write(chunk, cursor);
    cursor += chunk.size;

    finished = cursor >= file.size;
}
// Using where param to close file
nodeWriter.close(where);

About

File agents to handle writing and reading on Web and NodeJS

Resources

Stars

Watchers

Forks

Packages

No packages published