auth now using yesod-auth providers. Multiple providers supported.

This commit is contained in:
Stefan Dresselhaus
2015-06-16 20:08:01 +02:00
parent 07c0d37ceb
commit a59e571ea2
5 changed files with 27 additions and 29 deletions

View File

@ -1,9 +1,6 @@
module Handler.Home where
import Import
import Yesod.Form.Bootstrap3 (BootstrapFormLayout (..), renderBootstrap3,
withSmallInput, withPlaceholder, bfs,
withAutofocus)
-- This is a handler function for the GET request method on the HomeR
-- resource pattern. All of your resource patterns are defined in
@ -15,7 +12,6 @@ import Yesod.Form.Bootstrap3 (BootstrapFormLayout (..), renderBootstrap3,
getHomeR :: Handler Html
getHomeR = do
maid <- maybeAuthId
(loginWidget, loginEnctype) <- generateFormPost loginForm
defaultLayout $ do
setTitle "NEAT"
[whamlet|
@ -23,17 +19,16 @@ getHomeR = do
Welcome to NEAT.
<div>
Current Auth-ID: #{show maid}.
<div>
$maybe u <- maid
<p>
Data: #{show u}<br>
<a href=@{AuthR LogoutR}>Logout
$nothing
Login
<a href=@{AuthR LoginR}>Login-Page
<form method=post action=@{HomeR} enctype=#{loginEnctype}>
^{loginWidget}
<button>Submit
<a href=@{RegisterR}>Register Account
<p>
<a href=@{AuthR LoginR}>Login
<p>
<a href=@{RegisterR}>Register Account
|]
{-
(formWidget, formEnctype) <- generateFormPost sampleForm
@ -46,7 +41,10 @@ getHomeR = do
postHomeR :: Handler Html
postHomeR = do
((result, loginWidget), loginEnctype) <- runFormPost loginForm
defaultLayout $ [whamlet|
<h1>nothing to see here. Stuff coming soon (tm).
|]
{- ((result, loginWidget), loginEnctype) <- runFormPost loginForm
let loginfail err = defaultLayout $ do
setTitle "NEAT"
[whamlet|
@ -67,15 +65,10 @@ postHomeR = do
Nothing -> loginfail ("wrong username or password" :: Text)
Just (Entity _ (User name _ _)) ->
defaultLayout $ do [whamlet|<h1>Hello #{name}|]
_ -> loginfail ("wrong username or password" :: Text)
_ -> loginfail ("wrong username or password" :: Text)-}
sampleForm :: Form (FileInfo, Text)
sampleForm = renderBootstrap3 BootstrapBasicForm $ (,)
<$> fileAFormReq "Choose a file"
<*> areq textField (withSmallInput "What's on the file?") Nothing
loginForm :: Form (Text, Text)
{-loginForm :: Form (Text, Text)
loginForm = renderBootstrap3 BootstrapBasicForm $ (,)
<$> areq textField ((withAutofocus . withPlaceholder "Username") (bfs ("Username" :: Text))) Nothing
<*> areq passwordField (bfs ("Password" :: Text)) Nothing
<*> areq passwordField (bfs ("Password" :: Text)) Nothing-}

View File

@ -2,6 +2,7 @@ module Handler.Register where
import Import
import Yesod.Form.Bootstrap3
import Yesod.Auth.HashDB (setPassword)
import Handler.Home (getHomeR)
getRegisterR :: Handler Html
@ -28,8 +29,9 @@ postRegisterR = do
|]
case result of
FormSuccess (user,mail) -> do
u <- liftIO $ setPassword (fromMaybe "" $ userPassword user) user
_ <- runDB $ do
uid <- insert user
uid <- insert u
insert $ Email mail uid Nothing
getHomeR
FormFailure (err:_) -> again err