module MSAzureAPI.MachineLearning.Jobs where
import Control.Applicative (Alternative(..))
import Control.Monad.IO.Class (MonadIO(..))
import Data.Foldable (asum)
import Data.Functor (void)
import GHC.Generics (Generic(..))
import qualified Data.Aeson as A (ToJSON(..), genericToEncoding, FromJSON(..), genericParseJSON, defaultOptions, Options(..), withObject, withText, (.:), (.:?), object, (.=), Key, Value, camelTo2)
import qualified Data.ByteString as BS (ByteString)
import qualified Data.ByteString.Char8 as BS8 (pack, unpack)
import qualified Data.ByteString.Lazy as LBS (ByteString)
import Network.OAuth.OAuth2.Internal (AccessToken(..))
import Network.HTTP.Req (Req, Url, Option, Scheme(..), header, (=:))
import Data.Text (Text, pack, unpack)
import qualified Data.Text.Lazy as TL (Text, pack, unpack, toStrict)
import qualified MSAzureAPI.Internal.Common as MSA (APIPlane(..), (==:), put, get, getBs, post, getLbs, aesonOptions)
createJob :: (A.FromJSON b) =>
Text
-> Text
-> Text
-> Text
-> JobBase
-> AccessToken -> Req b
createJob :: forall b.
FromJSON b =>
Text -> Text -> Text -> Text -> JobBase -> AccessToken -> Req b
createJob Text
sid Text
rgid Text
wsid Text
jid =
forall b a.
(FromJSON b, ToJSON a) =>
APIPlane -> [Text] -> Option 'Https -> a -> AccessToken -> Req b
MSA.put APIPlane
MSA.APManagement [Text
"subscriptions", Text
sid,
Text
"resourceGroups", Text
rgid,
Text
"providers", Text
"Microsoft.MachineLearningServices",
Text
"workspaces", Text
wsid,
Text
"jobs", Text
jid] (Text
"api-version" Text -> Text -> Option 'Https
MSA.==: Text
"2023-04-JobBase")
data JobBase = JBAutoMLJob
| JBCommandJob
| JBPipelineJob
| JBSweepJob
deriving (JobBase -> JobBase -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: JobBase -> JobBase -> Bool
$c/= :: JobBase -> JobBase -> Bool
== :: JobBase -> JobBase -> Bool
$c== :: JobBase -> JobBase -> Bool
Eq, Int -> JobBase -> ShowS
[JobBase] -> ShowS
JobBase -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [JobBase] -> ShowS
$cshowList :: [JobBase] -> ShowS
show :: JobBase -> String
$cshow :: JobBase -> String
showsPrec :: Int -> JobBase -> ShowS
$cshowsPrec :: Int -> JobBase -> ShowS
Show, forall x. Rep JobBase x -> JobBase
forall x. JobBase -> Rep JobBase x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep JobBase x -> JobBase
$cfrom :: forall x. JobBase -> Rep JobBase x
Generic)
instance A.ToJSON JobBase where
toEncoding :: JobBase -> Encoding
toEncoding = forall a.
(Generic a, GToJSON' Encoding Zero (Rep a)) =>
Options -> a -> Encoding
A.genericToEncoding (String -> Options
MSA.aesonOptions String
"jb")