module Reddit.Actions.Moderation where
import Reddit.Routes.Moderation
import Reddit.Types.Error
import Reddit.Types.Listing
import Reddit.Types.Moderation
import Reddit.Types.Options
import Reddit.Types.Reddit
import Reddit.Types.Subreddit
import Reddit.Types.User
import Network.API.Builder.Error
bans :: Monad m => Options BanID -> SubredditName -> RedditT m (Listing BanID Ban)
bans opts r = runRoute $ bansListing opts r
lookupBan :: Monad m => Username -> SubredditName -> RedditT m (Maybe Ban)
lookupBan u r = do
res <- runRoute $ banLookup u r
case res :: Listing BanID Ban of
Listing _ _ bs ->
case bs of
[b] -> return $ Just b
[] -> return Nothing
_-> failWith (APIError InvalidResponseError)