From: Eevee <git@veekun.com>
Date: Wed, 19 May 2010 07:14:47 +0000 (-0700)
Subject: Posting!
X-Git-Tag: veekun-promotions/2010060201~1
X-Git-Url: http://git.veekun.com/zzz-spline-forum.git/commitdiff_plain/3be1ed06645727c8d66d23a07ead0d09a24b55c6?ds=sidebyside

Posting!
---

diff --git a/splinext/forum/__init__.py b/splinext/forum/__init__.py
index 98ad4af..6914409 100644
--- a/splinext/forum/__init__.py
+++ b/splinext/forum/__init__.py
@@ -9,10 +9,14 @@ import splinext.forum.controllers.forum
 
 def add_routes_hook(map, *args, **kwargs):
     """Hook to inject some of our behavior into the routes configuration."""
+    require_POST = dict(conditions=dict(method=['POST']))
+
     map.connect('/forums', controller='forum', action='forums')
     map.connect('/forums/{forum_id}', controller='forum', action='threads')
     map.connect('/forums/{forum_id}/threads/{thread_id}', controller='forum', action='posts')
 
+    map.connect('/forums/{forum_id}/threads/{thread_id}/write', controller='forum', action='write')
+
 
 class ForumPlugin(PluginBase):
     def controllers(self):
diff --git a/splinext/forum/controllers/forum.py b/splinext/forum/controllers/forum.py
index 93eaed4..d75bfe6 100644
--- a/splinext/forum/controllers/forum.py
+++ b/splinext/forum/controllers/forum.py
@@ -4,6 +4,8 @@ from pylons import config, request, response, session, tmpl_context as c, url
 from pylons.controllers.util import abort, redirect_to
 from routes import request_config
 from sqlalchemy.orm.exc import NoResultFound
+import wtforms
+from wtforms import fields
 
 from spline.model import meta
 from spline.lib import helpers as h
@@ -12,6 +14,10 @@ from splinext.forum import model as forum_model
 
 log = logging.getLogger(__name__)
 
+
+class WritePostForm(wtforms.Form):
+    content = fields.TextAreaField('Content')
+
 class ForumController(BaseController):
 
     def forums(self):
@@ -37,3 +43,46 @@ class ForumController(BaseController):
             abort(404)
 
         return render('/forum/posts.mako')
+
+
+    def write(self, forum_id, thread_id):
+        """Provides a form for posting to a thread."""
+        if not c.user.can('create_forum_post'):
+            abort(403)
+
+        try:
+            c.thread = meta.Session.query(forum_model.Thread) \
+                .filter_by(id=thread_id, forum_id=forum_id).one()
+        except NoResultFound:
+            abort(404)
+
+        c.form = WritePostForm(request.params)
+        c.write_mode = 'post'
+
+        if request.method != 'POST' or not c.form.validate():
+            # Failure or initial request; show the form
+            return render('/forum/write.mako')
+
+
+        # Otherwise, add the post.
+        c.thread = meta.Session.query(forum_model.Thread) \
+            .with_lockmode('update') \
+            .get(c.thread.id)
+
+        post = forum_model.Post(
+            position = c.thread.post_count + 1,
+            author_user_id = c.user.id,
+            content = c.form.content.data,
+        )
+
+        c.thread.posts.append(post)
+        c.thread.post_count += 1
+
+        meta.Session.commit()
+
+        # Redirect to the thread
+        # XXX probably to the post instead; anchor?  depends on paging scheme
+        h.flash('Your uniqueness has been added to our own.')
+        redirect_to(controller='forum', action='posts',
+            forum_id=forum_id, thread_id=thread_id,
+            _code=303)
diff --git a/splinext/forum/model/__init__.py b/splinext/forum/model/__init__.py
index 089a879..444f5b8 100644
--- a/splinext/forum/model/__init__.py
+++ b/splinext/forum/model/__init__.py
@@ -1,3 +1,5 @@
+from datetime import datetime
+
 from sqlalchemy import and_, Column, ForeignKey, Index
 from sqlalchemy.orm import relation
 from sqlalchemy.types import DateTime, Integer, Unicode
@@ -39,7 +41,7 @@ class Post(TableBase):
     thread_id = Column(Integer, ForeignKey('threads.id'), nullable=False)
     position = Column(Integer, nullable=False)
     author_user_id = Column(Integer, ForeignKey('users.id'), nullable=False)
-    posted_time = Column(DateTime, nullable=False, index=True)
+    posted_time = Column(DateTime, nullable=False, index=True, default=datetime.now)
     content = Column(Unicode(5120), nullable=False)
 
 Index('thread_position', Post.thread_id, Post.position, unique=True)
diff --git a/splinext/forum/templates/forum/write.mako b/splinext/forum/templates/forum/write.mako
new file mode 100644
index 0000000..79138f3
--- /dev/null
+++ b/splinext/forum/templates/forum/write.mako
@@ -0,0 +1,12 @@
+<%inherit file="/base.mako" />
+<%namespace name="lib" file="/lib.mako" />
+
+<%def name="title()">Post to ${c.thread.subject} - ${c.thread.forum.name} - Forums</%def>
+
+${h.form(url.current())}
+<dl class="standard-form">
+    ${lib.field('content', rows=12, cols=80)}
+
+    <dd><button type="submit">Post!</button></dd>
+</dl>
+${h.end_form()}