module Twilio.AuthorizedConnectApp
(
AuthorizedConnectApp(..)
, ConnectAppSID
, Twilio.AuthorizedConnectApp.get
) where
import Control.Monad
import Control.Monad.Catch
import Data.Aeson
import Data.Monoid
import Data.Text (Text)
import qualified Data.Text as T
import Data.Time.Clock
import Network.URI
import Control.Monad.Twilio
import Twilio.Internal.Parser
import Twilio.Internal.Request
import Twilio.Internal.Resource as Resource
import Twilio.Types
data AuthorizedConnectApp = AuthorizedConnectApp
{ dateCreated :: !UTCTime
, dateUpdated :: !UTCTime
, accountSID :: !AccountSID
, sid :: !ConnectAppSID
, friendlyName :: !Text
, description :: !Text
, companyName :: !Text
, homepageURL :: !(Maybe URI)
, uri :: !URI
} deriving (Show, Eq)
instance FromJSON AuthorizedConnectApp where
parseJSON (Object v) = AuthorizedConnectApp
<$> (v .: "date_created" >>= parseDateTime)
<*> (v .: "date_updated" >>= parseDateTime)
<*> v .: "account_sid"
<*> v .: "connect_app_sid"
<*> v .: "connect_app_friendly_name"
<*> v .: "connect_app_description"
<*> v .: "connect_app_company_name"
<*> (v .: "connect_app_homepage_url" <&> fmap filterEmpty
<&> fmap (fmap $ parseURI . T.unpack)
>>= maybeReturn'')
<*> (v .: "uri" <&> parseRelativeReference
>>= maybeReturn)
parseJSON _ = mzero
instance Get1 ConnectAppSID AuthorizedConnectApp where
get1 (getSID -> sid) = request parseJSONFromResponse =<< makeTwilioRequest
("/AuthorizedConnectApps/" <> sid <> ".json")
get :: MonadThrow m => ConnectAppSID -> TwilioT m AuthorizedConnectApp
get = Resource.get