Merge pull request #440 from jrperritt/block-storage-id-by-name
IDFromName functions for block storage
diff --git a/openstack/blockstorage/v1/snapshots/requests.go b/openstack/blockstorage/v1/snapshots/requests.go
index d2f10aa..71936e5 100644
--- a/openstack/blockstorage/v1/snapshots/requests.go
+++ b/openstack/blockstorage/v1/snapshots/requests.go
@@ -171,3 +171,36 @@
})
return res
}
+
+// IDFromName is a convienience function that returns a snapshot's ID given its name.
+func IDFromName(client *gophercloud.ServiceClient, name string) (string, error) {
+ snapshotCount := 0
+ snapshotID := ""
+ if name == "" {
+ return "", fmt.Errorf("A snapshot name must be provided.")
+ }
+ pager := List(client, nil)
+ pager.EachPage(func(page pagination.Page) (bool, error) {
+ snapshotList, err := ExtractSnapshots(page)
+ if err != nil {
+ return false, err
+ }
+
+ for _, s := range snapshotList {
+ if s.Name == name {
+ snapshotCount++
+ snapshotID = s.ID
+ }
+ }
+ return true, nil
+ })
+
+ switch snapshotCount {
+ case 0:
+ return "", fmt.Errorf("Unable to find snapshot: %s", name)
+ case 1:
+ return snapshotID, nil
+ default:
+ return "", fmt.Errorf("Found %d snapshots matching %s", snapshotCount, name)
+ }
+}
diff --git a/openstack/blockstorage/v1/volumes/requests.go b/openstack/blockstorage/v1/volumes/requests.go
index 253aaf7..3e9243a 100644
--- a/openstack/blockstorage/v1/volumes/requests.go
+++ b/openstack/blockstorage/v1/volumes/requests.go
@@ -201,3 +201,36 @@
})
return res
}
+
+// IDFromName is a convienience function that returns a server's ID given its name.
+func IDFromName(client *gophercloud.ServiceClient, name string) (string, error) {
+ volumeCount := 0
+ volumeID := ""
+ if name == "" {
+ return "", fmt.Errorf("A volume name must be provided.")
+ }
+ pager := List(client, nil)
+ pager.EachPage(func(page pagination.Page) (bool, error) {
+ volumeList, err := ExtractVolumes(page)
+ if err != nil {
+ return false, err
+ }
+
+ for _, s := range volumeList {
+ if s.Name == name {
+ volumeCount++
+ volumeID = s.ID
+ }
+ }
+ return true, nil
+ })
+
+ switch volumeCount {
+ case 0:
+ return "", fmt.Errorf("Unable to find volume: %s", name)
+ case 1:
+ return volumeID, nil
+ default:
+ return "", fmt.Errorf("Found %d volumes matching %s", volumeCount, name)
+ }
+}