mirror of
https://github.com/Start9Labs/registry.git
synced 2026-03-26 10:21:51 +00:00
53 lines
1.3 KiB
Haskell
53 lines
1.3 KiB
Haskell
{-# LANGUAGE QuasiQuotes #-}
|
|
|
|
module Handler.Package.V0.Icon where
|
|
|
|
import Conduit (
|
|
awaitForever,
|
|
(.|),
|
|
)
|
|
import Data.String.Interpolate.IsString (
|
|
i,
|
|
)
|
|
import Foundation (Handler)
|
|
import Handler.Package.V1.Index (getOsVersionQuery)
|
|
import Handler.Util (
|
|
fetchCompatiblePkgVersions,
|
|
getVersionSpecFromQuery,
|
|
orThrow,
|
|
versionPriorityFromQueryIsMin,
|
|
)
|
|
import Lib.Error (S9Error (..))
|
|
import Lib.PkgRepository (
|
|
getBestVersion,
|
|
getIcon,
|
|
)
|
|
import Lib.Types.Core (PkgId)
|
|
import Network.HTTP.Types (status400)
|
|
import Startlude (
|
|
pure,
|
|
show,
|
|
($),
|
|
)
|
|
import Yesod (
|
|
TypedContent,
|
|
addHeader,
|
|
respondSource,
|
|
sendChunkBS,
|
|
sendResponseStatus,
|
|
)
|
|
|
|
|
|
getIconsR :: PkgId -> Handler TypedContent
|
|
getIconsR pkg = do
|
|
osVersion <- getOsVersionQuery
|
|
osCompatibleVersions <- fetchCompatiblePkgVersions osVersion pkg
|
|
spec <- getVersionSpecFromQuery
|
|
preferMin <- versionPriorityFromQueryIsMin
|
|
version <-
|
|
(pure $ getBestVersion spec preferMin osCompatibleVersions)
|
|
`orThrow` sendResponseStatus status400 (NotFoundE [i|Icon for #{pkg} satisfying #{spec}|])
|
|
(ct, len, src) <- getIcon pkg version
|
|
addHeader "Content-Length" (show len)
|
|
respondSource ct $ src .| awaitForever sendChunkBS
|