From 8581943ac0b07a9dc95481bebfd726ac4c60cab3 Mon Sep 17 00:00:00 2001 From: Achyuta Date: Tue, 27 Aug 2024 14:30:47 +0530 Subject: [PATCH] volume: field for external vol import --- v1/api/swagger/components/schemas/Volume.yaml | 26 +++++++++++++++++++ v1/pkg/client/api/openapi.yaml | 24 +++++++++++++++++ v1/pkg/client/docs/Volume.md | 4 +++ v1/pkg/client/docs/VolumeAllOf.md | 4 +++ v1/pkg/client/model_volume.go | 8 ++++++ v1/pkg/client/model_volume_all_of.go | 8 ++++++ 6 files changed, 74 insertions(+) diff --git a/v1/api/swagger/components/schemas/Volume.yaml b/v1/api/swagger/components/schemas/Volume.yaml index f831610d..b1f071e2 100644 --- a/v1/api/swagger/components/schemas/Volume.yaml +++ b/v1/api/swagger/components/schemas/Volume.yaml @@ -6,6 +6,7 @@ allOf: - FlavorID - StoragePoolID - Capacity + - CapacityUsed - Shareable - LocationID - State @@ -13,6 +14,10 @@ allOf: - Status - Labels - WWN + - UnmanagedVolume + - ActiveSite + - CreatedSite + properties: Description: type: string @@ -35,6 +40,12 @@ allOf: example: 10485760 minimum: 0 description: The size of the volume in KiB + CapacityUsed: + type: integer + format: int64 + example: 10485760 + minimum: 0 + description: The amount of the volume currently used as reported by the array in KiB Shareable: type: boolean description: Indicates if the volume can be attached to multiple hosts @@ -63,3 +74,18 @@ allOf: WWN: type: string description: Serial number of the volume. + ActiveSite: + type: string + format: uuid + description: >- + The site where the remote copy role for the volume is + Primary at the time of most recent import. + CreatedSite: + type: string + format: uuid + description: >- + The site where the volume was originally created. + UnmanagedVolume: + type: boolean + description: Indicates whether the volume is a native Metal created one or an external one. + diff --git a/v1/pkg/client/api/openapi.yaml b/v1/pkg/client/api/openapi.yaml index 62041f84..e7736125 100644 --- a/v1/pkg/client/api/openapi.yaml +++ b/v1/pkg/client/api/openapi.yaml @@ -7111,6 +7111,13 @@ components: format: int64 minimum: 0 type: integer + CapacityUsed: + description: The amount of the volume currently used as reported by the + array in KiB + example: 10485760 + format: int64 + minimum: 0 + type: integer Shareable: description: Indicates if the volume can be attached to multiple hosts type: boolean @@ -7143,8 +7150,24 @@ components: WWN: description: Serial number of the volume. type: string + ActiveSite: + description: The site where the remote copy role for the volume is Primary + at the time of most recent import. + format: uuid + type: string + CreatedSite: + description: The site where the volume was originally created. + format: uuid + type: string + UnmanagedVolume: + description: Indicates whether the volume is a native Metal created one + or an external one. + type: boolean required: + - ActiveSite - Capacity + - CapacityUsed + - CreatedSite - Description - FlavorID - Labels @@ -7154,6 +7177,7 @@ components: - Status - StoragePoolID - SubState + - UnmanagedVolume - WWN UpdateVolume_allOf: properties: diff --git a/v1/pkg/client/docs/Volume.md b/v1/pkg/client/docs/Volume.md index 334b62f0..334e541b 100644 --- a/v1/pkg/client/docs/Volume.md +++ b/v1/pkg/client/docs/Volume.md @@ -13,6 +13,7 @@ Name | Type | Description | Notes **FlavorID** | **string** | The VolumeFlavorID matching an entry in the VolumeFlavors array returned as part of the get /available-resources call | **StoragePoolID** | **string** | The storage pool ID matching an entry in the StoragePools array returned as part of the get /available-resources call | **Capacity** | **int64** | The size of the volume in KiB | +**CapacityUsed** | **int64** | The amount of the volume currently used as reported by the array in KiB | **Shareable** | **bool** | Indicates if the volume can be attached to multiple hosts | **LocationID** | **string** | The location of the volume (and the storage array) LocationID is one of those listed by the LocationInfo array returned as part of the get /available-resources call. Any volumes must be in the same location as their attached Host. | **VolumeCollectionID** | **string** | The optional volume collection ID matching an entry in the VolumeCollections array returned as part of the get /available-resources call | [optional] @@ -21,6 +22,9 @@ Name | Type | Description | Notes **Status** | [**VolumeStatus**](VolumeStatus.md) | | **Labels** | **map[string]string** | The map of label name to label value for the resource. | **WWN** | **string** | Serial number of the volume. | +**ActiveSite** | **string** | The site where the remote copy role for the volume is Primary at the time of most recent import. | +**CreatedSite** | **string** | The site where the volume was originally created. | +**UnmanagedVolume** | **bool** | Indicates whether the volume is a native Metal created one or an external one. | [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) diff --git a/v1/pkg/client/docs/VolumeAllOf.md b/v1/pkg/client/docs/VolumeAllOf.md index 7001a9bb..cd8ccce8 100644 --- a/v1/pkg/client/docs/VolumeAllOf.md +++ b/v1/pkg/client/docs/VolumeAllOf.md @@ -8,6 +8,7 @@ Name | Type | Description | Notes **FlavorID** | **string** | The VolumeFlavorID matching an entry in the VolumeFlavors array returned as part of the get /available-resources call | **StoragePoolID** | **string** | The storage pool ID matching an entry in the StoragePools array returned as part of the get /available-resources call | **Capacity** | **int64** | The size of the volume in KiB | +**CapacityUsed** | **int64** | The amount of the volume currently used as reported by the array in KiB | **Shareable** | **bool** | Indicates if the volume can be attached to multiple hosts | **LocationID** | **string** | The location of the volume (and the storage array) LocationID is one of those listed by the LocationInfo array returned as part of the get /available-resources call. Any volumes must be in the same location as their attached Host. | **VolumeCollectionID** | **string** | The optional volume collection ID matching an entry in the VolumeCollections array returned as part of the get /available-resources call | [optional] @@ -16,6 +17,9 @@ Name | Type | Description | Notes **Status** | [**VolumeStatus**](VolumeStatus.md) | | **Labels** | **map[string]string** | The map of label name to label value for the resource. | **WWN** | **string** | Serial number of the volume. | +**ActiveSite** | **string** | The site where the remote copy role for the volume is Primary at the time of most recent import. | +**CreatedSite** | **string** | The site where the volume was originally created. | +**UnmanagedVolume** | **bool** | Indicates whether the volume is a native Metal created one or an external one. | [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) diff --git a/v1/pkg/client/model_volume.go b/v1/pkg/client/model_volume.go index f32bd3d0..f7eca571 100644 --- a/v1/pkg/client/model_volume.go +++ b/v1/pkg/client/model_volume.go @@ -32,6 +32,8 @@ type Volume struct { StoragePoolID string `json:"StoragePoolID"` // The size of the volume in KiB Capacity int64 `json:"Capacity"` + // The amount of the volume currently used as reported by the array in KiB + CapacityUsed int64 `json:"CapacityUsed"` // Indicates if the volume can be attached to multiple hosts Shareable bool `json:"Shareable"` // The location of the volume (and the storage array) LocationID is one of those listed by the LocationInfo array returned as part of the get /available-resources call. Any volumes must be in the same location as their attached Host. @@ -45,4 +47,10 @@ type Volume struct { Labels map[string]string `json:"Labels"` // Serial number of the volume. WWN string `json:"WWN"` + // The site where the remote copy role for the volume is Primary at the time of most recent import. + ActiveSite string `json:"ActiveSite"` + // The site where the volume was originally created. + CreatedSite string `json:"CreatedSite"` + // Indicates whether the volume is a native Metal created one or an external one. + UnmanagedVolume bool `json:"UnmanagedVolume"` } diff --git a/v1/pkg/client/model_volume_all_of.go b/v1/pkg/client/model_volume_all_of.go index c1b07f7b..c397ed86 100644 --- a/v1/pkg/client/model_volume_all_of.go +++ b/v1/pkg/client/model_volume_all_of.go @@ -19,6 +19,8 @@ type VolumeAllOf struct { StoragePoolID string `json:"StoragePoolID"` // The size of the volume in KiB Capacity int64 `json:"Capacity"` + // The amount of the volume currently used as reported by the array in KiB + CapacityUsed int64 `json:"CapacityUsed"` // Indicates if the volume can be attached to multiple hosts Shareable bool `json:"Shareable"` // The location of the volume (and the storage array) LocationID is one of those listed by the LocationInfo array returned as part of the get /available-resources call. Any volumes must be in the same location as their attached Host. @@ -32,4 +34,10 @@ type VolumeAllOf struct { Labels map[string]string `json:"Labels"` // Serial number of the volume. WWN string `json:"WWN"` + // The site where the remote copy role for the volume is Primary at the time of most recent import. + ActiveSite string `json:"ActiveSite"` + // The site where the volume was originally created. + CreatedSite string `json:"CreatedSite"` + // Indicates whether the volume is a native Metal created one or an external one. + UnmanagedVolume bool `json:"UnmanagedVolume"` }