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

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

View File

@ -8,6 +8,7 @@ import Yesod.Auth.BrowserId (authBrowserId)
import Yesod.Default.Util (addStaticContentExternal) import Yesod.Default.Util (addStaticContentExternal)
import Yesod.Core.Types (Logger) import Yesod.Core.Types (Logger)
import qualified Yesod.Core.Unsafe as Unsafe import qualified Yesod.Core.Unsafe as Unsafe
import Yesod.Auth.HashDB (authHashDB, getAuthIdHashDB)
-- | The foundation datatype for your application. This can be a good place to -- | The foundation datatype for your application. This can be a good place to
-- keep settings and values requiring initialization before your application -- keep settings and values requiring initialization before your application
@ -121,21 +122,18 @@ instance YesodAuth App where
-- Override the above two destinations when a Referer: header is present -- Override the above two destinations when a Referer: header is present
redirectToReferer _ = True redirectToReferer _ = True
getAuthId creds = do getAuthId creds = getAuthIdHashDB AuthR (Just . UniqueUser) creds --authenticate on own site
now <- liftIO getCurrentTime --TODO: Authenticate via OAuth2
{-do
runDB $ do runDB $ do
x <- getBy $ UniqueUser $ credsIdent creds x <- getBy $ UniqueUser $ credsIdent creds
case x of case x of
Just (Entity uid _) -> return $ Just uid Just (Entity uid _) -> return $ Just uid
Nothing -> do Nothing -> return Nothing-}
fmap Just $ insert User
{ userIdent = credsIdent creds
, userPassword = Nothing
, userLastLogin = now
}
-- You can add other plugins like BrowserID, email or OAuth here -- You can add other plugins like BrowserID, email or OAuth here
authPlugins _ = [ authBrowserId def authPlugins _ = [ authBrowserId def
, authHashDB (Just . UniqueUser)
] ]
authHttpManager = getHttpManager authHttpManager = getHttpManager

View File

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

View File

@ -2,6 +2,7 @@ module Model where
import ClassyPrelude.Yesod import ClassyPrelude.Yesod
import Database.Persist.Quasi import Database.Persist.Quasi
import Yesod.Auth.HashDB (HashDBUser(..))
-- You can define all of your database entities in the entities file. -- You can define all of your database entities in the entities file.
-- You can find more information on persistent and how to declare entities -- You can find more information on persistent and how to declare entities
@ -9,3 +10,7 @@ import Database.Persist.Quasi
-- http://www.yesodweb.com/book/persistent/ -- http://www.yesodweb.com/book/persistent/
share [mkPersist sqlSettings, mkMigrate "migrateAll"] share [mkPersist sqlSettings, mkMigrate "migrateAll"]
$(persistFileWith lowerCaseSettings "config/models") $(persistFileWith lowerCaseSettings "config/models")
instance HashDBUser User where
userPasswordHash = userPassword
setPasswordHash h p = p { userPassword = Just h }

View File

@ -52,9 +52,9 @@ library
, yesod >= 1.4.1 && < 1.5 , yesod >= 1.4.1 && < 1.5
, yesod-core >= 1.4.6 && < 1.5 , yesod-core >= 1.4.6 && < 1.5
, yesod-auth >= 1.4.0 && < 1.5 , yesod-auth >= 1.4.0 && < 1.5
, yesod-persistent >= 1.4.0 && < 1.5
, yesod-static >= 1.4.0.3 && < 1.5 , yesod-static >= 1.4.0.3 && < 1.5
, yesod-form >= 1.4.0 && < 1.5 , yesod-form >= 1.4.0 && < 1.5
, yesod-auth-hashdb >= 1.4.0 && < 1.5
, classy-prelude >= 0.10.2 , classy-prelude >= 0.10.2
, classy-prelude-conduit >= 0.10.2 , classy-prelude-conduit >= 0.10.2
, classy-prelude-yesod >= 0.10.2 , classy-prelude-yesod >= 0.10.2