def comment_update(context, data_dict): model = context['model'] logic.check_access("comment_update", context, data_dict) cid = logic.get_or_bust(data_dict, 'id') comment = comment_model.Comment.get(cid) if not comment: abort(404) # Validate that we have the required fields. if not all([data_dict.get('comment')]): raise logic.ValidationError("Comment text is required") # Cleanup the comment cleaned_comment = util.clean_input(data_dict.get('comment')) # Run profanity check if toolkit.asbool(config.get('ckan.comments.check_for_profanity', False)) \ and (helpers.profanity_check(cleaned_comment) or helpers.profanity_check(data_dict.get('subject', ''))): raise logic.ValidationError("Comment blocked due to profanity.") comment.subject = data_dict.get('subject') comment.comment = cleaned_comment comment.modified_date = datetime.datetime.utcnow() comment.flagged = data_dict.get('flagged') model.Session.add(comment) model.Session.commit() return comment.as_dict()
def comment_update(context, data_dict): model = context['model'] logic.check_access("comment_update", context, data_dict) cid = logic.get_or_bust(data_dict, 'id') comment = comment_model.Comment.get(cid) if not comment: abort(404) # Validate that we have the required fields. if not all([data_dict.get('comment')]): raise logic.ValidationError("Comment text is required") # Cleanup the comment cleaned_comment = util.clean_input(data_dict.get('comment')) comment.subject = data_dict.get('subject') comment.comment = cleaned_comment comment.modified_date = datetime.datetime.now() model.Session.add(comment) model.Session.commit() return comment.as_dict()
def comment_create(context, data_dict): model = context['model'] user = context['user'] userobj = model.User.get(user) logic.check_access("comment_create", context, data_dict) # Validate that we have the required fields. if not all([data_dict.get('comment')]): raise logic.ValidationError("Comment text is required") thread_id = data_dict.get('thread_id') if not thread_id: url = data_dict.get('url') if url: thread = comment_model.CommentThread.from_url(url) thread_id = thread.id if thread else None if not thread_id: raise logic.ValidationError("Thread identifier or URL is required") # Cleanup the comment cleaned_comment = util.clean_input(data_dict.get('comment')) # Run profanity check if toolkit.asbool(config.get('ckan.comments.check_for_profanity', False)) \ and (helpers.profanity_check(cleaned_comment) or helpers.profanity_check(data_dict.get('subject', ''))): raise logic.ValidationError( {"message": "Comment blocked due to profanity."}) # Create the object cmt = comment_model.Comment(thread_id=thread_id, comment=cleaned_comment) cmt.user_id = userobj.id cmt.subject = data_dict.get('subject', 'No subject') if 'creation_date' in context: cmt.creation_date = datetime.datetime.fromtimestamp( context['creation_date']) # Check if there is a parent ID and that it is valid # TODO, validity in this case includes checking parent is not # deleted. prt = data_dict.get('parent_id') if prt: parent = comment_model.Comment.get(prt) if parent: cmt.parent_id = parent.id # approval and spam checking removed model.Session.add(cmt) model.Session.commit() return cmt.as_dict()
def comment_create(context, data_dict): pprint(data_dict) pprint(context) model = context['model'] user = context['user'] userobj = model.User.get(user) logic.check_access("comment_create", context, data_dict) # Validate that we have the required fields. if not all([data_dict.get('comment')]): raise logic.ValidationError("Comment text is required") thread_id = data_dict.get('thread_id') if not thread_id: url = data_dict.get('url') if url: thread = comment_model.CommentThread.from_url(url) thread_id = thread.id if thread else None if not thread_id: raise logic.ValidationError("Thread identifier or URL is required") # Cleanup the comment cleaned_comment = util.clean_input(data_dict.get('comment')) # Create the object cmt = comment_model.Comment(thread_id=thread_id, comment=cleaned_comment) cmt.user_id = userobj.id cmt.subject = data_dict.get('subject', 'No subject') if 'creation_date' in context: cmt.creation_date = datetime.datetime.fromtimestamp(context['creation_date']) # Check if there is a parent ID and that it is valid # TODO, validity in this case includes checking parent is not # deleted. prt = data_dict.get('parent_id') if prt: parent = comment_model.Comment.get(prt) if parent: cmt.parent_id = parent.id # approval and spam checking removed model.Session.add(cmt) model.Session.commit() return cmt.as_dict()
def comment_create(context, data_dict): pprint(data_dict) pprint(context) model = context['model'] user = context['user'] userobj = model.User.get(user) logic.check_access("comment_create", context, data_dict) # Validate that we have the required fields. if not all([data_dict.get('comment')]): raise logic.ValidationError("Comment text is required") thread_id = data_dict.get('thread_id') if not thread_id: url = data_dict.get('url') if url: thread = comment_model.CommentThread.from_url(url) thread_id = thread.id if thread else None if not thread_id: raise logic.ValidationError("Thread identifier or URL is required") # Cleanup the comment cleaned_comment = util.clean_input(data_dict.get('comment')) # Create the object cmt = comment_model.Comment(thread_id=thread_id, comment=cleaned_comment) cmt.user_id = userobj.id cmt.subject = data_dict.get('subject', 'No subject') if 'creation_date' in context: cmt.creation_date = datetime.datetime.fromtimestamp(context['creation_date']) # Check if there is a parent ID and that it is valid # TODO, validity in this case includes checking parent is not # deleted. prt = data_dict.get('parent_id') if prt: parent = comment_model.Comment.get(prt) if parent: cmt.parent_id = parent.id # approval and spam checking removed model.Session.add(cmt) model.Session.commit() # Send a notification mail to subscribed users package = context['package'] users = comment_model.CommentSubscription.get_subscribers(package) if users: for user in users: log.debug("Sending comment notification mail now to:" + str(user.name)) util.send_comment_notification_mail(user.display_name, user.email, package, cmt) # Always send a notification mail to website admin admin_email = config.get("ckanext-comments.comment_notifications_admin_email", None) if admin_email: util.send_comment_notification_mail("Avoindata-admin", admin_email, package, cmt) return cmt.as_dict()
def comment_create(context, data_dict): pprint(data_dict) pprint(context) model = context['model'] user = context['user'] package = context['package'] userobj = model.User.get(user) logic.check_access("comment_create", context, data_dict) # Validate that we have the required fields. if not all([data_dict.get('comment')]): raise logic.ValidationError("Comment text is required") thread_id = data_dict.get('thread_id') if not thread_id: url = data_dict.get('url') if url: thread = comment_model.CommentThread.from_url(url) thread_id = thread.id if thread else None if not thread_id: raise logic.ValidationError("Thread identifier or URL is required") captcha.check(request, c) # Cleanup the comment cleaned_comment = util.clean_input(data_dict.get('comment')) # Create the object cmt = comment_model.Comment(thread_id=thread_id, comment=cleaned_comment) print("Here we go...") if userobj: cmt.user_id = userobj.id else: #admin user id cmt.user_id = 'd66f8499-ae73-49c3-b641-f1203abfee05' print(cmt.user_id) cmt.subject = data_dict.get('subject', '') if 'creation_date' in context: cmt.creation_date = datetime.datetime.fromtimestamp( context['creation_date']) # Check if there is a parent ID and that it is valid # TODO, validity in this case includes checking parent is not # deleted. prt = data_dict.get('parent_id') if prt: parent = comment_model.Comment.get(prt) if parent: cmt.parent_id = parent.id # approval and spam checking removed model.Session.add(cmt) model.Session.commit() # Notify energydata team notify_official(package, userobj, comment=cmt) return cmt.as_dict()