improve handling an anonymous user
This commit is contained in:
parent
e80f72d741
commit
92185a14a9
@ -115,6 +115,8 @@ instance Yesod App where
|
||||
isAuthorized (ChallengeGraphDataR _) _ = return Authorized
|
||||
isAuthorized (ChallengeDiscussionR _) _ = return Authorized
|
||||
|
||||
isAuthorized (AvatarR _) _ = return Authorized
|
||||
|
||||
-- Default to Authorized for now.
|
||||
isAuthorized _ _ = isTrustedAuthorized
|
||||
|
||||
|
@ -49,6 +49,7 @@ instance ToTimelineItem (Entity Submission) where
|
||||
getChallengeDiscussionR :: Text -> Handler Html
|
||||
getChallengeDiscussionR name = do
|
||||
(Entity challengeId challenge) <- runDB $ getBy404 $ UniqueName name
|
||||
maybeUser <- maybeAuth
|
||||
(formWidget, formEnctype) <- generateFormPost $ renderBootstrap3 BootstrapBasicForm (commentForm challengeId)
|
||||
comments <- runDB $ selectList [CommentChallenge ==. challengeId] [Desc CommentPosted]
|
||||
submissions <- runDB $ selectList [SubmissionChallenge ==. challengeId] [Desc SubmissionStamp]
|
||||
@ -56,9 +57,9 @@ getChallengeDiscussionR name = do
|
||||
timelineItems'' <- mapM toTimelineItem submissions
|
||||
let sortedTimelineItems = sortBy (\item1 item2 -> (getTime item2 `compare` getTime item1)) (
|
||||
timelineItems' ++ timelineItems'')
|
||||
challengeLayout True challenge (discussionWidget formWidget formEnctype name sortedTimelineItems)
|
||||
challengeLayout True challenge (discussionWidget maybeUser formWidget formEnctype name sortedTimelineItems)
|
||||
|
||||
discussionWidget formWidget formEnctype name sortedTimelineItems = $(widgetFile "challenge-discussion")
|
||||
discussionWidget maybeUser formWidget formEnctype name sortedTimelineItems = $(widgetFile "challenge-discussion")
|
||||
|
||||
timelineItemWidget item = $(widgetFile "timeline-item")
|
||||
|
||||
@ -66,28 +67,20 @@ postChallengeDiscussionR :: Text -> Handler TypedContent
|
||||
postChallengeDiscussionR name = do
|
||||
(Entity challengeId _) <- runDB $ getBy404 $ UniqueName name
|
||||
((result, formWidget), formEnctype) <- runFormPost $ renderBootstrap3 BootstrapBasicForm (commentForm challengeId)
|
||||
case result of
|
||||
FormSuccess comment -> do
|
||||
userId <- requireAuthId
|
||||
stamp <- liftIO getCurrentTime
|
||||
userId <- requireAuthId
|
||||
|
||||
if commentAuthor comment == userId
|
||||
then
|
||||
do
|
||||
setMessage $ toHtml ("Comment submitted" :: Text)
|
||||
_ <- runDB $ insert comment
|
||||
return ()
|
||||
else
|
||||
do
|
||||
setMessage $ toHtml ("Wrong user ID" :: Text)
|
||||
return ()
|
||||
case result of
|
||||
FormSuccess (challengeId, commentContent) -> do
|
||||
setMessage $ toHtml ("Comment submitted" :: Text)
|
||||
_ <- runDB $ insert $ Comment challengeId userId stamp commentContent
|
||||
return ()
|
||||
_ -> do
|
||||
setMessage $ toHtml ("Something went wrong" :: Text)
|
||||
|
||||
redirect $ ChallengeDiscussionR name
|
||||
|
||||
commentForm :: Key Challenge -> AForm Handler Comment
|
||||
commentForm challengeId = Comment
|
||||
commentForm :: Key Challenge -> AForm Handler (ChallengeId, Textarea)
|
||||
commentForm challengeId = (,)
|
||||
<$> pure challengeId
|
||||
<*> lift requireAuthId
|
||||
<*> lift (liftIO getCurrentTime)
|
||||
<*> areq textareaField (bfs MsgCommentText) Nothing
|
||||
|
@ -266,6 +266,7 @@ getChallengeSubmissions condition name = do
|
||||
challengeAllSubmissionsWidget muserId challenge submissions tests = $(widgetFile "challenge-all-submissions")
|
||||
|
||||
challengeLayout withHeader challenge widget = do
|
||||
maybeUser <- maybeAuth
|
||||
bc <- widgetToPageContent widget
|
||||
defaultLayout $ do
|
||||
setTitle "Challenge"
|
||||
|
@ -1,9 +1,12 @@
|
||||
|
||||
<p>
|
||||
<form method=post action=@{ChallengeDiscussionR name}#form enctype=#{formEnctype}>
|
||||
^{formWidget}
|
||||
<button .btn .btn-primary type="submit">
|
||||
_{MsgSend} <span class="glyphicon glyphicon-upload"></span>
|
||||
$maybe user <- maybeUser
|
||||
<form method=post action=@{ChallengeDiscussionR name}#form enctype=#{formEnctype}>
|
||||
^{formWidget}
|
||||
<button .btn .btn-primary type="submit">
|
||||
_{MsgSend} <span class="glyphicon glyphicon-upload"></span>
|
||||
$nothing
|
||||
<b>Log in to write a comment
|
||||
|
||||
<div .timeline-box>
|
||||
$forall item <- sortedTimelineItems
|
||||
|
@ -5,8 +5,9 @@
|
||||
<li role="presentation" class="active"><a href="@{ShowChallengeR (challengeName challenge)}">Challenge</a>
|
||||
<li role="presentation"><a href="@{ChallengeReadmeR (challengeName challenge)}">Readme</a>
|
||||
<li role="presentation"><a href="@{ChallengeHowToR (challengeName challenge)}">How To</a>
|
||||
<li role="presentation"><a href="@{ChallengeSubmissionR (challengeName challenge)}">Submit</a>
|
||||
<li role="presentation"><a href="@{ChallengeMySubmissionsR (challengeName challenge)}">My Submissions</a>
|
||||
$if isJust maybeUser
|
||||
<li role="presentation"><a href="@{ChallengeSubmissionR (challengeName challenge)}">Submit</a>
|
||||
<li role="presentation"><a href="@{ChallengeMySubmissionsR (challengeName challenge)}">My Submissions</a>
|
||||
<li role="presentation"><a href="@{ChallengeAllSubmissionsR (challengeName challenge)}">All Submissions</a>
|
||||
<li role="presentation"><a href="@{ChallengeDiscussionR (challengeName challenge)}">Discussion</a>
|
||||
<div .col-md-10 role="main">
|
||||
|
Loading…
Reference in New Issue
Block a user