module Unison.Share.Codeserver
( isCustomCodeserver,
defaultCodeserver,
resolveCodeserver,
CodeserverURI (..),
)
where
import Network.URI (parseURI)
import System.IO.Unsafe (unsafePerformIO)
import Unison.Codebase.Editor.RemoteRepo qualified as RemoteRepo
import Unison.Prelude
import Unison.Share.Types
import Unison.Share.Types qualified as Share
import UnliftIO.Environment (lookupEnv)
shareProd :: CodeserverURI
shareProd :: CodeserverURI
shareProd =
CodeserverURI
{ $sel:codeserverScheme:CodeserverURI :: Scheme
codeserverScheme = Scheme
Share.Https,
$sel:codeserverUserInfo:CodeserverURI :: [Char]
codeserverUserInfo = [Char]
"",
$sel:codeserverRegName:CodeserverURI :: [Char]
codeserverRegName = [Char]
"api.unison-lang.org",
$sel:codeserverPort:CodeserverURI :: Maybe Int
codeserverPort = Maybe Int
forall a. Maybe a
Nothing,
$sel:codeserverPath:CodeserverURI :: [[Char]]
codeserverPath = []
}
isCustomCodeserver :: CodeserverURI -> Bool
isCustomCodeserver :: CodeserverURI -> Bool
isCustomCodeserver = CodeserverURI -> CodeserverURI -> Bool
forall a. Eq a => a -> a -> Bool
(/=) CodeserverURI
shareProd
defaultCodeserver :: CodeserverURI
defaultCodeserver :: CodeserverURI
defaultCodeserver = IO CodeserverURI -> CodeserverURI
forall a. IO a -> a
unsafePerformIO (IO CodeserverURI -> CodeserverURI)
-> IO CodeserverURI -> CodeserverURI
forall a b. (a -> b) -> a -> b
$ do
[Char] -> IO (Maybe [Char])
forall (m :: * -> *). MonadIO m => [Char] -> m (Maybe [Char])
lookupEnv [Char]
"UNISON_SHARE_HOST" IO (Maybe [Char])
-> (Maybe [Char] -> CodeserverURI) -> IO CodeserverURI
forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&> \case
Maybe [Char]
Nothing -> CodeserverURI
shareProd
Just [Char]
shareHost ->
CodeserverURI -> Maybe CodeserverURI -> CodeserverURI
forall a. a -> Maybe a -> a
fromMaybe ([Char] -> CodeserverURI
forall a. HasCallStack => [Char] -> a
error ([Char] -> CodeserverURI) -> [Char] -> CodeserverURI
forall a b. (a -> b) -> a -> b
$ [Char]
"Share Host is not a valid URI: " [Char] -> [Char] -> [Char]
forall a. Semigroup a => a -> a -> a
<> [Char]
shareHost) (Maybe CodeserverURI -> CodeserverURI)
-> Maybe CodeserverURI -> CodeserverURI
forall a b. (a -> b) -> a -> b
$ do
URI
uri <- [Char] -> Maybe URI
parseURI [Char]
shareHost
URI -> Maybe CodeserverURI
codeserverFromURI URI
uri
{-# NOINLINE defaultCodeserver #-}
resolveCodeserver :: RemoteRepo.ShareCodeserver -> CodeserverURI
resolveCodeserver :: ShareCodeserver -> CodeserverURI
resolveCodeserver = \case
ShareCodeserver
RemoteRepo.DefaultCodeserver -> CodeserverURI
defaultCodeserver
RemoteRepo.CustomCodeserver CodeserverURI
cs -> CodeserverURI
cs