2016-03-22 18:41:02 +01:00
|
|
|
package command
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/hashicorp/terraform/terraform"
|
|
|
|
"github.com/mitchellh/cli"
|
|
|
|
)
|
|
|
|
|
|
|
|
// StateListCommand is a Command implementation that lists the resources
|
|
|
|
// within a state file.
|
|
|
|
type StateListCommand struct {
|
2017-02-28 19:13:03 +01:00
|
|
|
StateMeta
|
2016-03-22 18:41:02 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (c *StateListCommand) Run(args []string) int {
|
|
|
|
args = c.Meta.process(args, true)
|
|
|
|
|
|
|
|
cmdFlags := c.Meta.flagSet("state list")
|
|
|
|
cmdFlags.StringVar(&c.Meta.statePath, "state", DefaultStateFilename, "path")
|
|
|
|
if err := cmdFlags.Parse(args); err != nil {
|
|
|
|
return cli.RunResultHelp
|
|
|
|
}
|
|
|
|
args = cmdFlags.Args()
|
|
|
|
|
2017-01-19 05:50:45 +01:00
|
|
|
// Load the backend
|
|
|
|
b, err := c.Backend(nil)
|
2016-03-22 18:41:02 +01:00
|
|
|
if err != nil {
|
2017-01-19 05:50:45 +01:00
|
|
|
c.Ui.Error(fmt.Sprintf("Failed to load backend: %s", err))
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
2017-02-28 19:13:03 +01:00
|
|
|
env := c.Env()
|
2017-01-19 05:50:45 +01:00
|
|
|
// Get the state
|
2017-02-28 19:13:03 +01:00
|
|
|
state, err := b.State(env)
|
2017-01-19 05:50:45 +01:00
|
|
|
if err != nil {
|
|
|
|
c.Ui.Error(fmt.Sprintf("Failed to load state: %s", err))
|
|
|
|
return 1
|
2016-03-22 18:41:02 +01:00
|
|
|
}
|
|
|
|
|
2017-02-22 05:35:43 +01:00
|
|
|
if err := state.RefreshState(); err != nil {
|
|
|
|
c.Ui.Error(fmt.Sprintf("Failed to load state: %s", err))
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
2016-03-22 18:41:02 +01:00
|
|
|
stateReal := state.State()
|
|
|
|
if stateReal == nil {
|
|
|
|
c.Ui.Error(fmt.Sprintf(errStateNotFound))
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
|
|
|
filter := &terraform.StateFilter{State: stateReal}
|
|
|
|
results, err := filter.Filter(args...)
|
|
|
|
if err != nil {
|
|
|
|
c.Ui.Error(fmt.Sprintf(errStateFilter, err))
|
|
|
|
return cli.RunResultHelp
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, result := range results {
|
|
|
|
if _, ok := result.Value.(*terraform.InstanceState); ok {
|
|
|
|
c.Ui.Output(result.Address)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *StateListCommand) Help() string {
|
|
|
|
helpText := `
|
2016-03-22 18:41:02 +01:00
|
|
|
Usage: terraform state list [options] [pattern...]
|
2016-03-22 18:41:02 +01:00
|
|
|
|
|
|
|
List resources in the Terraform state.
|
|
|
|
|
2016-03-22 18:41:02 +01:00
|
|
|
This command lists resources in the Terraform state. The pattern argument
|
|
|
|
can be used to filter the resources by resource or module. If no pattern
|
2016-03-22 18:41:02 +01:00
|
|
|
is given, all resources are listed.
|
|
|
|
|
2016-03-22 18:41:02 +01:00
|
|
|
The pattern argument is meant to provide very simple filtering. For
|
2016-03-22 18:41:02 +01:00
|
|
|
advanced filtering, please use tools such as "grep". The output of this
|
|
|
|
command is designed to be friendly for this usage.
|
|
|
|
|
2016-03-22 18:41:02 +01:00
|
|
|
The pattern argument accepts any resource targeting syntax. Please
|
2016-03-22 18:41:02 +01:00
|
|
|
refer to the documentation on resource targeting syntax for more
|
|
|
|
information.
|
|
|
|
|
|
|
|
Options:
|
|
|
|
|
|
|
|
-state=statefile Path to a Terraform state file to use to look
|
|
|
|
up Terraform-managed resources. By default it will
|
|
|
|
use the state "terraform.tfstate" if it exists.
|
|
|
|
|
|
|
|
`
|
|
|
|
return strings.TrimSpace(helpText)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *StateListCommand) Synopsis() string {
|
|
|
|
return "List resources in the state"
|
|
|
|
}
|
|
|
|
|
|
|
|
const errStateFilter = `Error filtering state: %[1]s
|
|
|
|
|
|
|
|
Please ensure that all your addresses are formatted properly.`
|
|
|
|
|
|
|
|
const errStateLoadingState = `Error loading the state: %[1]s
|
|
|
|
|
|
|
|
Please ensure that your Terraform state exists and that you've
|
|
|
|
configured it properly. You can use the "-state" flag to point
|
|
|
|
Terraform at another state file.`
|
|
|
|
|
|
|
|
const errStateNotFound = `No state file was found!
|
|
|
|
|
|
|
|
State management commands require a state file. Run this command
|
|
|
|
in a directory where Terraform has been run or use the -state flag
|
|
|
|
to point the command to a specific state location.`
|