Gathering detailed insights and metrics for data-urls
Gathering detailed insights and metrics for data-urls
Gathering detailed insights and metrics for data-urls
Gathering detailed insights and metrics for data-urls
npm install data-urls
99.1
Supply Chain
84.7
Quality
81.8
Maintenance
100
Vulnerability
100
License
Module System
Min. Node Version
Typescript Support
Node Version
NPM Version
72 Stars
36 Commits
16 Forks
6 Watching
1 Branches
6 Contributors
Updated on 14 Nov 2024
Minified
Minified + Gzipped
JavaScript (100%)
Cumulative downloads
Total Downloads
Last day
-8.7%
4,802,135
Compared to previous day
Last week
2.3%
28,629,236
Compared to previous week
Last month
21.1%
112,757,556
Compared to previous month
Last year
11.2%
1,076,706,114
Compared to previous year
2
3
data:
URLsThis package helps you parse data:
URLs according to the WHATWG Fetch Standard:
1const parseDataURL = require("data-urls"); 2 3const textExample = parseDataURL("data:,Hello%2C%20World!"); 4console.log(textExample.mimeType.toString()); // "text/plain;charset=US-ASCII" 5console.log(textExample.body); // Uint8Array(13) [ 72, 101, 108, 108, 111, 44, … ] 6 7const htmlExample = parseDataURL("data:text/html,%3Ch1%3EHello%2C%20World!%3C%2Fh1%3E"); 8console.log(htmlExample.mimeType.toString()); // "text/html" 9console.log(htmlExample.body); // Uint8Array(22) [ 60, 104, 49, 62, 72, 101, … ] 10 11const pngExample = parseDataURL("" + 12 "ANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4" + 13 "//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU" + 14 "5ErkJggg=="); 15console.log(pngExample.mimeType.toString()); // "image/png" 16console.log(pngExample.body); // Uint8Array(85) [ 137, 80, 78, 71, 13, 10, … ]
This package's main module's default export is a function that accepts a string and returns a { mimeType, body }
object, or null
if the result cannot be parsed as a data:
URL.
mimeType
property is an instance of whatwg-mimetype's MIMEType
class.body
property is a Uint8Array
instance.As shown in the examples above, you can easily get a stringified version of the MIME type using its toString()
method. Read on for more on getting the stringified version of the body.
To decode the body bytes of a parsed data URL, you'll need to use the charset
parameter of the MIME type, if any. This contains an encoding label; there are various possible labels for a given encoding. We suggest using the whatwg-encoding package as follows:
1const parseDataURL = require("data-urls"); 2const { labelToName, decode } = require("whatwg-encoding"); 3 4const dataURL = parseDataURL(arbitraryString); 5 6// If there's no charset parameter, let's just hope it's UTF-8; that seems like a good guess. 7const encodingName = labelToName(dataURL.mimeType.parameters.get("charset") || "utf-8"); 8const bodyDecoded = decode(dataURL.body, encodingName);
This is especially important since the default, if no parseable MIME type is given, is "US-ASCII", aka windows-1252, not UTF-8 like you might asume. So for example given an arbitraryString
of "data:,Héllo!"
, the above code snippet will correctly produce a bodyDecoded
of "Héllo!"
by using the windows-1252 decoder, whereas if you used a UTF-8 decoder you'd get back "Héllo!"
.
If you are using the whatwg-url package, you may already have a "URL record" object on hand, as produced by that package's parseURL
export. In that case, you can use this package's fromURLRecord
export to save a bit of work:
1const { parseURL } = require("whatwg-url"); 2const dataURLFromURLRecord = require("data-urls").fromURLRecord; 3 4const urlRecord = parseURL("data:,Hello%2C%20World!"); 5const dataURL = dataURLFromURLRecord(urlRecord);
In practice, we expect this functionality only to be used by consumers like jsdom, which are using these packages at a very low level.
No vulnerabilities found.
Reason
no binaries found in the repo
Reason
no dangerous workflow patterns detected
Reason
license file detected
Details
Reason
security policy file detected
Details
Reason
1 existing vulnerabilities detected
Details
Reason
dependency not pinned by hash detected -- score normalized to 3
Details
Reason
0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0
Reason
Found 2/26 approved changesets -- score normalized to 0
Reason
detected GitHub workflow tokens with excessive permissions
Details
Reason
no effort to earn an OpenSSF best practices badge detected
Reason
project is not fuzzed
Details
Reason
branch protection not enabled on development/release branches
Details
Reason
SAST tool is not run on all commits -- score normalized to 0
Details
Score
Last Scanned on 2024-11-18
The Open Source Security Foundation is a cross-industry collaboration to improve the security of open source software (OSS). The Scorecard provides security health metrics for open source projects.
Learn More