0
0
mirror of https://github.com/bpg/terraform-provider-proxmox.git synced 2025-06-29 18:21:10 +00:00
terraform-provider-proxmox/provider.go
2019-12-07 19:58:29 +01:00

96 lines
2.9 KiB
Go

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at https://mozilla.org/MPL/2.0/. */
package main
import (
"github.com/danitso/terraform-provider-proxmox/proxmox"
"github.com/hashicorp/terraform/helper/schema"
)
const (
mkProviderVirtualEnvironment = "virtual_environment"
mkProviderVirtualEnvironmentEndpoint = "endpoint"
mkProviderVirtualEnvironmentInsecure = "insecure"
mkProviderVirtualEnvironmentPassword = "password"
mkProviderVirtualEnvironmentUsername = "username"
)
type providerConfiguration struct {
veClient *proxmox.VirtualEnvironmentClient
}
// Provider returns the object for this provider.
func Provider() *schema.Provider {
return &schema.Provider{
ConfigureFunc: providerConfigure,
DataSourcesMap: map[string]*schema.Resource{
"proxmox_virtual_environment_version": dataSourceVirtualEnvironmentVersion(),
},
ResourcesMap: map[string]*schema.Resource{},
Schema: map[string]*schema.Schema{
mkProviderVirtualEnvironment: &schema.Schema{
Type: schema.TypeList,
Optional: true,
Elem: &schema.Resource{
Schema: map[string]*schema.Schema{
mkProviderVirtualEnvironmentEndpoint: {
Type: schema.TypeString,
Required: true,
Description: "The endpoint for the Proxmox Virtual Environment API",
},
mkProviderVirtualEnvironmentInsecure: {
Type: schema.TypeBool,
Optional: true,
Description: "Whether to skip the TLS verification step",
Default: false,
},
mkProviderVirtualEnvironmentPassword: {
Type: schema.TypeString,
Required: true,
Description: "The password for the Proxmox Virtual Environment API",
},
mkProviderVirtualEnvironmentUsername: {
Type: schema.TypeString,
Required: true,
Description: "The username for the Proxmox Virtual Environment API",
},
},
},
MaxItems: 1,
},
},
}
}
// providerConfigure() configures the provider before processing any IronMQ resources.
func providerConfigure(d *schema.ResourceData) (interface{}, error) {
var err error
var veClient *proxmox.VirtualEnvironmentClient
// Initialize the client for the Virtual Environment, if required.
veConfigBlock := d.Get(mkProviderVirtualEnvironment).([]interface{})
if len(veConfigBlock) > 0 {
veConfig := veConfigBlock[0].(map[string]interface{})
veClient, err = proxmox.NewVirtualEnvironmentClient(
veConfig[mkProviderVirtualEnvironmentEndpoint].(string),
veConfig[mkProviderVirtualEnvironmentUsername].(string),
veConfig[mkProviderVirtualEnvironmentPassword].(string),
veConfig[mkProviderVirtualEnvironmentInsecure].(bool),
)
if err != nil {
return nil, err
}
}
config := providerConfiguration{
veClient: veClient,
}
return config, nil
}