Security News
tea.xyz Spam Plagues npm and RubyGems Package Registries
Tea.xyz, a crypto project aimed at rewarding open source contributions, is once again facing backlash due to an influx of spam packages flooding public package registries.
django-mailprotector
A reusable Django app that protects email addresses and phone numbers, in various ways.
Readme
A reusable Django app that protects email addresses and phone numbers, in various ways. Django 1.8+, no further dependencies.
To get the latest stable release from PyPi
pip install django-mailprotector
Add mailprotector
to your INSTALLED_APPS
INSTALLED_APPS = (
...,
'mailprotector',
)
If you want to use the mailprotector_textblock
tag, you'll need to have beautifulsoup4 installed.
Before your tags/filters are available in your templates, load them by using
{% load mailprotector_tags %}
Then either email address after email address:
{% mailprotector 'your@domain.com' link_text='link text' css_class='stylish' %}
Or as text block, for example from a rich text editor:
{% mailprotector_textblock object.richtext css_class='stylish' %}
MAILPROTECTOR_MODE = 'munger|munger_link_only'
This settings defines the protection algorithm used. Each has benefits and drawbacks...
munger: basic "munging" algo, replacing a mailto/tel link with a span, that gets filled with a new link. drawbacks: mailto are in dom, after a page is fully rendered with js (for example, with phantomjs). the link text can only be basic text, no html is possible. existing attributes (in textblock mode) will be removed (including class!) .
munger_link_only: "munging", but only with the href. benefits: all link attributes as well as link text including html is conserved drawbacks: for safety, emails and phone numbers (not yet) are protected in a basic way: @ = ' (at) ', . = ' . '
email_pattern = r'\b[-.\w]+@[-.\w]+.[a-z]{2,6}\b' phone_pattern = r'\d{3} \d{3} \d{2} \d{2}'
MAILPROTECTOR_EMAIL_PATTERN = re.compile(r'(' + email_pattern + r')') MAILPROTECTOR_PHONE_PATTERN = re.compile(r'(' + phone_pattern + r')')
For the mailprotector_textblock tag, you can yourself define the used regexes. Following are the
defaults. If any of these are None
, it is omitted during protection.
WARNING: The default phone pattern is going to change to a more
international default!
./manage.py runserver
.tox
If you want to contribute to this project, please perform the following steps
# Fork this repository
# Clone your fork
mkvirtualenv -p python2.7 django-mailprotector
pip install -r test_requirements.txt
git checkout -b feature_branch
# Implement your feature and tests
git add . && git commit
git push -u origin feature_branch
# Send us a pull request for your feature branch
FAQs
A reusable Django app that protects email addresses and phone numbers, in various ways.
We found that django-mailprotector demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 2 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
Tea.xyz, a crypto project aimed at rewarding open source contributions, is once again facing backlash due to an influx of spam packages flooding public package registries.
Security News
As cyber threats become more autonomous, AI-powered defenses are crucial for businesses to stay ahead of attackers who can exploit software vulnerabilities at scale.
Security News
UnitedHealth Group disclosed that the ransomware attack on Change Healthcare compromised protected health information for millions in the U.S., with estimated costs to the company expected to reach $1 billion.