mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-04 13:17:43 -06:00
6fe2703665
* Remove `make updatedeps` from Travis build. We'll follow up with more specific plans around dependency updating in subsequent PRs. * Update all `make` targets to set `GO15VENDOREXPERIMENT=1` and to filter out `/vendor/` from `./...` where appropriate. * Temporarily remove `vet` from the `make test` target until we can figure out how to get it to not vet `vendor/`. (Initial experimentation failed to yield the proper incantation.) Everything is pinned to current master, with the exception of: * Azure/azure-sdk-for-go which is pinned before the breaking change today * aws/aws-sdk-go which is pinned to the most recent tag The documentation still needs to be updated, which we can do in a follow up PR. The goal here is to unblock release.
139 lines
5.3 KiB
Go
139 lines
5.3 KiB
Go
// Package management provides the main API client to construct other clients
|
|
// and make requests to the Microsoft Azure Service Management REST API.
|
|
package management
|
|
|
|
import (
|
|
"errors"
|
|
"time"
|
|
)
|
|
|
|
const (
|
|
DefaultAzureManagementURL = "https://management.core.windows.net"
|
|
DefaultOperationPollInterval = time.Second * 30
|
|
DefaultAPIVersion = "2014-10-01"
|
|
DefaultUserAgent = "azure-sdk-for-go"
|
|
|
|
errPublishSettingsConfiguration = "PublishSettingsFilePath is set. Consequently ManagementCertificatePath and SubscriptionId must not be set."
|
|
errManagementCertificateConfiguration = "Both ManagementCertificatePath and SubscriptionId should be set, and PublishSettingsFilePath must not be set."
|
|
errParamNotSpecified = "Parameter %s is not specified."
|
|
)
|
|
|
|
type client struct {
|
|
publishSettings publishSettings
|
|
config ClientConfig
|
|
}
|
|
|
|
// Client is the base Azure Service Management API client instance that
|
|
// can be used to construct client instances for various services.
|
|
type Client interface {
|
|
// SendAzureGetRequest sends a request to the management API using the HTTP GET method
|
|
// and returns the response body or an error.
|
|
SendAzureGetRequest(url string) ([]byte, error)
|
|
|
|
// SendAzurePostRequest sends a request to the management API using the HTTP POST method
|
|
// and returns the request ID or an error.
|
|
SendAzurePostRequest(url string, data []byte) (OperationID, error)
|
|
|
|
// SendAzurePostRequestWithReturnedResponse sends a request to the management API using
|
|
// the HTTP POST method and returns the response body or an error.
|
|
SendAzurePostRequestWithReturnedResponse(url string, data []byte) ([]byte, error)
|
|
|
|
// SendAzurePutRequest sends a request to the management API using the HTTP PUT method
|
|
// and returns the request ID or an error. The content type can be specified, however
|
|
// if an empty string is passed, the default of "application/xml" will be used.
|
|
SendAzurePutRequest(url, contentType string, data []byte) (OperationID, error)
|
|
|
|
// SendAzureDeleteRequest sends a request to the management API using the HTTP DELETE method
|
|
// and returns the request ID or an error.
|
|
SendAzureDeleteRequest(url string) (OperationID, error)
|
|
|
|
// GetOperationStatus gets the status of operation with given Operation ID.
|
|
// WaitForOperation utility method can be used for polling for operation status.
|
|
GetOperationStatus(operationID OperationID) (GetOperationStatusResponse, error)
|
|
|
|
// WaitForOperation polls the Azure API for given operation ID indefinitely
|
|
// until the operation is completed with either success or failure.
|
|
// It is meant to be used for waiting for the result of the methods that
|
|
// return an OperationID value (meaning a long running operation has started).
|
|
//
|
|
// Cancellation of the polling loop (for instance, timing out) is done through
|
|
// cancel channel. If the user does not want to cancel, a nil chan can be provided.
|
|
// To cancel the method, it is recommended to close the channel provided to this
|
|
// method.
|
|
//
|
|
// If the operation was not successful or cancelling is signaled, an error
|
|
// is returned.
|
|
WaitForOperation(operationID OperationID, cancel chan struct{}) error
|
|
}
|
|
|
|
// ClientConfig provides a configuration for use by a Client.
|
|
type ClientConfig struct {
|
|
ManagementURL string
|
|
OperationPollInterval time.Duration
|
|
UserAgent string
|
|
APIVersion string
|
|
}
|
|
|
|
// NewAnonymousClient creates a new azure.Client with no credentials set.
|
|
func NewAnonymousClient() Client {
|
|
return client{}
|
|
}
|
|
|
|
// DefaultConfig returns the default client configuration used to construct
|
|
// a client. This value can be used to make modifications on the default API
|
|
// configuration.
|
|
func DefaultConfig() ClientConfig {
|
|
return ClientConfig{
|
|
ManagementURL: DefaultAzureManagementURL,
|
|
OperationPollInterval: DefaultOperationPollInterval,
|
|
APIVersion: DefaultAPIVersion,
|
|
UserAgent: DefaultUserAgent,
|
|
}
|
|
}
|
|
|
|
// NewClient creates a new Client using the given subscription ID and
|
|
// management certificate.
|
|
func NewClient(subscriptionID string, managementCert []byte) (Client, error) {
|
|
return NewClientFromConfig(subscriptionID, managementCert, DefaultConfig())
|
|
}
|
|
|
|
// NewClientFromConfig creates a new Client using a given ClientConfig.
|
|
func NewClientFromConfig(subscriptionID string, managementCert []byte, config ClientConfig) (Client, error) {
|
|
return makeClient(subscriptionID, managementCert, config)
|
|
}
|
|
|
|
func makeClient(subscriptionID string, managementCert []byte, config ClientConfig) (Client, error) {
|
|
var c client
|
|
|
|
if subscriptionID == "" {
|
|
return c, errors.New("azure: subscription ID required")
|
|
}
|
|
|
|
if len(managementCert) == 0 {
|
|
return c, errors.New("azure: management certificate required")
|
|
}
|
|
|
|
publishSettings := publishSettings{
|
|
SubscriptionID: subscriptionID,
|
|
SubscriptionCert: managementCert,
|
|
SubscriptionKey: managementCert,
|
|
}
|
|
|
|
// Validate client configuration
|
|
switch {
|
|
case config.ManagementURL == "":
|
|
return c, errors.New("azure: base URL required")
|
|
case config.OperationPollInterval <= 0:
|
|
return c, errors.New("azure: operation polling interval must be a positive duration")
|
|
case config.APIVersion == "":
|
|
return c, errors.New("azure: client configuration must specify an API version")
|
|
case config.UserAgent == "":
|
|
config.UserAgent = DefaultUserAgent
|
|
}
|
|
|
|
return client{
|
|
publishSettings: publishSettings,
|
|
config: config,
|
|
}, nil
|
|
}
|