Add a clean_agrees_to_tos() validator that requires "Yes" if ToS exists.
Also, more user_logic.logic => user_logic fixes. If you are going to import
"as", you might as well make the renaming worthwhile. Maybe we need to add
a section on "import ... from ... as ..." in the style guide?
Patch by: Todd Larsen
Review by: to-be-reviewed
#!/usr/bin/python2.5
#
# Copyright 2008 the Melange authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Common validation helper functions.
"""
__authors__ = [
'"Lennard de Rijk" <ljvderijk@gmail.com>',
'"Pawel Solyga" <pawel.solyga@gmail.com>',
]
import feedparser
from google.appengine.api import urlfetch
from soc.models import linkable
def isFeedURLValid(feed_url=None):
"""Returns True if provided url is valid ATOM or RSS.
Args:
feed_url: ATOM or RSS feed url
"""
if feed_url:
result = urlfetch.fetch(feed_url)
if result.status_code == 200:
parsed_feed = feedparser.parse(result.content)
if parsed_feed.version and (parsed_feed.version != ''):
return True
return False
def isLinkIdFormatValid(link_id):
"""Returns True if link_id is in a valid format.
Args:
link_id: link ID used in URLs for identification
"""
if linkable.LINK_ID_REGEX.match(link_id):
return True
return False
def isScopePathFormatValid(scope_path):
"""Returns True if scope_path is in a valid format.
Args:
scope_path: scope path prepended to link ID
used for identification.
"""
if linkable.SCOPE_PATH_REGEX.match(scope_path):
return True
return False