blob: 29083093896611e0a37153ac807f60588d567ad3 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE TemplateHaskell #-}
module Authentication (User, queryUser) where
import Data.Aeson
import GHC.Generics
import Network.HTTP.Conduit
import Data.ByteString.Lazy.Char8 (unpack)
import Control.Exception
makeUrl = ("https://www.googleapis.com/oauth2/v3/tokeninfo?id_token="++)
data User = User
{ email :: String
, name :: String
} deriving (Eq, Show, Generic)
instance FromJSON User
queryUser :: String -> IO (Maybe User)
queryUser token = (queryUser' token) `catch` \e -> do
print (e :: HttpException)
return Nothing
queryUser' token = do
response <- simpleHttp (makeUrl token)
return (decode response)
|