module Network.API.TheMovieDB.Actions
( searchMovies,
fetchMovie,
searchTV,
fetchTV,
fetchTVSeason,
fetchFullTVSeries,
config,
)
where
import Network.API.TheMovieDB.Internal.Configuration
import Network.API.TheMovieDB.Internal.SearchResults
import Network.API.TheMovieDB.Internal.TheMovieDB
import Network.API.TheMovieDB.Internal.Types
import Network.API.TheMovieDB.Types.Movie
import Network.API.TheMovieDB.Types.Season
import Network.API.TheMovieDB.Types.TV
searchMovies :: Text -> TheMovieDB [Movie]
searchMovies :: Text -> TheMovieDB [Movie]
searchMovies Text
query = forall a. SearchResults a -> [a]
searchResults forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> TheMovieDB (SearchResults Movie)
search
where
search :: TheMovieDB (SearchResults Movie)
search = forall a. FromJSON a => [Char] -> QueryText -> TheMovieDB a
getAndParse [Char]
"search/movie" [(Text
"query", forall a. a -> Maybe a
Just Text
query)]
fetchMovie ::
ItemID ->
TheMovieDB Movie
fetchMovie :: ItemID -> TheMovieDB Movie
fetchMovie ItemID
mid = forall a. FromJSON a => [Char] -> QueryText -> TheMovieDB a
getAndParse ([Char]
"movie/" forall a. [a] -> [a] -> [a]
++ forall b a. (Show a, IsString b) => a -> b
show ItemID
mid) []
searchTV :: Text -> TheMovieDB [TV]
searchTV :: Text -> TheMovieDB [TV]
searchTV Text
query = forall a. SearchResults a -> [a]
searchResults forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> TheMovieDB (SearchResults TV)
search
where
search :: TheMovieDB (SearchResults TV)
search = forall a. FromJSON a => [Char] -> QueryText -> TheMovieDB a
getAndParse [Char]
"search/tv" [(Text
"query", forall a. a -> Maybe a
Just Text
query)]
fetchTV ::
ItemID ->
TheMovieDB TV
fetchTV :: ItemID -> TheMovieDB TV
fetchTV ItemID
i = forall a. FromJSON a => [Char] -> QueryText -> TheMovieDB a
getAndParse ([Char]
"tv/" forall a. [a] -> [a] -> [a]
++ forall b a. (Show a, IsString b) => a -> b
show ItemID
i) []
fetchTVSeason ::
ItemID ->
Int ->
TheMovieDB Season
fetchTVSeason :: ItemID -> ItemID -> TheMovieDB Season
fetchTVSeason ItemID
i ItemID
n = forall a. FromJSON a => [Char] -> QueryText -> TheMovieDB a
getAndParse ([Char]
"tv/" forall a. [a] -> [a] -> [a]
++ forall b a. (Show a, IsString b) => a -> b
show ItemID
i forall a. [a] -> [a] -> [a]
++ [Char]
"/season/" forall a. [a] -> [a] -> [a]
++ forall b a. (Show a, IsString b) => a -> b
show ItemID
n) []
fetchFullTVSeries ::
ItemID ->
TheMovieDB TV
fetchFullTVSeries :: ItemID -> TheMovieDB TV
fetchFullTVSeries ItemID
i = do
TV
tv <- ItemID -> TheMovieDB TV
fetchTV ItemID
i
[Season]
seasons <- forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
mapM (ItemID -> ItemID -> TheMovieDB Season
fetchTVSeason ItemID
i forall b c a. (b -> c) -> (a -> b) -> a -> c
. Season -> ItemID
seasonNumber) (TV -> [Season]
tvSeasons TV
tv)
forall (m :: * -> *) a. Monad m => a -> m a
return TV
tv {tvSeasons :: [Season]
tvSeasons = [Season]
seasons}
config :: TheMovieDB Configuration
config :: TheMovieDB Configuration
config = forall a. FromJSON a => [Char] -> QueryText -> TheMovieDB a
getAndParse [Char]
"configuration" []