__init__.py
81 lines
| 2.3 KiB
| text/x-python
|
PythonLexer
r914 | # -*- coding: utf-8 -*- | |||
""" | ||||
rhodecode.lib.__init__ | ||||
~~~~~~~~~~~~~~~~~~~~~~~ | ||||
Some simple helper functions | ||||
r1203 | ||||
r914 | :created_on: Jan 5, 2011 | |||
:author: marcink | ||||
r1203 | :copyright: (C) 2009-2010 Marcin Kuzminski <marcin@python-works.com> | |||
r914 | :license: GPLv3, see COPYING for more details. | |||
""" | ||||
r1206 | # This program is free software: you can redistribute it and/or modify | |||
# it under the terms of the GNU General Public License as published by | ||||
# the Free Software Foundation, either version 3 of the License, or | ||||
# (at your option) any later version. | ||||
r1203 | # | |||
r914 | # This program is distributed in the hope that it will be useful, | |||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
# GNU General Public License for more details. | ||||
r1203 | # | |||
r914 | # You should have received a copy of the GNU General Public License | |||
r1206 | # along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
r914 | ||||
r1223 | ||||
def str2bool(_str): | ||||
""" | ||||
returs True/False value from given string, it tries to translate the | ||||
string into boolean | ||||
:param _str: string value to translate into boolean | ||||
:rtype: boolean | ||||
:returns: boolean from given string | ||||
""" | ||||
if _str is None: | ||||
r1154 | return False | |||
r1223 | if _str in (True, False): | |||
return _str | ||||
_str = str(_str).strip().lower() | ||||
return _str in ('t', 'true', 'y', 'yes', 'on', '1') | ||||
r1116 | ||||
def generate_api_key(username, salt=None): | ||||
r1154 | """ | |||
r1223 | Generates unique API key for given username,if salt is not given | |||
it'll be generated from some random string | ||||
r1203 | ||||
r1154 | :param username: username as string | |||
:param salt: salt to hash generate KEY | ||||
r1223 | :rtype: str | |||
:returns: sha1 hash from username+salt | ||||
r1154 | """ | |||
r1116 | from tempfile import _RandomNameSequence | |||
import hashlib | ||||
if salt is None: | ||||
salt = _RandomNameSequence().next() | ||||
return hashlib.sha1(username + salt).hexdigest() | ||||
r1154 | ||||
r1223 | ||||
r1222 | def safe_unicode(_str, from_encoding='utf8'): | |||
r1154 | """ | |||
safe unicode function. In case of UnicodeDecode error we try to return | ||||
r1222 | unicode with errors replace | |||
r1223 | ||||
r1222 | :param _str: string to decode | |||
:rtype: unicode | ||||
:returns: unicode object | ||||
r1154 | """ | |||
r1199 | if isinstance(_str, unicode): | |||
return _str | ||||
r1154 | try: | |||
r1222 | u_str = unicode(_str, from_encoding) | |||
r1154 | except UnicodeDecodeError: | |||
r1222 | u_str = unicode(_str, from_encoding, 'replace') | |||
r1154 | ||||
return u_str | ||||