{-# LANGUAGE FlexibleContexts #-} {-# LANGUAGE OverloadedStrings #-} module Main where import qualified Data.ByteString.Char8 as BS import qualified Data.ByteString.Lazy.Char8 as BSL import qualified Data.Text as T import Network.HTTP.Conduit import qualified Network.HTTP.Types as HT import URI.ByteString import Network.OAuth.OAuth2 import Keys main :: IO () main = do BS.putStrLn $ serializeURIRef' $ authorizationUrl dropboxKey putStrLn "visit the url and paste code here: " code <- getLine mgr <- newManager tlsManagerSettings token <- fetchAccessToken mgr dropboxKey (ExchangeToken (T.pack code)) print token case token of Right at -> getSpaceUsage mgr (accessToken at) >>= print Left _ -> putStrLn "no access token found yet" getSpaceUsage :: Manager -> AccessToken -> IO (OAuth2Result BSL.ByteString) getSpaceUsage mgr token = do req <- parseRequest $ BS.unpack "https://api.dropboxapi.com/2/users/get_space_usage" authRequest req upReq mgr where upHeaders = updateRequestHeaders (Just token) . setMethod HT.POST upBody req = req {requestBody = "null" } upReq = upHeaders . upBody