From b3a4c09e07dae208a49d6eb263facc107181d637 Mon Sep 17 00:00:00 2001 From: Anand Doshi Date: Fri, 27 Jul 2012 14:39:27 +0530 Subject: [PATCH] added guest read permission to blog --- .../july_2012/blog_guest_permission.py | 11 +++++++++++ erpnext/patches/patch_list.py | 6 +++++- erpnext/website/blog.py | 5 ++--- erpnext/website/doctype/blog/blog.txt | 19 +++++-------------- .../website_settings/website_settings.py | 5 ++++- 5 files changed, 27 insertions(+), 19 deletions(-) create mode 100644 erpnext/patches/july_2012/blog_guest_permission.py diff --git a/erpnext/patches/july_2012/blog_guest_permission.py b/erpnext/patches/july_2012/blog_guest_permission.py new file mode 100644 index 0000000000..eb254b1fbd --- /dev/null +++ b/erpnext/patches/july_2012/blog_guest_permission.py @@ -0,0 +1,11 @@ +def execute(): + """allocate read write permission to guest for doctype 'Blog'""" + import webnotes + webnotes.conn.sql("""delete from `tabDocPerm` where parent = 'Blog'""") + + webnotes.conn.commit() + + import webnotes.model.sync + webnotes.model.sync.sync('website', 'blog', 1) + + webnotes.conn.begin() diff --git a/erpnext/patches/patch_list.py b/erpnext/patches/patch_list.py index b945cd8e6e..6be98cd532 100644 --- a/erpnext/patches/patch_list.py +++ b/erpnext/patches/patch_list.py @@ -497,5 +497,9 @@ patch_list = [ 'patch_file': 'sync_trial_balance', 'description': "sync trial balance" }, - + { + 'patch_module': 'patches.july_2012', + 'patch_file': 'blog_guest_permission', + }, + ] \ No newline at end of file diff --git a/erpnext/website/blog.py b/erpnext/website/blog.py index a890cc0fc8..1f01b29171 100644 --- a/erpnext/website/blog.py +++ b/erpnext/website/blog.py @@ -34,6 +34,8 @@ def get_blog_list(args=None): from webnotes.utils import global_date_format, get_fullname res['full_name'] = get_fullname(res['owner']) res['published'] = global_date_format(res['published']) + if not res['content']: + res['content'] = website.web_cache.get_html(res['name']) res['content'] = split_blog_content(res['content']) res['content'] = res['content'][:1000] @@ -94,9 +96,6 @@ def add_comment(args=None): website.web_cache.clear_cache(args.get('page_name'), args.get('comment_doctype'), args.get('comment_docname')) - # loads fresh blog into cache - get_blog_content(args.get('page_name')) - import webnotes.utils comment['comment_date'] = webnotes.utils.pretty_date(comment['creation']) diff --git a/erpnext/website/doctype/blog/blog.txt b/erpnext/website/doctype/blog/blog.txt index 24187e3bf3..6ed7143b2d 100644 --- a/erpnext/website/doctype/blog/blog.txt +++ b/erpnext/website/doctype/blog/blog.txt @@ -3,9 +3,9 @@ # These values are common in all dictionaries { - 'creation': '2012-05-28 19:22:38', + 'creation': '2012-07-13 13:02:27', 'docstatus': 0, - 'modified': '2012-06-22 18:56:16', + 'modified': '2012-07-27 14:15:24', 'modified_by': u'Administrator', 'owner': u'Administrator' }, @@ -40,6 +40,7 @@ 'parent': u'Blog', 'parentfield': u'permissions', 'parenttype': u'DocType', + 'permlevel': 0, 'read': 1 }, @@ -51,10 +52,8 @@ # DocPerm { - 'cancel': 1, 'create': 1, 'doctype': u'DocPerm', - 'permlevel': 0, 'role': u'Website Manager', 'write': 1 }, @@ -63,7 +62,6 @@ { 'create': 1, 'doctype': u'DocPerm', - 'permlevel': 0, 'role': u'Blogger', 'write': 1 }, @@ -71,15 +69,8 @@ # DocPerm { 'doctype': u'DocPerm', - 'permlevel': 1, - 'role': u'Website Manager' - }, - - # DocPerm - { - 'doctype': u'DocPerm', - 'permlevel': 1, - 'role': u'Blogger' + 'role': u'Guest', + 'write': 0 }, # DocField diff --git a/erpnext/website/doctype/website_settings/website_settings.py b/erpnext/website/doctype/website_settings/website_settings.py index eb304d2155..4ceef6efb2 100644 --- a/erpnext/website/doctype/website_settings/website_settings.py +++ b/erpnext/website/doctype/website_settings/website_settings.py @@ -34,7 +34,8 @@ class DocType: # clear web cache import website.web_cache - website.web_cache.refresh_cache(build=['Blog']) + #website.web_cache.refresh_cache(build=['Blog']) + website.web_cache.refresh_cache() from webnotes.session_cache import clear_cache clear_cache('Guest') @@ -48,6 +49,8 @@ class DocType: d = Document('Default Home Page') d.parent = 'Control Panel' + d.parenttype = 'Control Panel' + d.parentfield = 'default_home_pages' d.role = 'Guest' d.home_page = self.doc.home_page d.save()