2015-01-26 22:17:52 -06:00
|
|
|
package terraform
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/hashicorp/terraform/config"
|
|
|
|
)
|
|
|
|
|
|
|
|
// OrphanTransformer is a GraphTransformer that adds orphans to the
|
|
|
|
// graph. This transformer adds both resource and module orphans.
|
|
|
|
type OrphanTransformer struct {
|
2015-01-26 23:32:32 -06:00
|
|
|
// State is the global state. We require the global state to
|
|
|
|
// properly find module orphans at our path.
|
|
|
|
State *State
|
|
|
|
|
|
|
|
// Config is just the configuration of our current module.
|
2015-01-26 22:17:52 -06:00
|
|
|
Config *config.Config
|
|
|
|
}
|
|
|
|
|
2015-01-26 23:23:27 -06:00
|
|
|
func (t *OrphanTransformer) Transform(g *Graph) error {
|
2015-01-26 23:32:32 -06:00
|
|
|
state := t.State.ModuleByPath(g.Path)
|
|
|
|
if state == nil {
|
|
|
|
// If there is no state for our module, there can't be any orphans
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2015-01-26 22:17:52 -06:00
|
|
|
// Get the orphans from our configuration. This will only get resources.
|
2015-01-26 23:32:32 -06:00
|
|
|
orphans := state.Orphans(t.Config)
|
2015-01-26 22:17:52 -06:00
|
|
|
if len(orphans) == 0 {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Go over each orphan and add it to the graph.
|
|
|
|
for _, k := range orphans {
|
2015-01-26 23:23:27 -06:00
|
|
|
g.ConnectTo(
|
|
|
|
g.Add(&graphNodeOrphanResource{ResourceName: k}),
|
2015-01-26 23:32:32 -06:00
|
|
|
state.Resources[k].Dependencies)
|
2015-01-26 22:17:52 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: modules
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// graphNodeOrphan is the graph vertex representing an orphan resource..
|
|
|
|
type graphNodeOrphanResource struct {
|
|
|
|
ResourceName string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (n *graphNodeOrphanResource) Name() string {
|
|
|
|
return fmt.Sprintf("%s (orphan)", n.ResourceName)
|
|
|
|
}
|