Haskell environment is assumed to be available see ghcup.
Known to compile with
$ ghcup list -c set -r
ghc 9.2.2 base-4.16.1.0 hls-powered
cabal 3.6.2.0 latest,recommended
hls 1.7.0.0 latest,recommended
stack 2.7.5 latest,recommended
ghcup 0.1.17.8 latest,recommended
Okta API Reference.
Generated client code is in gen, a small RIO wrapper is in rio.
To re-generate please run
# make generate
Run make help
to see all make targets.
Note that you need to use newTlsManager
or otherwise configure your client
with TLS or requests will fail.
Also note that API token you get from Okta MUST BE PREFIXED with SSWS
when
setting up auth method with AuthApiKeyApiToken
.
Please add this to your stack.yaml
to include in your project:
extra-deps:
- katip-0.8.2.0
- git: ssh://[email protected]/EarnestResearch/haskell-okta-http-client
commit: "27ca224cba36bbbe25714e89395671f32b81034b"
subdirs:
- gen
A complete GHCI example that lists groups:
import Data.Monoid
import Network.HTTP.Client.TLS
import Okta
let myOktaHost = "https://SOMETHING.okta.com"
let myApiToken = "APITOKEN"
mgr <- newTlsManager
config0 <- withStderrLogging =<< newConfig
let config =
config0 { configHost = myOktaHost }
`addAuthMethod` AuthApiKeyApiToken ("SSWS " <> myApiToken)
lgrRes <- dispatchMime mgr config listGroups
Note you can use
:{
multi line
code
:}
REPL syntax to paste into ghci
(run stack repl
under gen
).
Loads Okta config / HTTP manager from environment, adds pagination to generated APIs with pipes. A small complete example is found in rio/example.
Please add this to your stack.yaml
to include both, auto-generated API as well as RIO wrapper in your project:
extra-deps:
- github: EarnestResearch/haskell-okta-http-client
commit: "27ca224cba36bbbe25714e89395671f32b81034b"
subdirs:
- gen
- rio