slackbuilder/src/Main.hs

263 lines
12 KiB
Haskell
Raw Normal View History

2023-12-23 22:15:10 +01:00
{- This Source Code Form is subject to the terms of the Mozilla Public License,
v. 2.0. If a copy of the MPL was not distributed with this file, You can
obtain one at https://mozilla.org/MPL/2.0/. -}
module Main
( main
) where
2024-09-14 11:32:34 +02:00
import Control.Monad.Catch (MonadThrow(..), handle)
2023-09-03 10:26:43 +02:00
import Control.Monad.IO.Class (MonadIO(..))
import qualified Data.Map as Map
import Options.Applicative (execParser)
import SlackBuilder.CommandLine
2023-08-09 20:59:42 +02:00
import SlackBuilder.Config
2023-08-15 10:33:19 +02:00
import SlackBuilder.Trans
import SlackBuilder.LatestVersionCheck
2024-03-19 11:34:19 +01:00
import SlackBuilder.Update
2023-08-09 20:59:42 +02:00
import qualified Toml
2023-09-03 10:26:43 +02:00
import Data.Text (Text)
2024-09-08 16:44:57 +02:00
import qualified Data.Text.IO as Text
import Control.Monad.Trans.Reader (ReaderT(..), asks)
2024-03-19 11:34:19 +01:00
import SlackBuilder.Package (PackageDescription(..))
2023-09-03 10:26:43 +02:00
import qualified SlackBuilder.Package as Package
import Text.URI.QQ (uri)
import Data.Foldable (find, traverse_)
2023-10-08 12:28:46 +02:00
import GHC.Records (HasField(..))
2024-08-20 22:36:43 +02:00
import System.Console.ANSI
( setSGR
, SGR(..)
, ColorIntensity(..)
, Color(..)
, ConsoleLayer(..)
)
import Data.Maybe (fromJust)
2023-09-03 10:26:43 +02:00
autoUpdatable :: [PackageSettings] -> [PackageDescription]
autoUpdatable packageSettings =
[ PackageDescription
2023-09-03 10:26:43 +02:00
{ latest =
let ghArguments = uncurry PackageOwner $ fromJust $ getField @"github" setting
setting = fromJust $ find ((== "universal-ctags") . getField @"name") packageSettings
template = Package.DownloadTemplate $ getField @"template" setting
2024-01-19 09:57:58 +01:00
in Package.Updater
{ detectLatest = latestGitHub ghArguments (getField @"version" setting)
, getVersion = repackageWithTemplate (getField @"repackage" setting) template
, is64 = getField @"is64" setting
2024-01-19 09:57:58 +01:00
}
2023-09-03 10:26:43 +02:00
, name = "universal-ctags"
, downloaders = mempty
2023-10-01 17:19:06 +02:00
}
, PackageDescription
2023-10-01 17:19:06 +02:00
{ latest =
let packagistArguments = uncurry PackageOwner $ fromJust $ getField @"packagist" setting
setting = fromJust $ find ((== "composer") . getField @"name") packageSettings
template = Package.DownloadTemplate $ getField @"template" setting
2024-01-19 09:57:58 +01:00
in Package.Updater
{ detectLatest = latestPackagist packagistArguments
, getVersion = repackageWithTemplate (getField @"repackage" setting) template
, is64 = getField @"is64" setting
2024-01-19 09:57:58 +01:00
}
2023-10-01 17:19:06 +02:00
, name = "composer"
, downloaders = mempty
2023-09-03 10:26:43 +02:00
}
, PackageDescription
2023-10-03 18:53:41 +02:00
{ latest =
let ghArguments = uncurry PackageOwner $ fromJust $ getField @"github" setting
setting = fromJust $ find ((== "jitsi-meet-desktop") . getField @"name") packageSettings
template = Package.DownloadTemplate $ getField @"template" setting
2024-01-19 09:57:58 +01:00
in Package.Updater
{ detectLatest = latestGitHub ghArguments (getField @"version" setting)
, getVersion = repackageWithTemplate (getField @"repackage" setting) template
, is64 = getField @"is64" setting
2024-01-19 09:57:58 +01:00
}
2023-10-03 18:53:41 +02:00
, name = "jitsi-meet-desktop"
, downloaders = mempty
2023-10-03 18:53:41 +02:00
}
, PackageDescription
2023-10-04 22:36:19 +02:00
{ latest =
let ghArguments = uncurry PackageOwner $ fromJust $ getField @"github" setting
setting = fromJust $ find ((== "php82") . getField @"name") packageSettings
template = Package.DownloadTemplate $ getField @"template" setting
2024-01-19 09:57:58 +01:00
in Package.Updater
{ detectLatest = latestGitHub ghArguments (getField @"version" setting)
, getVersion = repackageWithTemplate (getField @"repackage" setting) template
, is64 = getField @"is64" setting
2024-01-19 09:57:58 +01:00
}
2023-10-04 22:36:19 +02:00
, name = "php82"
, downloaders = mempty
2023-10-08 12:28:46 +02:00
}
, PackageDescription
2023-10-08 12:28:46 +02:00
{ latest =
let ghArguments = uncurry PackageOwner $ fromJust $ getField @"github" setting
setting = fromJust $ find ((== "kitty") . getField @"name") packageSettings
template = Package.DownloadTemplate $ getField @"template" setting
2024-01-19 09:57:58 +01:00
in Package.Updater
{ detectLatest = latestGitHub ghArguments (getField @"version" setting)
, getVersion = repackageWithTemplate (getField @"repackage" setting) template
, is64 = getField @"is64" setting
2024-01-19 09:57:58 +01:00
}
2023-10-08 12:28:46 +02:00
, name = "kitty"
, downloaders = mempty
2023-10-04 22:36:19 +02:00
}
, PackageDescription
2023-10-13 19:34:02 +02:00
{ latest =
let ghArguments = uncurry PackageOwner $ fromJust $ getField @"github" setting
setting = fromJust $ find ((== "rdiff-backup") . getField @"name") packageSettings
template = Package.DownloadTemplate $ getField @"template" setting
2024-01-19 09:57:58 +01:00
in Package.Updater
{ detectLatest = latestGitHub ghArguments (getField @"version" setting)
, getVersion = repackageWithTemplate (getField @"repackage" setting) template
, is64 = getField @"is64" setting
2024-01-19 09:57:58 +01:00
}
2023-10-13 19:34:02 +02:00
, name = "rdiff-backup"
, downloaders = mempty
2023-10-13 19:34:02 +02:00
}
, PackageDescription
{ latest =
2024-09-27 12:20:34 +02:00
let textArguments = uncurry TextArguments $ fromJust $ getField @"text" setting
setting = fromJust $ find ((== "webex") . getField @"name") packageSettings
template = Package.DownloadTemplate $ getField @"template" setting
2024-01-19 09:57:58 +01:00
in Package.Updater
{ detectLatest = latestText textArguments (getField @"version" setting)
, getVersion = repackageWithTemplate (getField @"repackage" setting) template
, is64 = getField @"is64" setting
2024-01-19 09:57:58 +01:00
}
, name = "webex"
, downloaders = mempty
}
, PackageDescription
2023-10-20 19:23:21 +02:00
{ latest =
let ghArguments = uncurry PackageOwner $ fromJust $ getField @"github" setting
setting = fromJust $ find ((== "librsync") . getField @"name") packageSettings
template = Package.DownloadTemplate $ getField @"template" setting
2024-01-19 09:57:58 +01:00
in Package.Updater
{ detectLatest = latestGitHub ghArguments (getField @"version" setting)
, getVersion = repackageWithTemplate (getField @"repackage" setting) template
, is64 = getField @"is64" setting
2024-01-19 09:57:58 +01:00
}
2023-10-20 19:23:21 +02:00
, name = "librsync"
, downloaders = mempty
2023-10-20 19:23:21 +02:00
}
, PackageDescription
2023-10-20 19:23:21 +02:00
{ latest =
2024-09-27 12:20:34 +02:00
let textArguments = uncurry TextArguments $ fromJust $ getField @"text" setting
setting = fromJust $ find ((== "dmd") . getField @"name") packageSettings
template = Package.DownloadTemplate $ getField @"template" setting
2024-01-19 09:57:58 +01:00
in Package.Updater
{ detectLatest = latestText textArguments (getField @"version" setting)
, getVersion = repackageWithTemplate (getField @"repackage" setting) template
, is64 = getField @"is64" setting
2024-01-19 09:57:58 +01:00
}
2023-10-20 19:23:21 +02:00
, name = "dmd"
, downloaders = mempty
}
, PackageDescription
{ latest =
2024-09-27 12:20:34 +02:00
let textArguments = uncurry TextArguments $ fromJust $ getField @"text" setting
setting = fromJust $ find ((== "d-tools") . getField @"name") packageSettings
template = Package.DownloadTemplate $ getField @"template" setting
2024-01-19 09:57:58 +01:00
in Package.Updater
{ detectLatest = latestText textArguments (getField @"version" setting)
, getVersion = repackageWithTemplate (getField @"repackage" setting) template
, is64 = getField @"is64" setting
2024-01-19 09:57:58 +01:00
}
, name = "d-tools"
, downloaders =
let dubArguments = PackageOwner{ owner = "dlang", name = "dub" }
dscannerArguments = PackageOwner{ owner = "dlang-community", name = "D-Scanner" }
dcdArguments = PackageOwner{ owner = "dlang-community", name = "DCD" }
2024-01-19 09:57:58 +01:00
latestDub = Package.Updater
{ detectLatest = latestGitHub dubArguments "(v)\\."
, getVersion = reuploadWithTemplate dubTemplate
2024-01-19 09:57:58 +01:00
, is64 = False
}
latestDscanner = Package.Updater
{ detectLatest = latestGitHub dscannerArguments "(v)\\."
2024-01-19 09:57:58 +01:00
, getVersion = cloneFromGit dscannerURI "v"
, is64 = False
}
dcdURI = [uri|https://github.com/dlang-community/DCD.git|]
latestDcd = Package.Updater
{ detectLatest = latestGitHub dcdArguments "(v)\\."
2024-01-19 09:57:58 +01:00
, getVersion = cloneFromGit dcdURI "v"
, is64 = False
}
2024-09-01 17:34:24 +02:00
dubTemplate = Package.DownloadTemplate "https://codeload.github.com/dlang/dub/tar.gz/v{version}"
dscannerURI = [uri|https://github.com/dlang-community/D-Scanner.git|]
in Map.fromList
2024-01-19 09:57:58 +01:00
[ ("DUB", latestDub)
, ("DSCANNER", latestDscanner)
2024-01-19 09:57:58 +01:00
, ("DCD", latestDcd)
]
2023-10-20 19:23:21 +02:00
}
2024-03-26 11:52:16 +01:00
, PackageDescription
{ latest =
let ghArguments = uncurry PackageOwner $ fromJust $ getField @"github" setting
setting = fromJust $ find ((== "simde") . getField @"name") packageSettings
template = Package.DownloadTemplate $ getField @"template" setting
2024-03-26 11:52:16 +01:00
in Package.Updater
{ detectLatest = latestGitHub ghArguments (getField @"version" setting)
, getVersion = repackageWithTemplate (getField @"repackage" setting) template
, is64 = getField @"is64" setting
2024-03-26 11:52:16 +01:00
}
, name = "simde"
, downloaders = mempty
}
2024-09-09 16:47:44 +02:00
, PackageDescription
{ latest =
let ghArguments = uncurry PackageOwner $ fromJust $ getField @"github" setting
setting = fromJust $ find ((== "nginx") . getField @"name") packageSettings
template = Package.DownloadTemplate $ getField @"template" setting
2024-09-09 16:47:44 +02:00
in Package.Updater
{ detectLatest = latestGitHub ghArguments (getField @"version" setting)
, getVersion = repackageWithTemplate (getField @"repackage" setting) template
, is64 = getField @"is64" setting
2024-09-09 16:47:44 +02:00
}
, name = "nginx"
, downloaders = mempty
}
2023-09-03 10:26:43 +02:00
]
2023-12-11 08:14:55 +01:00
up2Date :: Maybe Text -> SlackBuilderT ()
up2Date selectedPackage = do
packages' <- SlackBuilderT $ asks (getField @"packages")
case selectedPackage of
Nothing -> traverse_ (handle handleException . go) $ autoUpdatable packages'
Just packageName
| Just foundPackage <- find ((packageName ==) . getField @"name") (autoUpdatable packages') ->
go foundPackage
| otherwise -> throwM $ UpdaterNotFound packageName
2023-09-03 10:26:43 +02:00
where
2023-10-20 19:23:21 +02:00
go package = getAndLogLatest package
>>= mapM_ updatePackageIfRequired
2023-10-20 19:23:21 +02:00
>> liftIO (putStrLn "")
2023-09-03 10:26:43 +02:00
check :: SlackBuilderT ()
check = SlackBuilderT (asks (getField @"packages"))
>>= traverse_ (handle handleException . go) . autoUpdatable
where
go package = getAndLogLatest package
>>= mapM_ checkUpdateAvailability
>> liftIO (putStrLn "")
main :: IO ()
2024-09-08 16:44:57 +02:00
main = execParser slackBuilderParser
>>= handle handleException . withCommandLine
2023-08-09 20:59:42 +02:00
where
2024-09-08 16:44:57 +02:00
withCommandLine programCommand = do
settingsResult <- Toml.decodeFileEither settingsCodec configurationFile
case settingsResult of
Right settings -> flip runReaderT settings
$ runSlackBuilderT
$ executeCommand programCommand
Left settingsErrors
-> setSGR [SetColor Foreground Dull Red]
>> putStrLn (configurationFile <> " parsing failed.")
>> setSGR [Reset]
>> Text.putStr (Toml.prettyTomlDecodeErrors settingsErrors)
configurationFile = "config/config.toml"
2023-08-15 10:33:19 +02:00
executeCommand = \case
2024-08-20 22:36:43 +02:00
CheckCommand -> check
Up2DateCommand packageName -> up2Date packageName