2014-10-02 13:48:11 -05:00
|
|
|
package remote
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2014-12-03 22:05:29 -06:00
|
|
|
"strings"
|
2014-12-04 18:57:11 -06:00
|
|
|
|
|
|
|
"github.com/hashicorp/terraform/terraform"
|
2014-10-02 13:48:11 -05:00
|
|
|
)
|
|
|
|
|
2014-10-06 19:50:09 -05:00
|
|
|
var (
|
|
|
|
// ErrConflict is used to indicate the upload was rejected
|
|
|
|
// due to a conflict on the state
|
|
|
|
ErrConflict = fmt.Errorf("Conflicting state file")
|
2014-10-07 14:09:51 -05:00
|
|
|
|
2014-10-08 12:28:47 -05:00
|
|
|
// ErrServerNewer is used to indicate the serial number of
|
|
|
|
// the state is newer on the server side
|
|
|
|
ErrServerNewer = fmt.Errorf("Server-side Serial is newer")
|
|
|
|
|
2014-10-07 14:09:51 -05:00
|
|
|
// ErrRequireAuth is used if the remote server requires
|
|
|
|
// authentication and none is provided
|
|
|
|
ErrRequireAuth = fmt.Errorf("Remote server requires authentication")
|
|
|
|
|
|
|
|
// ErrInvalidAuth is used if we provide authentication which
|
|
|
|
// is not valid
|
|
|
|
ErrInvalidAuth = fmt.Errorf("Invalid authentication")
|
|
|
|
|
|
|
|
// ErrRemoteInternal is used if we get an internal error
|
|
|
|
// from the remote server
|
|
|
|
ErrRemoteInternal = fmt.Errorf("Remote server reporting internal error")
|
2014-10-06 19:50:09 -05:00
|
|
|
)
|
|
|
|
|
2014-12-03 22:05:29 -06:00
|
|
|
type RemoteClient interface {
|
|
|
|
GetState() (*RemoteStatePayload, error)
|
|
|
|
PutState(state []byte, force bool) error
|
|
|
|
DeleteState() error
|
|
|
|
}
|
|
|
|
|
2014-10-02 13:48:11 -05:00
|
|
|
// RemoteStatePayload is used to return the remote state
|
|
|
|
// along with associated meta data when we do a remote fetch.
|
|
|
|
type RemoteStatePayload struct {
|
2014-10-03 13:14:12 -05:00
|
|
|
MD5 []byte
|
|
|
|
State []byte
|
2014-10-02 13:48:11 -05:00
|
|
|
}
|
|
|
|
|
2014-12-04 18:57:11 -06:00
|
|
|
// NewClientByState is used to construct a client from
|
|
|
|
// our remote state.
|
|
|
|
func NewClientByState(remote *terraform.RemoteState) (RemoteClient, error) {
|
|
|
|
return NewClientByType(remote.Type, remote.Config)
|
|
|
|
}
|
|
|
|
|
2014-12-03 22:05:29 -06:00
|
|
|
// NewClientByType is used to construct a RemoteClient
|
|
|
|
// based on the configured type.
|
|
|
|
func NewClientByType(ctype string, conf map[string]string) (RemoteClient, error) {
|
|
|
|
ctype = strings.ToLower(ctype)
|
|
|
|
switch ctype {
|
|
|
|
case "atlas":
|
|
|
|
return NewAtlasRemoteClient(conf)
|
|
|
|
case "consul":
|
|
|
|
return NewConsulRemoteClient(conf)
|
|
|
|
case "http":
|
|
|
|
return NewHTTPRemoteClient(conf)
|
2014-10-06 19:50:09 -05:00
|
|
|
default:
|
2014-12-03 22:05:29 -06:00
|
|
|
return nil, fmt.Errorf("Unknown remote client type '%s'", ctype)
|
2014-10-06 19:50:09 -05:00
|
|
|
}
|
|
|
|
}
|