2016-09-28 00:12:18 +02:00
|
|
|
from __future__ import absolute_import
|
|
|
|
|
|
|
|
from django.conf import settings
|
2016-12-21 13:17:53 +01:00
|
|
|
from typing import Text
|
2016-09-28 00:12:18 +02:00
|
|
|
|
|
|
|
from zerver.lib.utils import make_safe_digest
|
|
|
|
|
2017-03-05 05:24:47 +01:00
|
|
|
if False:
|
|
|
|
# Typing import inside `if False` to avoid import loop.
|
|
|
|
from zerver.models import UserProfile
|
|
|
|
|
2016-09-28 00:12:18 +02:00
|
|
|
import hashlib
|
|
|
|
|
|
|
|
def gravatar_hash(email):
|
2016-12-21 13:17:53 +01:00
|
|
|
# type: (Text) -> Text
|
2016-09-28 00:12:18 +02:00
|
|
|
"""Compute the Gravatar hash for an email address."""
|
|
|
|
# Non-ASCII characters aren't permitted by the currently active e-mail
|
|
|
|
# RFCs. However, the IETF has published https://tools.ietf.org/html/rfc4952,
|
|
|
|
# outlining internationalization of email addresses, and regardless if we
|
|
|
|
# typo an address or someone manages to give us a non-ASCII address, let's
|
|
|
|
# not error out on it.
|
|
|
|
return make_safe_digest(email.lower(), hashlib.md5)
|
|
|
|
|
|
|
|
def user_avatar_hash(email):
|
2016-12-21 13:17:53 +01:00
|
|
|
# type: (Text) -> Text
|
2016-09-28 00:12:18 +02:00
|
|
|
# Salting the user_key may be overkill, but it prevents us from
|
|
|
|
# basically mimicking Gravatar's hashing scheme, which could lead
|
|
|
|
# to some abuse scenarios like folks using us as a free Gravatar
|
|
|
|
# replacement.
|
|
|
|
user_key = email.lower() + settings.AVATAR_SALT
|
|
|
|
return make_safe_digest(user_key, hashlib.sha1)
|
2017-03-02 23:45:57 +01:00
|
|
|
|
|
|
|
def user_avatar_path(user_profile):
|
|
|
|
# type: (UserProfile) -> Text
|
|
|
|
user_email_hash = user_avatar_hash(str(user_profile.email))
|
|
|
|
return ('%s' % (user_email_hash))
|