Skip to content

Commit

Permalink
feat: can use user/password
Browse files Browse the repository at this point in the history
Some method in Proxmox required root permissions (account).
So we can pass it through cluster config.

Signed-off-by: Serge Logvinov <serge.logvinov@sinextra.dev>
  • Loading branch information
sergelogvinov committed Jan 3, 2024
1 parent 41a7f8d commit cd99ee9
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 7 deletions.
8 changes: 7 additions & 1 deletion pkg/cluster/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,13 @@ func NewCluster(config *ClustersConfig, hclient *http.Client) (*Cluster, error)
return nil, err
}

client.SetAPIToken(cfg.TokenID, cfg.TokenSecret)
if cfg.Username != "" && cfg.Password != "" {
if err := client.Login(cfg.Username, cfg.Password, ""); err != nil {
return nil, err
}
} else {
client.SetAPIToken(cfg.TokenID, cfg.TokenSecret)
}

proxmox[cfg.Region] = client
}
Expand Down
14 changes: 8 additions & 6 deletions pkg/cluster/cloud_config.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,8 @@ type ClustersConfig struct {
Insecure bool `yaml:"insecure,omitempty"`
TokenID string `yaml:"token_id,omitempty"`
TokenSecret string `yaml:"token_secret,omitempty"`
Username string `yaml:"username,omitempty"`
Password string `yaml:"password,omitempty"`
Region string `yaml:"region,omitempty"`
} `yaml:"clusters,omitempty"`
}
Expand All @@ -48,12 +50,12 @@ func ReadCloudConfig(config io.Reader) (ClustersConfig, error) {
}

for idx, c := range cfg.Clusters {
if c.TokenID == "" {
return ClustersConfig{}, fmt.Errorf("cluster #%d: token_id is required", idx+1)
}

if c.TokenSecret == "" {
return ClustersConfig{}, fmt.Errorf("cluster #%d: token_secret is required", idx+1)
if c.Username != "" && c.Password != "" {
if c.TokenID != "" || c.TokenSecret != "" {
return ClustersConfig{}, fmt.Errorf("cluster #%d: token_id and token_secret are not allowed when username and password are set", idx+1)
}
} else if c.TokenID == "" || c.TokenSecret == "" {
return ClustersConfig{}, fmt.Errorf("cluster #%d: either username and password or token_id and token_secret are required", idx+1)
}

if c.Region == "" {
Expand Down
13 changes: 13 additions & 0 deletions pkg/cluster/cloud_config_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,19 @@ clusters:
token_id: "user!token-id"
token_secret: "secret"
region: cluster-1
`))
assert.Nil(t, err)
assert.NotNil(t, cfg)
assert.Equal(t, 1, len(cfg.Clusters))

// Valid config with one cluster (username/password)
cfg, err = cluster.ReadCloudConfig(strings.NewReader(`
clusters:
- url: https://example.com
insecure: false
username: "user@pam"
password: "secret"
region: cluster-1
`))
assert.Nil(t, err)
assert.NotNil(t, cfg)
Expand Down

0 comments on commit cd99ee9

Please sign in to comment.