diff --git a/.github/workflows/integration-tests.yml b/.github/workflows/integration-tests.yml index 0a6b4921..7ce4b732 100644 --- a/.github/workflows/integration-tests.yml +++ b/.github/workflows/integration-tests.yml @@ -36,8 +36,8 @@ jobs: gotestsum --format testname --junitfile report.xml -- -v ./test/integration_tests/... env: CONDUCTOR_SERVER_URL: ${{ secrets.CONDUCTOR_SERVER_URL }} - KEY: ${{ secrets.KEY }} - SECRET: ${{ secrets.SECRET }} + CONDUCTOR_AUTH_KEY: ${{ secrets.KEY }} + CONDUCTOR_AUTH_SECRET: ${{ secrets.SECRET }} - name: Set PR Status to Failure if: ${{ failure() }} diff --git a/Dockerfile b/Dockerfile index 27f68be6..cfdcfb71 100644 --- a/Dockerfile +++ b/Dockerfile @@ -12,10 +12,10 @@ RUN go test -v $(go list ./... | grep -v /test/integration_tests) FROM build as inttest COPY /test /package/test -ARG KEY -ARG SECRET +ARG CONDUCTOR_AUTH_KEY +ARG CONDUCTOR_AUTH_SECRET ARG CONDUCTOR_SERVER_URL -ENV KEY=${KEY} -ENV SECRET=${SECRET} +ENV CONDUCTOR_AUTH_KEY=${CONDUCTOR_AUTH_KEY} +ENV CONDUCTOR_AUTH_SECRET=${CONDUCTOR_AUTH_SECRET} ENV CONDUCTOR_SERVER_URL=${CONDUCTOR_SERVER_URL} RUN go test -v ./test/integration_tests/... diff --git a/README.md b/README.md index aba8a14a..3a2197ab 100644 --- a/README.md +++ b/README.md @@ -173,41 +173,16 @@ To begin with, let's take a look at the variable declaration in [examples/hello_ ```go var ( - apiClient = client.NewAPIClient( - authSettings(), - httpSettings(), - ) + apiClient = client.NewAPIClientFromEnv() taskRunner = worker.NewTaskRunnerWithApiClient(apiClient) workflowExecutor = executor.NewWorkflowExecutor(apiClient) ) -func authSettings() *settings.AuthenticationSettings { - key := os.Getenv("KEY") - secret := os.Getenv("SECRET") - if key != "" && secret != "" { - return settings.NewAuthenticationSettings( - key, - secret, - ) - } - - return nil -} - -func httpSettings() *settings.HttpSettings { - url := os.Getenv("CONDUCTOR_SERVER_URL") - if url == "" { - fmt.Fprintf(os.Stderr, "Error: CONDUCTOR_SERVER_URL env variable is not set\n") - os.Exit(1) - } - - return settings.NewHttpSettings(url) -} ``` First we create an `APIClient` instance. This is a REST client. -We need to pass on the proper settings to our client. For convenience to run the example you can set the following environment variables: `CONDUCTOR_SERVER_URL`, `KEY`, `SECRET`. +We need to provide the correct settings to our client. In this example, `client.NewAPIClientFromEnv()` is used, which initializes a new client by reading the settings from the following environment variables: `CONDUCTOR_SERVER_URL`, `CONDUCTOR_AUTH_KEY`, and `CONDUCTOR_AUTH_SECRET`. Now let's take a look at the `main` function: @@ -265,11 +240,11 @@ cd examples go run hello_world/main.go ``` -#### Running the example in Orkes playground. +#### Running the example with an [Orkes developer account](https://developer.orkescloud.com). ```shell -export CONDUCTOR_SERVER_URL="https://play.orkes.io/api" -export KEY="..." -export SECRET="..." +export CONDUCTOR_SERVER_URL="https://developer.orkescloud.com/api" +export CONDUCTOR_AUTH_KEY="..." +export CONDUCTOR_AUTH_SECRET="..." cd examples go run hello_world/main.go ``` diff --git a/examples/hello_world/main.go b/examples/hello_world/main.go index e6450f04..395fc38e 100644 --- a/examples/hello_world/main.go +++ b/examples/hello_world/main.go @@ -2,51 +2,23 @@ package main import ( hello_world "examples/hello_world/src" - "os" "time" log "github.com/sirupsen/logrus" "github.com/conductor-sdk/conductor-go/sdk/client" "github.com/conductor-sdk/conductor-go/sdk/model" - "github.com/conductor-sdk/conductor-go/sdk/settings" "github.com/conductor-sdk/conductor-go/sdk/worker" "github.com/conductor-sdk/conductor-go/sdk/workflow/executor" ) var ( - apiClient = client.NewAPIClient( - authSettings(), - httpSettings(), - ) + apiClient = client.NewAPIClientFromEnv() taskRunner = worker.NewTaskRunnerWithApiClient(apiClient) workflowExecutor = executor.NewWorkflowExecutor(apiClient) ) -func authSettings() *settings.AuthenticationSettings { - key := os.Getenv("KEY") - secret := os.Getenv("SECRET") - if key != "" && secret != "" { - return settings.NewAuthenticationSettings( - key, - secret, - ) - } - - return nil -} - -func httpSettings() *settings.HttpSettings { - url := os.Getenv("CONDUCTOR_SERVER_URL") - if url == "" { - log.Error("Error: CONDUCTOR_SERVER_URL env variable is not set") - os.Exit(1) - } - - return settings.NewHttpSettings(url) -} - func main() { // Start the Greet Worker. This worker will process "greet" tasks. taskRunner.StartWorker("greet", hello_world.Greet, 1, time.Millisecond*100) diff --git a/sdk/client/api_client.go b/sdk/client/api_client.go index 5d50f33e..6320b62d 100644 --- a/sdk/client/api_client.go +++ b/sdk/client/api_client.go @@ -18,6 +18,7 @@ import ( "errors" "fmt" "io" + "log" "mime/multipart" "net" "net/http" @@ -47,7 +48,6 @@ var ( type APIClient struct { httpRequester *HttpRequester - tokenManager authentication.TokenManager } func NewAPIClient( @@ -62,9 +62,23 @@ func NewAPIClient( ) } func NewAPIClientFromEnv() *APIClient { - authenticationSettings := settings.NewAuthenticationSettings(os.Getenv(CONDUCTOR_AUTH_KEY), os.Getenv(CONDUCTOR_AUTH_SECRET)) - httpSettings := settings.NewHttpSettings(os.Getenv(CONDUCTOR_SERVER_URL)) - return NewAPIClient(authenticationSettings, httpSettings) + return NewAPIClient(NewAuthenticationSettingsFromEnv(), NewHttpSettingsFromEnv()) +} + +func NewAuthenticationSettingsFromEnv() *settings.AuthenticationSettings { + return settings.NewAuthenticationSettings( + os.Getenv(CONDUCTOR_AUTH_KEY), + os.Getenv(CONDUCTOR_AUTH_SECRET), + ) +} + +func NewHttpSettingsFromEnv() *settings.HttpSettings { + url := os.Getenv(CONDUCTOR_SERVER_URL) + if url == "" { + log.Fatalf("Error: %s env variable is not set", CONDUCTOR_SERVER_URL) + } + + return settings.NewHttpSettings(url) } func NewAPIClientWithTokenExpiration( diff --git a/test/testdata/util.go b/test/testdata/util.go index 51b3295d..fea681ed 100644 --- a/test/testdata/util.go +++ b/test/testdata/util.go @@ -19,7 +19,6 @@ import ( "github.com/conductor-sdk/conductor-go/sdk/authentication" "github.com/conductor-sdk/conductor-go/sdk/client" "github.com/conductor-sdk/conductor-go/sdk/model" - "github.com/conductor-sdk/conductor-go/sdk/settings" "github.com/conductor-sdk/conductor-go/sdk/worker" "github.com/conductor-sdk/conductor-go/sdk/workflow" "github.com/conductor-sdk/conductor-go/sdk/workflow/executor" @@ -27,17 +26,12 @@ import ( log "github.com/sirupsen/logrus" ) -const ( - AUTHENTICATION_KEY_ID = "KEY" - AUTHENTICATION_KEY_SECRET = "SECRET" - BASE_URL = "CONDUCTOR_SERVER_URL" -) - -var ( - apiClient = getApiClientWithAuthentication() -) - var ( + apiClient = client.NewAPIClientWithTokenExpiration( + client.NewAuthenticationSettingsFromEnv(), + client.NewHttpSettingsFromEnv(), + authentication.NewTokenExpiration(3*time.Second, 30*time.Second), + ) MetadataClient = client.MetadataResourceApiService{ APIClient: apiClient, } @@ -98,30 +92,6 @@ func ValidateWorkflowDaemon(waitTime time.Duration, outputChannel chan error, wo outputChannel <- nil } -func getApiClientWithAuthentication() *client.APIClient { - return client.NewAPIClientWithTokenExpiration( - getAuthenticationSettings(), - getHttpSettingsWithAuth(), - authentication.NewTokenExpiration( - 3*time.Second, - 30*time.Second, - ), - ) -} - -func getAuthenticationSettings() *settings.AuthenticationSettings { - return settings.NewAuthenticationSettings( - os.Getenv(AUTHENTICATION_KEY_ID), - os.Getenv(AUTHENTICATION_KEY_SECRET), - ) -} - -func getHttpSettingsWithAuth() *settings.HttpSettings { - return settings.NewHttpSettings( - os.Getenv(BASE_URL), - ) -} - func StartWorkflows(workflowQty int, workflowName string) ([]string, error) { workflowIdList := make([]string, workflowQty) for i := 0; i < workflowQty; i += 1 {