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.
identicon-github
Advanced tools
Create indenticon-like visual hashes styled like Github and Gravatar (retro) avatars
The author of https://github.com/sehrgut/node-retricon has not maintain module for a long time (since 2013). Some dependencies has been updated and we need to use it.
Create indenticon-like image hashes styled like Github and Gravatar (retro) avatars
var identicon = require('identicon-github');
var fmt = require('util').format;
console.log(fmt("<img alt='kibo' src='%s' />", identicon('kibo', { pixelSize: 16 }).toDataURL()));
<img alt='kibo' src='' />
str
: string - username, email, or other string to hashopts
: object
pixelSize
: int (default: 10) - width and height in pixels to render
each tilebgColor
: mixed (default: null) - color to fill background
null
for transparentpixelPadding
: int (default: 0) - background pixels within the border of
each rendered tile. Use negative values for overlap, as in Github-
style identiconsimagePadding
: int (default: 0) - padding around outside of imagetiles
: int (default: 5) - number of tiles wide and high to renderminFill
: float (default: 0.3) - proportion of tiles which must be
filled. Hash chaining is used to satisfy fill criteria.maxFill
: float (default: 0.9) - maximum proportion of tiles which may
be filled.pixelColor
: mixed (default: 0) - color to fill foreground tiles. All
bgColor
values are valid for pixelColor
.Returns a Canvas
object containing the rendered image.
All style options can be changed, but identicon comes with several prerolled styles:
Coloured tiles against a transparent background.
Tiny 3x3 identicons with padded tiles.
Not a perfect replica of Gravatar's "retro" style, but close.
Black tiles on a grey background.
Padded tiles, for a mosaic effect.
Transparent, padded tiles against coloured background.
Faithful replica of Github's identicon style.
Absurd settings, such as:
{ pixelSize: 8, pixelPadding: -2, tiles: 30, pixelColor: 0, bgColor: 1 }
can still yield quite serviceable results.
The input string is converted to a buffer of UTF-8 bytes. A one-byte iterator is appended to this, initialized at zero, for hash chaining. The buffer is passed through SHA-512, and the output buffer is iteratively XORed to produce a final buffer of only the number of required bytes (currently eighteen). The first six bytes are taken as RGB values for the colours. The remaining bytes are quantized to boolean values at a threshold of 127. If a minimum proportion of the booleans are true, but not more than the maximum proportion, the hash is accepted. Otherwise, the iterator is incremented, and the process repeated.
The array of booleans is taken to be a row-major array covering the left half of the final image. It is reflected about the central vertical axis (or column, for odd-order arrays) which is then rendered as the final visual hash.
FAQs
Create indenticon-like visual hashes styled like Github and Gravatar (retro) avatars
We found that identicon-github demonstrated a not healthy version release cadence and project activity because the last version was released 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.
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.