Gathering detailed insights and metrics for @ryniaubenpm2/ea-commodi-voluptatibus
Gathering detailed insights and metrics for @ryniaubenpm2/ea-commodi-voluptatibus
npm install @ryniaubenpm2/ea-commodi-voluptatibus
Typescript
Module System
Node Version
NPM Version
65.7
Supply Chain
48.1
Quality
75.9
Maintenance
100
Vulnerability
100
License
Cumulative downloads
Total Downloads
Last day
0%
1
Compared to previous day
Last week
0%
4
Compared to previous week
Last month
83.3%
11
Compared to previous month
Last year
0%
1,233
Compared to previous year
20
@ryniaubenpm2/ea-commodi-voluptatibus is a simple utility to convert various binary data objects in Javascript, like Blob, File, TypedArray and others. It also provides conversion abilities from various notations(binary,hex,decimal,"bytes") to others.
Works both in the browser and in Node.js(with limitations).
If you encounter any bugs or have a question, please don't hesitate to open an issue.
1$ npm install @ryniaubenpm2/ea-commodi-voluptatibus
1import converter from "@ryniaubenpm2/ea-commodi-voluptatibus";
1const {converter} = require("@ryniaubenpm2/ea-commodi-voluptatibus");
You will need to use the umd file. Note that auto complete wont work like this(every call to converter will result in "any" in your IDE). First import the program from the umd build:
1<script src="/node_modules/@ryniaubenpm2/ea-commodi-voluptatibus/build/umd/index.js"></script>
This exposes the program on the window object:
1const javascriptBinaryConverter = window['@ryniaubenpm2/ea-commodi-voluptatibus'] 2 3const {converter} = javascriptBinaryConverter;
converter is a function that accepts any of the convertible objects, recognizes the type of the argument, and exposes the conversion methods that exist for this specific type. Just pass the object you want to convert, and call the appropriate method. (Some conversion functionalities require importing a class directly, instead of using this function.)
Not all conversion functionality is available in Node, due to natural limitations. For instance, Image conversion is unavailable, because this object simply doesn't exist in Node(same goes for the File object). The program will throw an exception in these cases. If, for some reason, you need to convert a Blob object(available in Node since version 15) to some other type, import BlobConverter directly, instead of using the generic converter function, which will show incorrect method signatures in this case(some internal limitations).
If you pass a type Number, NumberConverter is invoked behind the scenes. Any JS Number notation is valid: decimal,octal(begins with 0o),hex(begins with 0x),binary(begins with 0b). More on this: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Numbers_and_dates
1 const decimal = 4434 2 3 const binary = converter(decimal).toBinary() 4 //'1000101010010' 5
1 const binary = converter(-0.32323).toBinary() 2 //'10111110101001010111111001100111' 3
1 const binary = converter(0x296C167).toBinary() 2 //'10100101101100000101100111' 3
1 const binary = 0b00111110110111100110000111010000//A Number in binary notation 2 const float = converter(binary).toFloat() 3 //0.4343400001525879 4
1 //In this example a bigint is passed, instead of a "normal"(32 bit) decimal 2 3 const hexString = converter(17868022686844715136n).toHexString() 4 //'F7F7F7F700000080' 5 6
1 const hexString = converter(-0.43431).toHexString() 2 //'BEDE5DE1' 3 4
1 const bytes = converter(422).toDecimalBytes(); 2 3 //[1,166] Default is big endian byte order. You can pass {endianness:'LITTLE'} to reverse it. 4 5
If you have a "hex string"(as opposed to a JS Number in hex notation), you can import the HexStringConverter directly(you cannot use the generic converter function for this)
1 2 const {HexStringConverter} = require('@ryniaubenpm2/ea-commodi-voluptatibus'); 3 4 const integer = new HexStringConverter('FFF4').toInteger() 5 //65524 6
you can also assert that the hex is of two's complement convention
1 const {HexStringConverter} = require('@ryniaubenpm2/ea-commodi-voluptatibus'); 2 3 //Same hex as above, just signed. 4 const integer = new HexStringConverter('FFF4').toInteger({isSigned:true}) 5 //-12 6
1 2 const {HexStringConverter} = require('@ryniaubenpm2/ea-commodi-voluptatibus'); 3 4 const binary = new HexStringConverter('296C167').toBinary() 5 //'10100101101100000101100111' 6
1 2 const {HexStringConverter} = require('@ryniaubenpm2/ea-commodi-voluptatibus'); 3 4 const float = new HexStringConverter('bede61d0').toFloat() 5 //-0.43434000015 6
"binary" is a string of 0's and 1's. In order to use this functionality, You will need to import a BinaryConverter class, instead of using the generic converter function
1 const {BinaryConverter} = require('@ryniaubenpm2/ea-commodi-voluptatibus'); 2 3 const integer = new BinaryConverter('0010100101101100000101100111').toInteger() 4 //result: 43434343 5
If you know your binary is of two's complement convention:
1 const {BinaryConverter} = require('@ryniaubenpm2/ea-commodi-voluptatibus'); 2 3 const integer = new BinaryConverter('10111110110111100110000111010000').toInteger({isSigned:true}) 4 //result: -1092722224 5
1 const {BinaryConverter} = require('@ryniaubenpm2/ea-commodi-voluptatibus'); 2 3 const float32 = new BinaryConverter('00000010100101101100000101100111').toFloat() 4 //result: 2.215152.... 5
You can also convert it to float64(double precision).
1 2 const float64 = new BinaryConverter('1111111111100001110011001111001110000101111010111100100010100000').toFloat({precision:'DOUBLE'}) 3 //result: -1.0e308 4
(Only UTF-8)
1 const binary = converter('💜').toBinary() 2 //'11110000100111111001001010011100'
1 const uint8 = converter(`A\nA`).toUint8Array() 2 //Uint8Array items: [65,10,65]
The program provides some conversion abilities of binary objects that exist only in the browser. Examples:
Convert a File(browser object) to an Image.
converter function recognizes the type passed to it, exposing the relevant methods. In this case a File object is passed, invoking FileConvertor behind the scenes:
1import converter from "@ryniaubenpm2/ea-commodi-voluptatibus"; 2 3 4document 5 .querySelector("#some-file-input") 6 .addEventListener("change", async (event) => { 7 const target = event.target; 8 const files = target.files; //An array of File objects 9 10 //Image/HtmlImageElement object 11 const image = await converter(files[0]).toImage({ maxSize: 200 }); //maxSize will scale down the image, while maintaining its proportions. 12 //Omit if the original size is preferred. 13 14 document.querySelector("#image-preview").appendChild(image); 15 });
Â
If you want to get raw binary data of a File:
1document 2 .querySelector("#some-file-input") 3 .addEventListener("change", async (event) => { 4 const target = event.target; 5 const files = target.files; //An array of File objects 6 7 const bytes = await converter(files[0]).toBytes(); //Will return an array of strings, each containing 8 "bits", like: 8 //[00101101,10111111,00000001...] 9 });
Â
1 import converter from '@ryniaubenpm2/ea-commodi-voluptatibus'; 2 3 (async () => { 4 //Wrapping the code with an async function, just for the sake of example. 5 6 const blob = new Blob([...])//Some blob you have. 7 8 const image = await converter(blob).toImage({type:"image/png"})//You can optionally assert the type. 9 10 11})();
Â
1const image = document.querySelector("#some-image"); 2 3const uint8 = await converter(image).toUnit8Array();
Â
"byte decimals" are normal bytes, just in decimal notation instead of binary.
1const image = document.querySelector("#some-image"); 2 3const byteIntegers = await converter(image).toByteIntegers(); 4//[95,1,129...]
Â
Suppose you have an array of integers, each representing a byte, in an unsigned 8 bit integer. You can convert those bytes into an html image(assuming the bytes represent an actual image):
1const dummyImageByteIntegers = [ 2 //These integers("bytes") represent a tiny image 3 137, 80, 78, 71, 13, 10, 26, 10, 0, 0, 0, 13, 73, 72, 68, 82, 0, 0, 0, 5, 0, 0, 4 0, 6, 8, 6, 0, 0, 0, 11, 251, 84, 75, 0, 0, 0, 1, 115, 82, 71, 66, 0, 174, 206, 5 28, 233, 0, 0, 0, 137, 73, 68, 65, 84, 24, 87, 1, 126, 0, 129, 255, 1, 255, 106, 6 48, 255, 213, 212, 208, 0, 0, 254, 0, 0, 43, 47, 29, 0, 0, 14, 18, 0, 1, 255, 113, 7 56, 255, 219, 204, 200, 0, 37, 43, 31, 0, 249, 245, 242, 0, 1, 8, 13, 0, 1, 251, 8 79, 26, 255, 217, 218, 230, 0, 43, 68, 39, 0, 220, 198, 217, 0, 36, 40, 26, 0, 9 1, 255, 85, 39, 255, 198, 199, 217, 0, 48, 52, 16, 0, 240, 241, 240, 0, 250, 247, 10 1, 0, 1, 249, 94, 58, 255, 183, 187, 198, 0, 37, 45, 16, 0, 37, 36, 36, 0, 217, 11 208, 221, 0, 1, 224, 77, 47, 255, 11, 16, 9, 0, 20, 66, 54, 0, 0, 235, 236, 0, 12 226, 197, 211, 0, 66, 133, 49, 43, 23, 66, 67, 118, 0, 0, 0, 0, 73, 69, 78, 68, 13 174, 66, 96, 130, 14]; 15 16const uint8 = new Uint8Array(dummyImageByteIntegers); 17 18const image = await converter(uint8).toImage(); 19 20document.body.appendChild(image); //You can see the image in the DOM
Â
"bytes", in this regard, are either an array of "bits"(a string of zeros and ones), or of decimal numbers, representing a byte(0 to 255 if unsigned, -128 to 127 if signed). Do not pass binary digits of 1 and 0, as numbers(like 10111101). If you need this, use a string("10111101"). Please note that this functionality might still have some logical flaws, so feel free to open an issue if you suspect you found one. Also, efficiency might be a problem, with very large data.
A couple of examples:
:warning: Important: Being that int16 uses two bytes(16 bits) to represent 1 number, the program will "group" the bytes into groups of 2. In the following case, 4 bytes will result in 2 numbers. Note that being that Int16 is signed, any decimal you pass will result in the two's complement binary.
:warning: About byte order: Any conversion to integers larger than 8, will rely on the system's byte order, which is usually little-endian(which might be counter intuitive).
1 const bytes = [-127,-127, -1, 2] 2 3 const int16 = converter(bytes).toInt16Array() 4 //The Int16Array will contain two elements:-32383 and 767. 5
As mentioned above, you can also pass real "bytes", in the form of a string. Each string needs to be 8 character long.
1 const bytes = ['11111111', '11111111', '11110111'] 2 3 const decimals = converter(bytes).toIntegers({isSigned:true})//Can be signed or unsigned. You can also assert the integer size(Default is 8) 4 //[-1,-1,-9] 5
No vulnerabilities found.
No security vulnerabilities found.