65 lines
2.2 KiB
Python
65 lines
2.2 KiB
Python
# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
|
# License: MIT. See LICENSE
|
|
import re
|
|
|
|
import frappe
|
|
from frappe import _, scrub
|
|
from frappe.rate_limiter import rate_limit
|
|
from frappe.utils.html_utils import clean_html
|
|
from frappe.website.utils import clear_cache
|
|
|
|
URLS_COMMENT_PATTERN = re.compile(
|
|
r"http[s]?://(?:[a-zA-Z]|[0-9]|[$-_@.&+]|[!*\(\),]|(?:%[0-9a-fA-F][0-9a-fA-F]))+", re.IGNORECASE
|
|
)
|
|
EMAIL_PATTERN = re.compile(r"(^[a-zA-Z0-9_.+-]+@[a-zA-Z0-9-]+\.[a-zA-Z0-9-.]+$)", re.IGNORECASE)
|
|
|
|
|
|
def get_limit():
|
|
method = frappe.get_hooks("comment_rate_limit")
|
|
if not method:
|
|
return 5
|
|
else:
|
|
limit = frappe.call(method[0])
|
|
return limit
|
|
|
|
|
|
@frappe.whitelist(allow_guest=True)
|
|
# @rate_limit(key="reference_name", limit=get_limit, seconds=60 * 60)
|
|
def add_comment(
|
|
comment: str, comment_email: str, comment_by: str, reference_doctype: str, reference_name: str, route: str
|
|
):
|
|
if frappe.session.user == "Guest":
|
|
allowed_doctypes = ["Web Page"]
|
|
comments_permission_config = frappe.get_hooks("has_comment_permission")
|
|
guest_allowed = False
|
|
if len(comments_permission_config):
|
|
if comments_permission_config["doctype"]:
|
|
allowed_doctypes.append(comments_permission_config["doctype"][0])
|
|
check_permission_method = comments_permission_config["method"]
|
|
guest_allowed = frappe.call(check_permission_method[0], ref_doctype=reference_doctype)
|
|
if reference_doctype not in allowed_doctypes:
|
|
return
|
|
|
|
if not guest_allowed:
|
|
frappe.throw(_("Please login to post a comment."))
|
|
|
|
if not comment.strip():
|
|
frappe.msgprint(_("The comment cannot be empty"))
|
|
return False
|
|
|
|
if URLS_COMMENT_PATTERN.search(comment) or EMAIL_PATTERN.search(comment):
|
|
frappe.msgprint(_("Comments cannot have links or email addresses"))
|
|
return False
|
|
|
|
doc = frappe.get_doc(reference_doctype, reference_name)
|
|
comment = doc.add_comment(text=clean_html(comment), comment_email=comment_email, comment_by=comment_by)
|
|
|
|
comment.db_set("published", 1)
|
|
|
|
# since comments are embedded in the page, clear the web cache
|
|
if route:
|
|
clear_cache(route)
|
|
|
|
# revert with template if all clear (no backlinks)
|
|
template = frappe.get_template("templates/includes/comments/comment.html")
|
|
return template.render({"comment": comment.as_dict()})
|