Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@meteor-it/fs

Package Overview
Dependencies
Maintainers
2
Versions
43
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@meteor-it/fs - npm Package Compare versions

Comparing version 1.1.2 to 1.1.3

8

index.d.ts
/// <reference types="node" />
import { promises as fs, Stats } from 'fs';
declare type FileHandle = fs.FileHandle;
import fsNative, { Stats } from 'fs';
declare type FileHandle = fsNative.promises.FileHandle;
export interface IParsedDataUrl {

@@ -49,7 +49,7 @@ mime: string;

*/
export declare function getReadStream(path: string, options?: {}): import("fs").ReadStream;
export declare function getReadStream(path: string, options?: {}): fsNative.ReadStream;
/**
* Wrapper to fs function
*/
export declare function getWriteStream(path: string, options?: {}): import("fs").WriteStream;
export declare function getWriteStream(path: string, options?: {}): fsNative.WriteStream;
export {};
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const fs_1 = require("fs");
const path_1 = require("path");
const utils_1 = require("@meteor-it/utils");
const path_1 = require("path");
const { promises: fs, constants: fsConstants, createReadStream, createWriteStream } = fs_1.default;
const { sep } = path_1.default;
/**

@@ -27,3 +29,3 @@ * Returns true if path is a valid data url

async function readDir(dir) {
return await fs_1.promises.readdir(dir);
return await fs.readdir(dir);
}

@@ -38,15 +40,15 @@ exports.readDir = readDir;

return parseDataUrl(file).data;
return await fs_1.promises.readFile(file);
return await fs.readFile(file);
}
exports.readFile = readFile;
async function stat(file) {
return await fs_1.promises.stat(file);
return await fs.stat(file);
}
exports.stat = stat;
async function open(file, mode, access) {
return await fs_1.promises.open(file, mode, access);
return await fs.open(file, mode, access);
}
exports.open = open;
async function read(fd, buffer, offset, length, position) {
return await fs_1.promises.read(fd, buffer, offset, length, position);
return await fs.read(fd, buffer, offset, length, position);
}

@@ -58,3 +60,3 @@ exports.read = read;

async function writeFile(filename, text) {
return await fs_1.promises.writeFile(filename, text);
return await fs.writeFile(filename, text);
}

@@ -77,3 +79,3 @@ exports.writeFile = writeFile;

cb = (file, dir) => {
returnValue.push(dir + path_1.sep + file);
returnValue.push(dir + sep + file);
};

@@ -83,3 +85,3 @@ }

await utils_1.asyncEach(await readDir(dir), async (file) => {
let path = dir + path_1.sep + file;
let path = dir + sep + file;
if (await isFile(path)) {

@@ -93,3 +95,3 @@ cb(file, dir);

await utils_1.asyncEach(dirList, async (dirLevelDown) => {
await walkDir(dir + path_1.sep + dirLevelDown, cb);
await walkDir(dir + sep + dirLevelDown, cb);
});

@@ -107,3 +109,3 @@ if (shouldReturn) {

try {
let result = await fs_1.promises.access(file, fs_1.constants.F_OK);
let result = await fs.access(file, fsConstants.F_OK);
return result === undefined;

@@ -136,3 +138,3 @@ }

function getReadStream(path, options = {}) {
return fs_1.createReadStream(path, options);
return createReadStream(path, options);
}

@@ -144,6 +146,6 @@ exports.getReadStream = getReadStream;

function getWriteStream(path, options = {}) {
return fs_1.createWriteStream(path, options);
return createWriteStream(path, options);
}
exports.getWriteStream = getWriteStream;
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["xrest/node_modules/@meteor-it/fs/index.ts"],"names":[],"mappings":"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","file":"xrest/node_modules/@meteor-it/fs/index.js","sourcesContent":["import {promises as fs,Stats,constants as fsConstants,createReadStream,createWriteStream} from 'fs';\nimport {asyncEach} from '@meteor-it/utils';\nimport {sep} from 'path';\n\ntype FileHandle = fs.FileHandle;\n/**\n * Returns true if path is a valid data url\n * @param path path\n */\nfunction isDataUrl(path:string):boolean{\n\treturn /^data:.+\\/.+;base64,/.test(path.substr(0,268))\n}\n\nexport interface IParsedDataUrl{\n\tmime: string,\n\tdata: Buffer\n}\n/**\n * Returns mime and data of dataurl\n * @param path Data url\n */\nfunction parseDataUrl(path:string):IParsedDataUrl{\n\treturn {\n\t\tmime: path.slice(5,path.indexOf(';')),\n\t\tdata: Buffer.from(path.slice(path.indexOf(',')+1),'base64')\n\t}\n}\n\n/**\n * Get all files in directory\n */\nexport async function readDir (dir:string) {\n\treturn await fs.readdir(dir);\n}\n/**\n * Read file or parse data url\n * @param file Path to file to read\n */\nexport async function readFile (file:string):Promise<Buffer> {\n\tif(isDataUrl(file))\n\t\treturn parseDataUrl(file).data;\n\treturn await fs.readFile(file);\n}\n\nexport async function stat (file:string):Promise<Stats>{\n\treturn await fs.stat(file);\n}\n\nexport async function open (file:string,mode:string,access:string):Promise<FileHandle>{\n\treturn await fs.open(file,mode,access);\n}\n\nexport async function read(fd: FileHandle, buffer:Buffer, offset:number, length:number, position:number){\n\treturn await fs.read(fd, buffer, offset, length, position);\n}\n\n/**\n * Write text to file\n */\nexport async function writeFile (filename:string, text:string|Buffer) {\n\treturn await fs.writeFile(filename, text);\n}\n\n/**\n * Walk directory\n * @param dir Directory to walk\n * @param cb If provided, found files will returned realtime. If not - function will return all found files\n */\nexport async function walkDir (dir:string, cb?:(file:string,dir:string)=>void):Promise<string[]|null> {\n\tif (!await exists(dir)) { throw new Error('No such file or directory: ' + dir); }\n\tlet returnValue:string[];\n\tlet shouldReturn = false;\n\tif (!cb) {\n\t\treturnValue = [];\n\t\tshouldReturn = true;\n\t\tcb = (file:string, dir:string) => {\n\t\t\treturnValue.push(dir + sep + file);\n\t\t};\n\t}\n\tlet dirList:string[] = [];\n\tawait asyncEach(await readDir(dir), async(file:string) => {\n\t\tlet path = dir + sep + file;\n\t\tif (await isFile(path)) {\n\t\t\tcb(file, dir);\n\t\t} else if (await isDirectory(path)) {\n\t\t\tdirList.push(file);\n\t\t}\n\t});\n\tawait asyncEach(dirList, async(dirLevelDown:string) => {\n\t\tawait walkDir(dir + sep + dirLevelDown, cb);\n\t});\n\tif (shouldReturn) {\n\t    return returnValue.sort();\n\t}\n\treturn null;\n}\n\n/**\n * Check if file exists\n */\nexport async function exists (file:string):Promise<boolean> {\n\ttry {\n\t\tlet result = await fs.access(file, fsConstants.F_OK);\n\t\treturn result === undefined;\n    } catch (e) {\n        // Because only \"err\" field is returned if not exists\n\t\treturn false;\n\t}\n}\n\n/**\n * Is path a file\n * @param path path to test\n */\nexport async function isFile (path:string): Promise<boolean> {\n\treturn (await stat(path)).isFile();\n}\n/**\n * Is path a directory\n */\nexport async function isDirectory (path:string): Promise<boolean> {\n\treturn (await stat(path)).isDirectory();\n}\n\n/**\n * Wrapper to fs function\n */\nexport function getReadStream (path:string, options = {}) {\n\treturn createReadStream(path, options);\n}\n\n/**\n * Wrapper to fs function\n */\nexport function getWriteStream (path:string, options={}) {\n\treturn createWriteStream(path, options);\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["xrest/node_modules/@meteor-it/fs/index.ts"],"names":[],"mappings":"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","file":"xrest/node_modules/@meteor-it/fs/index.js","sourcesContent":["import fsNative, { Stats } from 'fs';\nimport path from 'path';\nimport { asyncEach } from '@meteor-it/utils';\n\nconst { promises: fs, constants: fsConstants, createReadStream, createWriteStream } = fsNative;\nconst { sep } = path;\ntype FileHandle = fsNative.promises.FileHandle;\n/**\n * Returns true if path is a valid data url\n * @param path path\n */\nfunction isDataUrl(path: string): boolean {\n\treturn /^data:.+\\/.+;base64,/.test(path.substr(0, 268))\n}\n\nexport interface IParsedDataUrl {\n\tmime: string,\n\tdata: Buffer\n}\n/**\n * Returns mime and data of dataurl\n * @param path Data url\n */\nfunction parseDataUrl(path: string): IParsedDataUrl {\n\treturn {\n\t\tmime: path.slice(5, path.indexOf(';')),\n\t\tdata: Buffer.from(path.slice(path.indexOf(',') + 1), 'base64')\n\t}\n}\n\n/**\n * Get all files in directory\n */\nexport async function readDir(dir: string) {\n\treturn await fs.readdir(dir);\n}\n/**\n * Read file or parse data url\n * @param file Path to file to read\n */\nexport async function readFile(file: string): Promise<Buffer> {\n\tif (isDataUrl(file))\n\t\treturn parseDataUrl(file).data;\n\treturn await fs.readFile(file);\n}\n\nexport async function stat(file: string): Promise<Stats> {\n\treturn await fs.stat(file);\n}\n\nexport async function open(file: string, mode: string, access: string): Promise<FileHandle> {\n\treturn await fs.open(file, mode, access);\n}\n\nexport async function read(fd: FileHandle, buffer: Buffer, offset: number, length: number, position: number) {\n\treturn await fs.read(fd, buffer, offset, length, position);\n}\n\n/**\n * Write text to file\n */\nexport async function writeFile(filename: string, text: string | Buffer) {\n\treturn await fs.writeFile(filename, text);\n}\n\n/**\n * Walk directory\n * @param dir Directory to walk\n * @param cb If provided, found files will returned realtime. If not - function will return all found files\n */\nexport async function walkDir(dir: string, cb?: (file: string, dir: string) => void): Promise<string[] | null> {\n\tif (!await exists(dir)) { throw new Error('No such file or directory: ' + dir); }\n\tlet returnValue: string[];\n\tlet shouldReturn = false;\n\tif (!cb) {\n\t\treturnValue = [];\n\t\tshouldReturn = true;\n\t\tcb = (file: string, dir: string) => {\n\t\t\treturnValue.push(dir + sep + file);\n\t\t};\n\t}\n\tlet dirList: string[] = [];\n\tawait asyncEach(await readDir(dir), async (file: string) => {\n\t\tlet path = dir + sep + file;\n\t\tif (await isFile(path)) {\n\t\t\tcb(file, dir);\n\t\t} else if (await isDirectory(path)) {\n\t\t\tdirList.push(file);\n\t\t}\n\t});\n\tawait asyncEach(dirList, async (dirLevelDown: string) => {\n\t\tawait walkDir(dir + sep + dirLevelDown, cb);\n\t});\n\tif (shouldReturn) {\n\t\treturn returnValue.sort();\n\t}\n\treturn null;\n}\n\n/**\n * Check if file exists\n */\nexport async function exists(file: string): Promise<boolean> {\n\ttry {\n\t\tlet result = await fs.access(file, fsConstants.F_OK);\n\t\treturn result === undefined;\n\t} catch (e) {\n\t\t// Because only \"err\" field is returned if not exists\n\t\treturn false;\n\t}\n}\n\n/**\n * Is path a file\n * @param path path to test\n */\nexport async function isFile(path: string): Promise<boolean> {\n\treturn (await stat(path)).isFile();\n}\n/**\n * Is path a directory\n */\nexport async function isDirectory(path: string): Promise<boolean> {\n\treturn (await stat(path)).isDirectory();\n}\n\n/**\n * Wrapper to fs function\n */\nexport function getReadStream(path: string, options = {}) {\n\treturn createReadStream(path, options);\n}\n\n/**\n * Wrapper to fs function\n */\nexport function getWriteStream(path: string, options = {}) {\n\treturn createWriteStream(path, options);\n}\n"]}

@@ -1,6 +0,8 @@

import {promises as fs,Stats,constants as fsConstants,createReadStream,createWriteStream} from 'fs';
import {asyncEach} from '@meteor-it/utils';
import {sep} from 'path';
import fsNative, { Stats } from 'fs';
import path from 'path';
import { asyncEach } from '@meteor-it/utils';
type FileHandle = fs.FileHandle;
const { promises: fs, constants: fsConstants, createReadStream, createWriteStream } = fsNative;
const { sep } = path;
type FileHandle = fsNative.promises.FileHandle;
/**

@@ -10,7 +12,7 @@ * Returns true if path is a valid data url

*/
function isDataUrl(path:string):boolean{
return /^data:.+\/.+;base64,/.test(path.substr(0,268))
function isDataUrl(path: string): boolean {
return /^data:.+\/.+;base64,/.test(path.substr(0, 268))
}
export interface IParsedDataUrl{
export interface IParsedDataUrl {
mime: string,

@@ -23,6 +25,6 @@ data: Buffer

*/
function parseDataUrl(path:string):IParsedDataUrl{
function parseDataUrl(path: string): IParsedDataUrl {
return {
mime: path.slice(5,path.indexOf(';')),
data: Buffer.from(path.slice(path.indexOf(',')+1),'base64')
mime: path.slice(5, path.indexOf(';')),
data: Buffer.from(path.slice(path.indexOf(',') + 1), 'base64')
}

@@ -34,3 +36,3 @@ }

*/
export async function readDir (dir:string) {
export async function readDir(dir: string) {
return await fs.readdir(dir);

@@ -42,4 +44,4 @@ }

*/
export async function readFile (file:string):Promise<Buffer> {
if(isDataUrl(file))
export async function readFile(file: string): Promise<Buffer> {
if (isDataUrl(file))
return parseDataUrl(file).data;

@@ -49,11 +51,11 @@ return await fs.readFile(file);

export async function stat (file:string):Promise<Stats>{
export async function stat(file: string): Promise<Stats> {
return await fs.stat(file);
}
export async function open (file:string,mode:string,access:string):Promise<FileHandle>{
return await fs.open(file,mode,access);
export async function open(file: string, mode: string, access: string): Promise<FileHandle> {
return await fs.open(file, mode, access);
}
export async function read(fd: FileHandle, buffer:Buffer, offset:number, length:number, position:number){
export async function read(fd: FileHandle, buffer: Buffer, offset: number, length: number, position: number) {
return await fs.read(fd, buffer, offset, length, position);

@@ -65,3 +67,3 @@ }

*/
export async function writeFile (filename:string, text:string|Buffer) {
export async function writeFile(filename: string, text: string | Buffer) {
return await fs.writeFile(filename, text);

@@ -75,5 +77,5 @@ }

*/
export async function walkDir (dir:string, cb?:(file:string,dir:string)=>void):Promise<string[]|null> {
export async function walkDir(dir: string, cb?: (file: string, dir: string) => void): Promise<string[] | null> {
if (!await exists(dir)) { throw new Error('No such file or directory: ' + dir); }
let returnValue:string[];
let returnValue: string[];
let shouldReturn = false;

@@ -83,8 +85,8 @@ if (!cb) {

shouldReturn = true;
cb = (file:string, dir:string) => {
cb = (file: string, dir: string) => {
returnValue.push(dir + sep + file);
};
}
let dirList:string[] = [];
await asyncEach(await readDir(dir), async(file:string) => {
let dirList: string[] = [];
await asyncEach(await readDir(dir), async (file: string) => {
let path = dir + sep + file;

@@ -97,7 +99,7 @@ if (await isFile(path)) {

});
await asyncEach(dirList, async(dirLevelDown:string) => {
await asyncEach(dirList, async (dirLevelDown: string) => {
await walkDir(dir + sep + dirLevelDown, cb);
});
if (shouldReturn) {
return returnValue.sort();
return returnValue.sort();
}

@@ -110,8 +112,8 @@ return null;

*/
export async function exists (file:string):Promise<boolean> {
export async function exists(file: string): Promise<boolean> {
try {
let result = await fs.access(file, fsConstants.F_OK);
return result === undefined;
} catch (e) {
// Because only "err" field is returned if not exists
} catch (e) {
// Because only "err" field is returned if not exists
return false;

@@ -125,3 +127,3 @@ }

*/
export async function isFile (path:string): Promise<boolean> {
export async function isFile(path: string): Promise<boolean> {
return (await stat(path)).isFile();

@@ -132,3 +134,3 @@ }

*/
export async function isDirectory (path:string): Promise<boolean> {
export async function isDirectory(path: string): Promise<boolean> {
return (await stat(path)).isDirectory();

@@ -140,3 +142,3 @@ }

*/
export function getReadStream (path:string, options = {}) {
export function getReadStream(path: string, options = {}) {
return createReadStream(path, options);

@@ -148,4 +150,4 @@ }

*/
export function getWriteStream (path:string, options={}) {
export function getWriteStream(path: string, options = {}) {
return createWriteStream(path, options);
}
{
"name": "@meteor-it/fs",
"version": "1.1.2",
"version": "1.1.3",
"description": "Wrappers for native fs module",

@@ -14,3 +14,3 @@ "module": "index.mjs",

"dependencies": {
"@meteor-it/utils": "^1.3.12"
"@meteor-it/utils": "^1.3.13"
},

@@ -21,3 +21,3 @@ "sideEffects": false,

},
"gitHead": "888982e812786093e95b2103f646c34fdd32abc5"
"gitHead": "13a378ab6afab3cac18cd00dd670900bf81d4a3e"
}

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc