Research
Security News
Quasar RAT Disguised as an npm Package for Detecting Vulnerabilities in Ethereum Smart Contracts
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
isbinaryfile
Advanced tools
The isbinaryfile npm package is used to determine if a file is binary or text. This can be useful in various scenarios such as file processing, content analysis, and data validation.
Check if a file is binary by file path
This feature allows you to check if a file is binary by providing the file path. The function returns a promise that resolves to a boolean indicating whether the file is binary.
const { isBinaryFile } = require('isbinaryfile');
(async () => {
const result = await isBinaryFile('path/to/file');
console.log(result); // true or false
})();
Check if a file is binary by buffer
This feature allows you to check if a file is binary by providing a buffer. The function returns a promise that resolves to a boolean indicating whether the file is binary.
const { isBinaryFile } = require('isbinaryfile');
const fs = require('fs');
(async () => {
const buffer = fs.readFileSync('path/to/file');
const result = await isBinaryFile(buffer);
console.log(result); // true or false
})();
The isbinaryfile package is another option for determining if a file is binary or text. It offers similar functionality to the isbinaryfile package, allowing you to check files by path or buffer.
The file-type package can detect the file type of a buffer or stream. While it is more focused on identifying the file type rather than just determining if it is binary, it can be used to achieve similar results by checking the detected file type.
The binaryextensions package provides a list of binary file extensions. While it does not directly check if a file is binary, it can be used in conjunction with file extension checks to determine if a file is likely to be binary.
Detects if a file is binary in Node.js using ✨promises✨. Similar to Perl's -B
switch, in that:
null
byte; if it's found, it's binaryMuch of the logic is pretty much ported from ag.
Note: if the file doesn't exist or is a directory, an error is thrown.
npm install isbinaryfile
Returns Promise<boolean>
(or just boolean
for *Sync
). true
if the file is binary, false
otherwise.
filepath
- a string
indicating the path to the file.bytes
- a Buffer
of the file's contents.size
- an optional number
indicating the file size.filepath
- a string
indicating the path to the file.bytes
- a Buffer
of the file's contents.size
- an optional number
indicating the file size.Here's an arbitrary usage:
const isBinaryFile = require("isbinaryfile").isBinaryFile;
const fs = require("fs");
const filename = "fixtures/pdf.pdf";
const data = fs.readFileSync(filename);
const stat = fs.lstatSync(filename);
isBinaryFile(data, stat.size).then((result) => {
if (result) {
console.log("It is binary!")
}
else {
console.log("No it is not.")
}
});
const isBinaryFileSync = require("isbinaryfile").isBinaryFileSync;
const bytes = fs.readFileSync(filename);
const size = fs.lstatSync(filename).size;
console.log(isBinaryFileSync(bytes, size)); // true or false
Run npm install
, then run npm test
.
FAQs
Detects if a file is binary in Node.js. Similar to Perl's -B.
The npm package isbinaryfile receives a total of 4,673,726 weekly downloads. As such, isbinaryfile popularity was classified as popular.
We found that isbinaryfile demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Security News
Research
A supply chain attack on Rspack's npm packages injected cryptomining malware, potentially impacting thousands of developers.
Research
Security News
Socket researchers discovered a malware campaign on npm delivering the Skuld infostealer via typosquatted packages, exposing sensitive data.