Skip to content

Commit

Permalink
Merge pull request #355 from slickwarren/cwarren/8/harvester-client
Browse files Browse the repository at this point in the history
[v2.8] harvester client
  • Loading branch information
caliskanugur authored Dec 5, 2024
2 parents a63d6cd + 4e26b85 commit 1c68727
Show file tree
Hide file tree
Showing 2 changed files with 114 additions and 0 deletions.
101 changes: 101 additions & 0 deletions clients/harvester/client.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
package harvester

import (
"fmt"

frameworkDynamic "github.com/rancher/shepherd/clients/dynamic"
"github.com/rancher/shepherd/clients/rancher/catalog"
v1 "github.com/rancher/shepherd/clients/rancher/v1"

"github.com/rancher/shepherd/pkg/clientbase"
"github.com/rancher/shepherd/pkg/config"
"github.com/rancher/shepherd/pkg/environmentflag"
"github.com/rancher/shepherd/pkg/session"
"k8s.io/client-go/dynamic"
"k8s.io/client-go/rest"
)

// Client is the main harvester Client object that gives an end user access to the Provisioning and Catalog
// clients in order to create resources on harvester
type Client struct {
// Client used to access Steve v1 API resources
Steve *v1.Client
// Client used to access catalog.cattle.io v1 API resources (apps, charts, etc.)
Catalog *catalog.Client
// Config used to test against a harvester instance
HarvesterConfig *Config
// Session is the session object used by the client to track all the resources being created by the client.
Session *session.Session

restConfig *rest.Config
}

// NewClient is the constructor to the initializing a harvester Client. It takes a bearer token and session.Session. If bearer token is not provided,
// the bearer token provided in the configuration file is used.
func NewClient(bearerToken string, session *session.Session) (*Client, error) {
harvesterConfig := new(Config)
config.LoadConfig(ConfigurationFileKey, harvesterConfig)

environmentFlags := environmentflag.NewEnvironmentFlags()
environmentflag.LoadEnvironmentFlags(environmentflag.ConfigurationFileKey, environmentFlags)

if bearerToken == "" {
bearerToken = harvesterConfig.AdminToken
}

c := &Client{
HarvesterConfig: harvesterConfig,
}

session.CleanupEnabled = *harvesterConfig.Cleanup

var err error
restConfig := newRestConfig(bearerToken, harvesterConfig)
c.restConfig = restConfig
c.Session = session

c.Steve, err = v1.NewClient(clientOptsV1(restConfig, c.HarvesterConfig))
if err != nil {
return nil, err
}

c.Steve.Ops.Session = session

catalogClient, err := catalog.NewForConfig(restConfig, session)
if err != nil {
return nil, err
}

c.Catalog = catalogClient

return c, nil
}

// newRestConfig is a constructor that sets ups rest.Config the configuration used by the Provisioning client.
func newRestConfig(bearerToken string, harvesterConfig *Config) *rest.Config {
return &rest.Config{
Host: harvesterConfig.Host,
BearerToken: bearerToken,
TLSClientConfig: rest.TLSClientConfig{
Insecure: *harvesterConfig.Insecure,
},
}
}

// clientOptsV1 is a constructor that sets ups clientbase.ClientOpts the configuration used by the v1 harvester clients.
func clientOptsV1(restConfig *rest.Config, harvesterConfig *Config) *clientbase.ClientOpts {
return &clientbase.ClientOpts{
URL: fmt.Sprintf("https://%s/v1", harvesterConfig.Host),
TokenKey: restConfig.BearerToken,
Insecure: restConfig.Insecure,
}
}

// GetHarvesterDynamicClient is a helper function that instantiates a dynamic client to communicate with the harvester host.
func (c *Client) GetHarvesterDynamicClient() (dynamic.Interface, error) {
dynamic, err := frameworkDynamic.NewForConfig(c.Session, c.restConfig)
if err != nil {
return nil, err
}
return dynamic, nil
}
13 changes: 13 additions & 0 deletions clients/harvester/config.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
package harvester

// The json/yaml config key for the harvester config
const ConfigurationFileKey = "harvester"

// Config is configuration need to test against a harvester instance
type Config struct {
Host string `yaml:"host" json:"host"`
AdminToken string `yaml:"adminToken" json:"adminToken"`
AdminPassword string `yaml:"adminPassword" json:"adminPassword"`
Insecure *bool `yaml:"insecure" json:"insecure" default:"true"`
Cleanup *bool `yaml:"cleanup" json:"cleanup" default:"true"`
}

0 comments on commit 1c68727

Please sign in to comment.