disk.go 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287
  1. // Copyright 2019 Yunion
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package bingocloud
  15. import (
  16. "context"
  17. "fmt"
  18. "strconv"
  19. "yunion.io/x/pkg/errors"
  20. api "yunion.io/x/cloudmux/pkg/apis/compute"
  21. "yunion.io/x/cloudmux/pkg/cloudprovider"
  22. "yunion.io/x/cloudmux/pkg/multicloud"
  23. )
  24. type SDisk struct {
  25. BingoTags
  26. multicloud.SDisk
  27. storage *SStorage
  28. AttachmentSet []AttachmentSet `json:"attachmentSet"`
  29. AvailabilityZone string `json:"availabilityZone"`
  30. CreateTime string `json:"createTime"`
  31. Description string `json:"description"`
  32. DetachBehavior string `json:"detachBehavior"`
  33. Goal string `json:"goal"`
  34. Iops string `json:"iops"`
  35. IsDeductQuota string `json:"isDeductQuota"`
  36. IsEncrypt string `json:"isEncrypt"`
  37. IsForSleepInst string `json:"isForSleepInst"`
  38. IsMirrorVolume string `json:"isMirrorVolume"`
  39. IsMultiAttach string `json:"isMultiAttach"`
  40. IsOneInst string `json:"isOneInst"`
  41. IsRoot string `json:"isRoot"`
  42. Location string `json:"location"`
  43. MirrorFrom string `json:"mirrorFrom"`
  44. MirrorProcess string `json:"mirrorProcess"`
  45. MirrorStatus string `json:"mirrorStatus"`
  46. NodeId string `json:"nodeId"`
  47. Owner string `json:"owner"`
  48. Passphrase string `json:"passphrase"`
  49. Readonly string `json:"readonly"`
  50. Size int `json:"size"`
  51. SnapshotId string `json:"snapshotId"`
  52. Status string `json:"status"`
  53. StorageId string `json:"storageId"`
  54. VolumeId string `json:"volumeId"`
  55. VolumeName string `json:"volumeName"`
  56. }
  57. func (self *SDisk) GetISnapshots() ([]cloudprovider.ICloudSnapshot, error) {
  58. snapshots, err := self.storage.cluster.region.getSnapshots("", "")
  59. if err != nil {
  60. return nil, err
  61. }
  62. iSnapshots := make([]cloudprovider.ICloudSnapshot, len(snapshots))
  63. for i := 0; i < len(snapshots); i++ {
  64. snapshots[i].region = self.storage.cluster.region
  65. iSnapshots[i] = &snapshots[i]
  66. }
  67. return iSnapshots, nil
  68. }
  69. type AttachmentSet struct {
  70. AttachTime string `json:"attachTime"`
  71. Cache string `json:"cache"`
  72. DeleteOnTermination string `json:"deleteOnTermination"`
  73. Device string `json:"device"`
  74. InstanceId string `json:"instanceId"`
  75. Status string `json:"status"`
  76. VolumeId string `json:"volumeId"`
  77. }
  78. func (self *SDisk) GetName() string {
  79. return self.VolumeName
  80. }
  81. func (self *SDisk) GetId() string {
  82. return self.VolumeId
  83. }
  84. func (self *SDisk) GetGlobalId() string {
  85. return self.GetId()
  86. }
  87. func (self *SDisk) GetIStorage() (cloudprovider.ICloudStorage, error) {
  88. return self.storage, nil
  89. }
  90. func (self *SDisk) GetIStorageId() string {
  91. return self.StorageId
  92. }
  93. func (self *SDisk) GetDiskFormat() string {
  94. return "raw"
  95. }
  96. func (self *SDisk) GetDiskSizeMB() int {
  97. return self.Size * 1024
  98. }
  99. func (self *SDisk) GetIsAutoDelete() bool {
  100. return self.IsRoot == "true"
  101. }
  102. func (self *SDisk) GetTemplateId() string {
  103. return ""
  104. }
  105. func (self *SDisk) GetDiskType() string {
  106. if self.IsRoot == "true" {
  107. return api.DISK_TYPE_SYS
  108. }
  109. return api.DISK_TYPE_DATA
  110. }
  111. func (self *SDisk) GetFsFormat() string {
  112. return ""
  113. }
  114. func (self *SDisk) GetIsNonPersistent() bool {
  115. return false
  116. }
  117. func (self *SDisk) GetDriver() string {
  118. return "virtio"
  119. }
  120. func (self *SDisk) GetCacheMode() string {
  121. return "none"
  122. }
  123. func (self *SDisk) GetMountpoint() string {
  124. for _, att := range self.AttachmentSet {
  125. return att.Device
  126. }
  127. return ""
  128. }
  129. func (self *SDisk) GetAccessPath() string {
  130. return ""
  131. }
  132. func (self *SDisk) Delete(ctx context.Context) error {
  133. params := map[string]string{}
  134. params["VolumeId"] = self.VolumeId
  135. _, err := self.storage.cluster.region.invoke("DeleteVolume", params)
  136. return err
  137. }
  138. func (self *SDisk) CreateISnapshot(ctx context.Context, name string, desc string) (cloudprovider.ICloudSnapshot, error) {
  139. snapshotId, err := self.storage.cluster.region.createSnapshot(self.VolumeId, name, desc)
  140. if err != nil {
  141. return nil, err
  142. }
  143. return self.storage.cluster.region.GetISnapshotById(snapshotId)
  144. }
  145. func (self *SDisk) Resize(ctx context.Context, newSizeMB int64) error {
  146. return cloudprovider.ErrNotImplemented
  147. }
  148. func (self *SDisk) Reset(ctx context.Context, snapshotId string) (string, error) {
  149. return "", cloudprovider.ErrNotImplemented
  150. }
  151. func (self *SDisk) Rebuild(ctx context.Context) error {
  152. return cloudprovider.ErrNotImplemented
  153. }
  154. func (self *SDisk) GetStatus() string {
  155. switch self.Status {
  156. case "available", "in-use":
  157. return api.DISK_READY
  158. default:
  159. return self.Status
  160. }
  161. }
  162. func (self *SRegion) GetDisks(id string, maxResult int, nextToken string) ([]SDisk, string, error) {
  163. params := map[string]string{}
  164. idx := 1
  165. if len(id) > 0 {
  166. params[fmt.Sprintf("Filter.%d.Name", idx)] = "volume-id"
  167. params[fmt.Sprintf("Filter.%d.Value.1", idx)] = id
  168. idx++
  169. }
  170. if len(nextToken) > 0 {
  171. params["NextToken"] = nextToken
  172. }
  173. if maxResult > 0 {
  174. params["MaxRecords"] = fmt.Sprintf("%d", maxResult)
  175. }
  176. resp, err := self.invoke("DescribeVolumes", params)
  177. if err != nil {
  178. return nil, "", err
  179. }
  180. ret := struct {
  181. NextToken string
  182. VolumeSet []SDisk
  183. }{}
  184. _ = resp.Unmarshal(&ret)
  185. return ret.VolumeSet, ret.NextToken, nil
  186. }
  187. func (self *SStorage) GetIDisks() ([]cloudprovider.ICloudDisk, error) {
  188. part, nextToken, err := self.cluster.region.GetDisks("", MAX_RESULT, "")
  189. if err != nil {
  190. return nil, err
  191. }
  192. var disks []SDisk
  193. disks = append(disks, part...)
  194. for len(nextToken) > 0 {
  195. part, nextToken, err = self.cluster.region.GetDisks("", MAX_RESULT, nextToken)
  196. if err != nil {
  197. return nil, err
  198. }
  199. disks = append(disks, part...)
  200. }
  201. var ret []cloudprovider.ICloudDisk
  202. for i := range disks {
  203. if disks[i].StorageId == self.StorageId {
  204. disks[i].storage = self
  205. ret = append(ret, &disks[i])
  206. }
  207. }
  208. return ret, nil
  209. }
  210. func (self *SStorage) GetIDiskById(id string) (cloudprovider.ICloudDisk, error) {
  211. disk, err := self.cluster.region.GetDisk(id)
  212. if err != nil {
  213. return nil, err
  214. }
  215. if disk.StorageId != self.StorageId {
  216. return nil, cloudprovider.ErrNotFound
  217. }
  218. disk.storage = self
  219. return disk, nil
  220. }
  221. func (self *SRegion) GetDisk(id string) (*SDisk, error) {
  222. disks, _, err := self.GetDisks(id, 1, "")
  223. if err != nil {
  224. return nil, err
  225. }
  226. for i := range disks {
  227. if disks[i].GetGlobalId() == id {
  228. return &disks[i], nil
  229. }
  230. }
  231. return nil, errors.Wrapf(cloudprovider.ErrNotFound, "%s", id)
  232. }
  233. func (self *SStorage) CreateIDisk(conf *cloudprovider.DiskCreateConfig) (cloudprovider.ICloudDisk, error) {
  234. params := map[string]string{}
  235. params["VolumeName"] = conf.Name
  236. params["AvailabilityZone"] = self.cluster.ClusterId
  237. params["Size"] = strconv.Itoa(conf.SizeGb)
  238. resp, err := self.cluster.region.invoke("CreateVolume", params)
  239. if err != nil {
  240. return nil, err
  241. }
  242. ret := &SDisk{}
  243. _ = resp.Unmarshal(&ret)
  244. return ret, nil
  245. }