1.5.8-k8s-extnet-branch
stSolo 2 years ago
parent 7ddd8c5fbe
commit cc9aa2a6fc

@ -2,7 +2,11 @@
### Features
<<<<<<< CHANGELOG.md
#### CloudAPI
=======
## CloudAPI
>>>>>>> CHANGELOG.md
- Account
- Delete "ResTypes" field in Create/Update request structs
@ -15,6 +19,10 @@
- Disks
- Add fields "PresentTo", "Shareable", "Computes" in Get/List/ListDeleted/ListUnattached/Search response structs
- Delete fields "ComputeID", "ComputeName" in List/ListDeleted/ListUnattached/Search response structs
<<<<<<< CHANGELOG.md
- Add Share/Unshare methods
=======
>>>>>>> CHANGELOG.md
- FLIPgroup
- Add field "ClientNames" in Get response struct
- Image
@ -23,7 +31,11 @@
- Delete "ResTypes" field in Create/Update request structs
- Add fields "DiskSizeMax", "Shareable", "SEPs" in Get/List response structs
<<<<<<< CHANGELOG.md
#### Cloudbroker
=======
## Cloudbroker
>>>>>>> CHANGELOG.md
- Account
- Add fields "SEPs", "ResourceTypes", "PresentTo", "DiskSizeMax", "UniqPools", "Shareable" in Get/List/ListDeleted/ListDisks/ListRG response structs
@ -32,6 +44,10 @@
- Disks
- Add fields "ReferenceID", "Shareable", "PresentTo", "Computes" in List/ListDeleted/ListUnattached/Search response structs
- Delete fields "ComputeID", "ComputeName" in List/ListDeleted/ListUnattached/Search response structs
<<<<<<< CHANGELOG.md
- Add Share/Unshare methods
=======
>>>>>>> CHANGELOG.md
- Grid
- Add fields "SEPs", "DiskSizeMax" in Get/List response structs
- Image
@ -44,3 +60,7 @@
- Delete field "IPAddr" in MassCreate request struct
- RG
- Add fields "DiskSizeMax", "Shareable", "SEPs" in Get/List response structs
<<<<<<< CHANGELOG.md
=======
>>>>>>> CHANGELOG.md

@ -0,0 +1,45 @@
package disks
import (
"context"
"errors"
"net/http"
"strconv"
)
// Request struct for share data disk
type ShareRequest struct {
// ID of the disk to share
// Required: true
DiskID uint64 `url:"diskId"`
}
func (drq ShareRequest) validate() error {
if drq.DiskID == 0 {
return errors.New("validation-error: field DiskID can not be empty or equal to 0")
}
return nil
}
// Share shares data disk
func (d Disks) Share(ctx context.Context, req ShareRequest) (bool, error) {
err := req.validate()
if err != nil {
return false, err
}
url := "/cloudbroker/disks/share"
res, err := d.client.DecortApiCall(ctx, http.MethodPost, url, req)
if err != nil {
return false, err
}
result, err := strconv.ParseBool(string(res))
if err != nil {
return false, err
}
return result, nil
}

@ -0,0 +1,45 @@
package disks
import (
"context"
"errors"
"net/http"
"strconv"
)
// Request struct for unshare data disk
type UnshareRequest struct {
// ID of the disk to unshare
// Required: true
DiskID uint64 `url:"diskId"`
}
func (drq UnshareRequest) validate() error {
if drq.DiskID == 0 {
return errors.New("validation-error: field DiskID can not be empty or equal to 0")
}
return nil
}
// Unshare unshares data disk
func (d Disks) Unshare(ctx context.Context, req UnshareRequest) (bool, error) {
err := req.validate()
if err != nil {
return false, err
}
url := "/cloudbroker/disks/unshare"
res, err := d.client.DecortApiCall(ctx, http.MethodPost, url, req)
if err != nil {
return false, err
}
result, err := strconv.ParseBool(string(res))
if err != nil {
return false, err
}
return result, nil
}
Loading…
Cancel
Save