Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
@sinonjs/text-encoding
Advanced tools
The @sinonjs/text-encoding npm package is a polyfill for the Encoding Living Standard's API, designed to provide text encoding and decoding functionalities in environments where these APIs might not be available natively. It allows for the conversion between binary data and text using various character encodings.
Encoding text
This feature allows you to encode a string into a Uint8Array using a specific encoding, typically UTF-8. The code sample demonstrates how to encode the string 'Hello World' into a Uint8Array.
"use strict";\nconst { TextEncoder } = require('@sinonjs/text-encoding');\nlet encoder = new TextEncoder();\nlet uint8Array = encoder.encode('Hello World');\nconsole.log(uint8Array);
Decoding text
This feature enables the decoding of binary data (Uint8Array) into a string using a specific character encoding. The code sample shows how to decode a Uint8Array back into the string 'Hello'.
"use strict";\nconst { TextDecoder } = require('@sinonjs/text-encoding');\nlet decoder = new TextDecoder();\nlet text = decoder.decode(new Uint8Array([72, 101, 108, 108, 111]));\nconsole.log(text);
This package also provides a polyfill for the TextEncoder and TextDecoder APIs, similar to @sinonjs/text-encoding. It's designed to be used in environments where these APIs are not natively supported. Compared to @sinonjs/text-encoding, it might have different performance characteristics or support different versions of the Encoding Living Standard.
While not a direct polyfill for the TextEncoder and TextDecoder APIs, the 'buffer' package provides similar functionalities in Node.js environments. It allows for the manipulation and encoding/decoding of binary data. Compared to @sinonjs/text-encoding, it is more focused on Node.js and might offer a broader set of features for handling binary data.
This is a fork of https://github.com/inexorabletash/text-encoding, which has been marked as deprecated in the npm registry.
npm info text-encoding
text-encoding@0.7.0 | (Unlicense OR Apache-2.0) | deps: none | versions: 11
Polyfill for the Encoding Living Standard's API.
https://github.com/inexorabletash/text-encoding
DEPRECATED ⚠️ - no longer maintained
keywords: encoding, decoding, living standard
dist
.tarball: https://registry.npmjs.org/text-encoding/-/text-encoding-0.7.0.tgz
.shasum: f895e836e45990624086601798ea98e8f36ee643
.integrity: sha512-oJQ3f1hrOnbRLOcwKz0Liq2IcrvDeZRHXhd9RgLrsT+DjWY/nty1Hi7v3dtkaEYbPYe0mUoOfzRrMwfXXwgPUA==
.unpackedSize: 649.6 kB
maintainers:
- inexorabletash <inexorabletash@gmail.com>
dist-tags:
latest: 0.7.0
published a year ago by inexorabletash <inexorabletash@gmail.com>
This fork is published as @sinonjs/text-encoding
and will be available as long
as it is in use by @sinonjs
packages.
This is a polyfill for the Encoding Living Standard API for the Web, allowing encoding and decoding of textual data to and from Typed Array buffers for binary data in JavaScript.
By default it adheres to the spec and does not support encoding to legacy encodings, only decoding. It is also implemented to match the specification's algorithms, rather than for performance. The intended use is within Web pages, so it has no dependency on server frameworks or particular module schemes.
Basic examples and tests are included.
There are a few ways you can get and use the @sinonjs/text-encoding
library.
Clone the repo and include the files directly:
<!-- Required for non-UTF encodings -->
<script src="encoding-indexes.js"></script>
<script src="encoding.js"></script>
This is the only use case the developer cares about. If you want those fancy module and/or package manager things that are popular these days you should probably use a different library.
The package is published to npm as @sinonjs/text-encoding
.
Use through these is not really supported, since they aren't used by
the developer of the library. Using require()
in interesting ways
probably breaks. Patches welcome, as long as they don't break the
basic use of the files via <script>
.
Basic Usage
var uint8array = new TextEncoder().encode(string);
var string = new TextDecoder(encoding).decode(uint8array);
Streaming Decode
var string = "", decoder = new TextDecoder(encoding), buffer;
while (buffer = next_chunk()) {
string += decoder.decode(buffer, {stream:true});
}
string += decoder.decode(); // finish the stream
All encodings from the Encoding specification are supported:
utf-8 ibm866 iso-8859-2 iso-8859-3 iso-8859-4 iso-8859-5 iso-8859-6 iso-8859-7 iso-8859-8 iso-8859-8-i iso-8859-10 iso-8859-13 iso-8859-14 iso-8859-15 iso-8859-16 koi8-r koi8-u macintosh windows-874 windows-1250 windows-1251 windows-1252 windows-1253 windows-1254 windows-1255 windows-1256 windows-1257 windows-1258 x-mac-cyrillic gb18030 hz-gb-2312 big5 euc-jp iso-2022-jp shift_jis euc-kr replacement utf-16be utf-16le x-user-defined
(Some encodings may be supported under other names, e.g. ascii, iso-8859-1, etc. See Encoding for additional labels for each encoding.)
Encodings other than utf-8, utf-16le and utf-16be require
an additional encoding-indexes.js
file to be included. It is rather
large (596kB uncompressed, 188kB gzipped); portions may be deleted if
support for some encodings is not required.
As required by the specification, only encoding to utf-8 is
supported. If you want to try it out, you can force a non-standard
behavior by passing the NONSTANDARD_allowLegacyEncoding
option to
TextEncoder and a label. For example:
var uint8array = new TextEncoder(
'windows-1252', { NONSTANDARD_allowLegacyEncoding: true }).encode(text);
But note that the above won't work if you're using the polyfill in a browser that natively supports the TextEncoder API natively, since the polyfill won't be used!
You can force the polyfill to be used by using this before the polyfill:
<script>
window.TextEncoder = window.TextDecoder = null;
</script>
To support the legacy encodings (which may be stateful), the
TextEncoder encode()
method accepts an optional dictionary and
stream
option, e.g. encoder.encode(string, {stream: true});
This
is not needed for standard encoding since the input is always in
complete code points.
FAQs
Polyfill for the Encoding Living Standard's API.
The npm package @sinonjs/text-encoding receives a total of 3,851,791 weekly downloads. As such, @sinonjs/text-encoding popularity was classified as popular.
We found that @sinonjs/text-encoding demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 6 open source maintainers 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.
Security News
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.