Configuring the Clients
In every LittleHorse SDK, there is an LHConfig
class or struct that handles the configuration required for allowing your clients and Task Workers to talk to LittleHorse Server.
Creating the LHConfig
- Java
- Go
- Python
- C#
You can create a config object in three ways (this is the same for LHClientConfig
and LHWorkerConfig
):
- With no arguments, eg.
new LHClientConfig()
. This loads all configurations from the environment variables. - Passing in a properties object, eg.
new LHClientConfig(properties)
. This uses the configuration from the providedProperties
object. - Passing in a path to a properties file, eg.
new LHClientConfig("/opt/littlehorse.config")
. This uses the configuration from the provided file.
The java class can be found at:
import io.littlehorse.sdk.common.config.LHConfig;
You can create a config object in two ways:
- Using the environment variables as defaults, via
littlehorse.NewConfigFromEnv()
. - Passing in a path to a properties file, via
littlehorse.NewConfigFromProps("/opt/littlehorse.config")
. This assumes that the file is in the format of a JavaProperties
file.
To import it, you can use the following:
import "github.com/littlehorse-enterprises/littlehorse/sdk-go/littlehorse";
You can create a LHConfig
in Python as follows:
from littlehorse.config import LHConfig
def get_config() -> LHConfig:
config = LHConfig()
config_path = Path.home().joinpath(".config", "littlehorse.config")
if config_path.exists():
config.load(config_path)
return config
config: LHConfig = get_config()
If you do not call config.load(...)
, then the configurations are loaded from the environment variables.
You can create a config object in three ways:
- With no arguments, eg.
new LHConfig();
. This loads all configurations from the environment variables or set default values if env variables are not being set. - Passing in a dictionary object, eg.
new LHConfig(args);
. This uses the configuration from the providedDictionary
object, its usage is common when you pass arguments from your main program. - Passing in a path to a properties file, eg.
new LHConfig(filePath);
. This uses the configuration from the provided file.
The C# class can be found at:
using LittleHorse.Sdk;
This is an example of LHConfig setup:
private static LHConfig GetLHConfig(string[] args, ILoggerFactory loggerFactory)
{
// LHConfig setup from LH env variables
var config = new LHConfig(loggerFactory);
// LHConfig setup from path file
var userProfilePath = Environment.GetFolderPath(Environment.SpecialFolder.UserProfile);
string filePath = Path.Combine(userProfilePath, ".config/littlehorse.config");
if (File.Exists(filePath))
config = new LHConfig(filePath, loggerFactory);
// LHConfig setup from dictionary
if (args.Length > 0)
{
var lhConfigs = GetDictionaryFromMainArgs(args);
config = new LHConfig(lhConfigs, loggerFactory);
}
return config;
}
If you want to enable logs you should add a new param to the LHConfig eg. new LHConfig(filePath, loggerFactory)
, the loggerFactory comes from your service provider.
Client Config Options
All of our SDK's share common configuration options. They are listed below:
LHC_API_HOST
- This is the host name that the client should use to connect to the LH Server. It is equivalent to
bootstrap.servers
in Kafka; on LittleHorse Cloud this host always points to a Load Balancer.
- This is the host name that the client should use to connect to the LH Server. It is equivalent to
LHC_API_PORT
- This is the port that the client should connect to.
LHC_CLIENT_ID
- This is the client ID. This should be unique for every client.
LHC_CLIENT_KEY
- This is the path to the Client Private Key. Used for mTLS authentication.
LHC_CLIENT_CERT
- This is the path to the Client Public Key (Certificate). Used for mTLS authentication.
LHC_CA_CERT
- This is the path to the CA Certificate. Used for TLS.
LHC_OAUTH_CLIENT_ID
- This is the OAuth client ID. Used for OAuth authorization.
LHC_OAUTH_CLIENT_SECRET
- Optional OAuth2 Client Secret. Used by the Worker to identify itself at an Authorization Server. Client Credentials Flow.
LHC_OAUTH_ACCESS_TOKEN_URL
- Optional Access Token URL provided by the OAuth Authorization Server. Used by the Worker to obtain a token using client credentials flow. It is mandatory if
LHC_OAUTH_CLIENT_ID
andLHC_OAUTH_CLIENT_SECRET
are provided.
- Optional Access Token URL provided by the OAuth Authorization Server. Used by the Worker to obtain a token using client credentials flow. It is mandatory if
The following configurations are used for the Task Workers (in addition to the above configuration options for all):
LHW_NUM_WORKER_THREADS
- The number of worker threads in the
Threadpool
which executes Task Runs.
- The number of worker threads in the
LHW_TASK_WORKER_VERSION
- The version of this Task Worker. This is an optional config which is useful for keeping track of when you release new versions of your Task Workers.
LHW_SERVER_CONNECT_LISTENER
- The name of the Listener to connect to on the LH Server. This defaults to
PLAIN
.
- The name of the Listener to connect to on the LH Server. This defaults to
The following is specific for lhctl
cli:
LHC_OAUTH_SERVER_URL
- Optional Authorization Server URL. Used by the client to obtain a token using OAuth 2 authorization code credentials flow. It is used by OIDC to discover the server endpoints. It is mandatory if
LHC_OAUTH_CLIENT_ID
is provided.
- Optional Authorization Server URL. Used by the client to obtain a token using OAuth 2 authorization code credentials flow. It is used by OIDC to discover the server endpoints. It is mandatory if
Configuring the CLI
By default, lhctl
looks for a configuration file at ${HOME}/.config/littlehorse.config
. This configuration file tells lhctl
where and how to connect to the LittleHorse Servers. An example littlehorse.config
file looks like:
LHC_API_HOST=localhost
LHC_API_PORT=2023
LHW_SERVER_CONNECT_LISTENER=PLAIN
The LHC_API_HOST
and LHC_API_PORT
determine the endpoint that lhctl
connects to. The LHW_SERVER_CONNECT_LISTENER
is a config used by the Task Worker to tell the servers which listener to advertise to it. More details can be found in the configuration docs.
If you have properly installed lhctl
and configured it to point to a running LittleHorse Server, you should be able to run the following command:
-> lhctl search wfSpec
{
"results": []
}
Getting a gRPC Client
In an effort to not reinvent the wheel, LittleHorse exposes a gRPC API to its users. The LHConfig
allows you to get a gRPC client.
- Java
- Go
- Python
- C#
You can get an async gPRC stub as follows:
LHConfig config = new LHConfig();
LittleHorseStub client = config.getAsyncStub();
You can get a blocking gRPC stub as follows:
LHConfig config = new LHConfig();
LittleHorseBlockingStub client = config.getBlockingStub();
In Go, you can get a gRPC client as follows:
config := littlehorse.NewConfigFromEnv()
client := littlehorse.getGrpcClient()
Note that in gRPC in Go, there is no distinction between async or blocking gRPC clients.
In python, you can get a gRPC client as follows:
config = LHConfig()
blocking_stub = config.stub(async_channel=False)
async_stub = config.stub(async_channel=True)
In C#, you can get a gRPC client as follows, and if you want to call a method synchronously, or asynchronously you should specify the method call:
var config = LHConfig()
var lhClient = config.GetGrpcClientInstance();
lhClient.RegisterTaskWorker();
lhClient.RegisterTaskWorkerAsync()