{-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE FlexibleContexts #-} {- weibo oauth2: http://open.weibo.com/wiki/Oauth2 This is very trivial testing of the httpclient api. 1. this case will print out a URL 2. run the URL in browser and will navigate to weibo auth page 3. conform the authentication and browser will navigate back to the callback url, which obviously will failed cause there is no local server. 4. copy the `code` in the callback url and parse into console 5. this test case will gain access token using the `code` and print it out. check for integration testing at: https://github.com/HaskellCNOrg/snaplet-oauth/tree/master/test -} module Main where import qualified Data.ByteString as BS import qualified Data.ByteString.Lazy.Char8 as BSL import Data.Maybe (fromJust) import qualified Data.Text as T import qualified Data.Text.Encoding as T import qualified Network.HTTP.Types as HT import Network.HTTP.Conduit import Control.Monad.Trans.Control (MonadBaseControl) import Data.Conduit (MonadResource) import Network.OAuth2.HTTP.HttpClient import Network.OAuth2.OAuth2 import Weibo.Key weibooauth :: OAuth2 weibooauth = weiboKey { oauthOAuthorizeEndpoint = "https://api.weibo.com/oauth2/authorize" , oauthAccessTokenEndpoint = "https://api.weibo.com/oauth2/access_token" , oauthAccessToken = Nothing } main :: IO () main = do print $ authorizationUrl weibooauth putStrLn "visit the url and paste code here: " code <- getLine token <- requestAccessToken weibooauth (sToBS code) print token sToBS :: String -> BS.ByteString sToBS = T.encodeUtf8 . T.pack