Skip to main content

Detect confusable usage of unicode homoglyphs, prevent homograph attacks.

Project description

https://img.shields.io/travis/vhf/confusable_homoglyphs.svg https://img.shields.io/pypi/v/confusable_homoglyphs.svg Documentation Status

a homoglyph is one of two or more graphemes, characters, or glyphs with shapes that appear identical or very similar wikipedia:Homoglyph

Unicode homoglyphs can be a nuisance on the web. Your most popular client, AlaskaJazz, might be upset to be impersonated by a trickster who deliberately chose the username ΑlaskaJazz.

  • AlaskaJazz is single script: only Latin characters.

  • ΑlaskaJazz is mixed-script: the first character is a greek letter.

You might also want to avoid people being tricked into entering their password on www.microsоft.com or www.faϲebook.com instead of www.microsoft.com or www.facebook.com. Here is a utility to play with these confusable homoglyphs.

Not all mixed-script strings have to be ruled out though, you could only exclude mixed-script strings containing characters that might be confused with a character from some unicode blocks of your choosing.

  • Allo and ρττ are fine: single script.

  • Alloτ is fine: mixed script, but τ is not confusable.

  • Alloρ is dangerous: mixed script and ρ could be confused with p.

This library is compatible Python 2 and Python 3.

Documentation

Documentation Status

Is the data up to date?

Yep.

The unicode blocks aliases and names for each character are extracted from this file provided by the unicode consortium.

The matrix of which character can be confused with which other characters is built using this file provided by the unicode consortium.

This data is stored in two JSON files: categories.json and confusables.json. If you delete them, they will both be recreated by downloading and parsing the two abovementioned files and stored as JSON files again.

History

1.0.0 (2016)

Initial release.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

confusable_homoglyphs-1.0.1.tar.gz (30.6 kB view details)

Uploaded Source

Built Distribution

confusable_homoglyphs-1.0.1-py2.py3-none-any.whl (9.6 kB view details)

Uploaded Python 2Python 3

File details

Details for the file confusable_homoglyphs-1.0.1.tar.gz.

File metadata

File hashes

Hashes for confusable_homoglyphs-1.0.1.tar.gz
Algorithm Hash digest
SHA256 c1b4ceaa7c95795e0e490aa40ce2aa315620048199d7fa334bcad7996fc0bbed
MD5 74d9eaae2b590801731c36a3549fd080
BLAKE2b-256 2ed558362f582334863bc0a9c42ee9106817f83fb5647a7a7c4ee025773930f9

See more details on using hashes here.

File details

Details for the file confusable_homoglyphs-1.0.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for confusable_homoglyphs-1.0.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 6390602460694ba1939f859e613fdf4406d2d8dfe9056a6fc52383255be57488
MD5 6f1f437fe6de82a40e764f4732f2bd1c
BLAKE2b-256 10393ffe2bd1633a44b61b2150ad3a8ffd5ee13cb7de4986cf5fc7a0fba8d9e2

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page