diff --git a/addons/website_forum/controllers/main.py b/addons/website_forum/controllers/main.py index 39ec0002c9d..ee4239668fb 100644 --- a/addons/website_forum/controllers/main.py +++ b/addons/website_forum/controllers/main.py @@ -143,6 +143,28 @@ class website_forum(http.Controller): } return request.website.render("website_forum.post_description_full", values) + @http.route(['/forum//comment'], type='http', auth="public", methods=['POST'], website=True) + def post_comment(self, forum, post_id=1, **kwargs): + cr, uid, context = request.cr, request.uid, request.context + if kwargs.get('comment'): + user = request.registry['res.users'].browse(cr, SUPERUSER_ID, uid, context=context) + group_ids = user.groups_id + group_id = request.registry["ir.model.data"].get_object_reference(cr, uid, 'website_mail', 'group_comment')[1] + if group_id in [group.id for group in group_ids]: + Post = request.registry['website.forum.post'] + Post.check_access_rights(cr, uid, 'read') + Post.message_post( + cr, SUPERUSER_ID, int(post_id), + body=kwargs.get('comment'), + type='comment', + subtype='mt_comment', + author_id=user.partner_id.id, + context=dict(context, mail_create_nosubcribe=True)) + + post = request.registry['website.forum.post'].browse(cr, uid, int(post_id), context=context) + question_id = post.parent_id.id if post.parent_id else post.id + return werkzeug.utils.redirect("/forum/%s/question/%s" % (slug(forum),question_id)) + @http.route(['/forum//user/'], type='http', auth="public", website=True, multilang=True) def open_user(self, forum, user, **post): answers = {} diff --git a/addons/website_forum/models/website_forum.py b/addons/website_forum/models/website_forum.py index 819791cb101..4d01988a7f8 100644 --- a/addons/website_forum/models/website_forum.py +++ b/addons/website_forum/models/website_forum.py @@ -74,19 +74,20 @@ class Post(osv.Model): 'create_uid': fields.many2one('res.users', 'Asked by', select=True, readonly=True ), 'write_date': fields.datetime('Update on', select=True, readonly=True ), 'write_uid': fields.many2one('res.users', 'Update by', select=True, readonly=True), - + 'tags': fields.many2many('website.forum.tag', 'forum_tag_rel', 'forum_id', 'forum_tag_id', 'Tag'), 'vote_ids':fields.one2many('website.forum.post.vote', 'post_id', 'Vote'), - + 'favourite_ids': fields.many2many('res.users', 'forum_favourite_rel', 'forum_id', 'user_id', 'Favourite'), - + 'state': fields.selection([('active', 'Active'),('close', 'Close'),('offensive', 'Offensive')], 'Status'), 'active': fields.boolean('Active'), 'views': fields.integer('Views'), - + 'parent_id': fields.many2one('website.forum.post', 'Parent'), 'child_ids': fields.one2many('website.forum.post', 'parent_id', 'Child'), - + + 'history_ids': fields.one2many('blog.post.history', 'post_id', 'History', help='Last post modifications'), # TODO FIXME: when website_mail/mail_thread.py inheritance work -> this field won't be necessary 'website_message_ids': fields.one2many( 'mail.message', 'res_id', diff --git a/addons/website_forum/security/ir.model.access.csv b/addons/website_forum/security/ir.model.access.csv index d67152a1979..32827ac671a 100644 --- a/addons/website_forum/security/ir.model.access.csv +++ b/addons/website_forum/security/ir.model.access.csv @@ -1,5 +1,6 @@ id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink +access_website_forum,website.forum,model_website_forum,base.group_public,1,0,0,0 access_website_forum_post,website.forum.post,model_website_forum_post,base.group_public,1,0,0,0 access_website_forum_post_history,website.forum.post.history,model_website_forum_post_history,base.group_public,1,0,0,0 access_website_forum_post_vote,website.forum.post.vote,model_website_forum_post_vote,base.group_public,1,0,0,0 diff --git a/addons/website_forum/views/website_forum.xml b/addons/website_forum/views/website_forum.xml index 635ec62ca26..e3c00ab8190 100644 --- a/addons/website_forum/views/website_forum.xml +++ b/addons/website_forum/views/website_forum.xml @@ -376,6 +376,9 @@ Asked on + + +
@@ -432,6 +435,10 @@ Answered on
+ + + +
@@ -444,6 +451,28 @@ +