Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 1 | package stacks |
| 2 | |
| 3 | import ( |
Jon Perritt | 3d381d5 | 2015-02-09 13:04:48 -0700 | [diff] [blame] | 4 | "encoding/json" |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 5 | "time" |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 6 | |
Krzysztof Szukiełojć | 3f41d08 | 2017-05-07 14:43:06 +0200 | [diff] [blame] | 7 | "gerrit.mcp.mirantis.net/debian/gophercloud.git" |
Krzysztof Szukiełojć | 24a29ce | 2017-05-07 14:24:02 +0200 | [diff] [blame] | 8 | "gerrit.mcp.mirantis.net/debian/gophercloud.git/pagination" |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 9 | ) |
| 10 | |
Jon Perritt | 7726e49 | 2015-02-04 17:54:28 -0700 | [diff] [blame] | 11 | // CreatedStack represents the object extracted from a Create operation. |
Jon Perritt | 01972e2 | 2015-01-28 10:30:45 -0700 | [diff] [blame] | 12 | type CreatedStack struct { |
Jon Perritt | 3c16647 | 2016-02-25 03:07:41 -0600 | [diff] [blame] | 13 | ID string `json:"id"` |
| 14 | Links []gophercloud.Link `json:"links"` |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 15 | } |
| 16 | |
Jon Perritt | 7726e49 | 2015-02-04 17:54:28 -0700 | [diff] [blame] | 17 | // CreateResult represents the result of a Create operation. |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 18 | type CreateResult struct { |
| 19 | gophercloud.Result |
| 20 | } |
| 21 | |
Jon Perritt | 7726e49 | 2015-02-04 17:54:28 -0700 | [diff] [blame] | 22 | // Extract returns a pointer to a CreatedStack object and is called after a |
| 23 | // Create operation. |
Jon Perritt | 22325f4 | 2015-01-29 14:48:18 -0700 | [diff] [blame] | 24 | func (r CreateResult) Extract() (*CreatedStack, error) { |
Jon Perritt | 3c16647 | 2016-02-25 03:07:41 -0600 | [diff] [blame] | 25 | var s struct { |
| 26 | CreatedStack *CreatedStack `json:"stack"` |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 27 | } |
Jon Perritt | 3c16647 | 2016-02-25 03:07:41 -0600 | [diff] [blame] | 28 | err := r.ExtractInto(&s) |
| 29 | return s.CreatedStack, err |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 30 | } |
| 31 | |
Jon Perritt | 7726e49 | 2015-02-04 17:54:28 -0700 | [diff] [blame] | 32 | // AdoptResult represents the result of an Adopt operation. AdoptResult has the |
| 33 | // same form as CreateResult. |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 34 | type AdoptResult struct { |
Jon Perritt | 9741dd9 | 2015-02-04 12:05:47 -0700 | [diff] [blame] | 35 | CreateResult |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 36 | } |
| 37 | |
| 38 | // StackPage is a pagination.Pager that is returned from a call to the List function. |
| 39 | type StackPage struct { |
| 40 | pagination.SinglePageBase |
| 41 | } |
| 42 | |
| 43 | // IsEmpty returns true if a ListResult contains no Stacks. |
| 44 | func (r StackPage) IsEmpty() (bool, error) { |
| 45 | stacks, err := ExtractStacks(r) |
Jon Perritt | 3c16647 | 2016-02-25 03:07:41 -0600 | [diff] [blame] | 46 | return len(stacks) == 0, err |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 47 | } |
| 48 | |
Jon Perritt | 7726e49 | 2015-02-04 17:54:28 -0700 | [diff] [blame] | 49 | // ListedStack represents an element in the slice extracted from a List operation. |
Jon Perritt | 01972e2 | 2015-01-28 10:30:45 -0700 | [diff] [blame] | 50 | type ListedStack struct { |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 51 | CreationTime time.Time `json:"-"` |
| 52 | Description string `json:"description"` |
| 53 | ID string `json:"id"` |
| 54 | Links []gophercloud.Link `json:"links"` |
| 55 | Name string `json:"stack_name"` |
| 56 | Status string `json:"stack_status"` |
| 57 | StatusReason string `json:"stack_status_reason"` |
| 58 | Tags []string `json:"tags"` |
| 59 | UpdatedTime time.Time `json:"-"` |
| 60 | } |
| 61 | |
| 62 | func (r *ListedStack) UnmarshalJSON(b []byte) error { |
| 63 | type tmp ListedStack |
| 64 | var s struct { |
| 65 | tmp |
Ildar Svetlov | d213969 | 2020-11-10 15:16:16 +0400 | [diff] [blame] | 66 | CreationTime string `json:"creation_time"` |
| 67 | UpdatedTime string `json:"updated_time"` |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 68 | } |
Ildar Svetlov | d213969 | 2020-11-10 15:16:16 +0400 | [diff] [blame] | 69 | |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 70 | err := json.Unmarshal(b, &s) |
| 71 | if err != nil { |
| 72 | return err |
| 73 | } |
Ildar Svetlov | d213969 | 2020-11-10 15:16:16 +0400 | [diff] [blame] | 74 | |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 75 | *r = ListedStack(s.tmp) |
| 76 | |
Ildar Svetlov | d213969 | 2020-11-10 15:16:16 +0400 | [diff] [blame] | 77 | if s.CreationTime != "" { |
| 78 | t, err := time.Parse(time.RFC3339, s.CreationTime) |
| 79 | if err != nil { |
| 80 | t, err = time.Parse(gophercloud.RFC3339NoZ, s.CreationTime) |
| 81 | if err != nil { |
| 82 | return err |
| 83 | } |
| 84 | } |
| 85 | r.CreationTime = t |
| 86 | } |
| 87 | |
| 88 | if s.UpdatedTime != "" { |
| 89 | t, err := time.Parse(time.RFC3339, s.UpdatedTime) |
| 90 | if err != nil { |
| 91 | t, err = time.Parse(gophercloud.RFC3339NoZ, s.UpdatedTime) |
| 92 | if err != nil { |
| 93 | return err |
| 94 | } |
| 95 | } |
| 96 | r.UpdatedTime = t |
| 97 | } |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 98 | |
| 99 | return nil |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 100 | } |
| 101 | |
Jon Perritt | 7726e49 | 2015-02-04 17:54:28 -0700 | [diff] [blame] | 102 | // ExtractStacks extracts and returns a slice of ListedStack. It is used while iterating |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 103 | // over a stacks.List call. |
Jon Perritt | 3c16647 | 2016-02-25 03:07:41 -0600 | [diff] [blame] | 104 | func ExtractStacks(r pagination.Page) ([]ListedStack, error) { |
| 105 | var s struct { |
| 106 | ListedStacks []ListedStack `json:"stacks"` |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 107 | } |
Jon Perritt | 3c16647 | 2016-02-25 03:07:41 -0600 | [diff] [blame] | 108 | err := (r.(StackPage)).ExtractInto(&s) |
| 109 | return s.ListedStacks, err |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 110 | } |
| 111 | |
Jon Perritt | 7726e49 | 2015-02-04 17:54:28 -0700 | [diff] [blame] | 112 | // RetrievedStack represents the object extracted from a Get operation. |
Jon Perritt | 01972e2 | 2015-01-28 10:30:45 -0700 | [diff] [blame] | 113 | type RetrievedStack struct { |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 114 | Capabilities []interface{} `json:"capabilities"` |
| 115 | CreationTime time.Time `json:"-"` |
| 116 | Description string `json:"description"` |
| 117 | DisableRollback bool `json:"disable_rollback"` |
| 118 | ID string `json:"id"` |
| 119 | Links []gophercloud.Link `json:"links"` |
| 120 | NotificationTopics []interface{} `json:"notification_topics"` |
| 121 | Outputs []map[string]interface{} `json:"outputs"` |
| 122 | Parameters map[string]string `json:"parameters"` |
| 123 | Name string `json:"stack_name"` |
| 124 | Status string `json:"stack_status"` |
| 125 | StatusReason string `json:"stack_status_reason"` |
| 126 | Tags []string `json:"tags"` |
| 127 | TemplateDescription string `json:"template_description"` |
| 128 | Timeout int `json:"timeout_mins"` |
| 129 | UpdatedTime time.Time `json:"-"` |
| 130 | } |
| 131 | |
| 132 | func (r *RetrievedStack) UnmarshalJSON(b []byte) error { |
| 133 | type tmp RetrievedStack |
| 134 | var s struct { |
| 135 | tmp |
Ildar Svetlov | d213969 | 2020-11-10 15:16:16 +0400 | [diff] [blame] | 136 | CreationTime string `json:"creation_time"` |
| 137 | UpdatedTime string `json:"updated_time"` |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 138 | } |
Ildar Svetlov | d213969 | 2020-11-10 15:16:16 +0400 | [diff] [blame] | 139 | |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 140 | err := json.Unmarshal(b, &s) |
| 141 | if err != nil { |
| 142 | return err |
| 143 | } |
Ildar Svetlov | d213969 | 2020-11-10 15:16:16 +0400 | [diff] [blame] | 144 | |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 145 | *r = RetrievedStack(s.tmp) |
| 146 | |
Ildar Svetlov | d213969 | 2020-11-10 15:16:16 +0400 | [diff] [blame] | 147 | if s.CreationTime != "" { |
| 148 | t, err := time.Parse(time.RFC3339, s.CreationTime) |
| 149 | if err != nil { |
| 150 | t, err = time.Parse(gophercloud.RFC3339NoZ, s.CreationTime) |
| 151 | if err != nil { |
| 152 | return err |
| 153 | } |
| 154 | } |
| 155 | r.CreationTime = t |
| 156 | } |
| 157 | |
| 158 | if s.UpdatedTime != "" { |
| 159 | t, err := time.Parse(time.RFC3339, s.UpdatedTime) |
| 160 | if err != nil { |
| 161 | t, err = time.Parse(gophercloud.RFC3339NoZ, s.UpdatedTime) |
| 162 | if err != nil { |
| 163 | return err |
| 164 | } |
| 165 | } |
| 166 | r.UpdatedTime = t |
| 167 | } |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 168 | |
| 169 | return nil |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 170 | } |
| 171 | |
Jon Perritt | 7726e49 | 2015-02-04 17:54:28 -0700 | [diff] [blame] | 172 | // GetResult represents the result of a Get operation. |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 173 | type GetResult struct { |
| 174 | gophercloud.Result |
| 175 | } |
| 176 | |
Jon Perritt | 7726e49 | 2015-02-04 17:54:28 -0700 | [diff] [blame] | 177 | // Extract returns a pointer to a RetrievedStack object and is called after a |
| 178 | // Get operation. |
Jon Perritt | 22325f4 | 2015-01-29 14:48:18 -0700 | [diff] [blame] | 179 | func (r GetResult) Extract() (*RetrievedStack, error) { |
Jon Perritt | 3c16647 | 2016-02-25 03:07:41 -0600 | [diff] [blame] | 180 | var s struct { |
| 181 | Stack *RetrievedStack `json:"stack"` |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 182 | } |
Jon Perritt | 3c16647 | 2016-02-25 03:07:41 -0600 | [diff] [blame] | 183 | err := r.ExtractInto(&s) |
| 184 | return s.Stack, err |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 185 | } |
| 186 | |
Jon Perritt | 7726e49 | 2015-02-04 17:54:28 -0700 | [diff] [blame] | 187 | // UpdateResult represents the result of a Update operation. |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 188 | type UpdateResult struct { |
| 189 | gophercloud.ErrResult |
| 190 | } |
| 191 | |
Jon Perritt | 7726e49 | 2015-02-04 17:54:28 -0700 | [diff] [blame] | 192 | // DeleteResult represents the result of a Delete operation. |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 193 | type DeleteResult struct { |
| 194 | gophercloud.ErrResult |
| 195 | } |
| 196 | |
Jon Perritt | 37f9774 | 2015-02-04 18:55:05 -0700 | [diff] [blame] | 197 | // PreviewedStack represents the result of a Preview operation. |
Jon Perritt | 01972e2 | 2015-01-28 10:30:45 -0700 | [diff] [blame] | 198 | type PreviewedStack struct { |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 199 | Capabilities []interface{} `json:"capabilities"` |
| 200 | CreationTime time.Time `json:"-"` |
| 201 | Description string `json:"description"` |
| 202 | DisableRollback bool `json:"disable_rollback"` |
| 203 | ID string `json:"id"` |
| 204 | Links []gophercloud.Link `json:"links"` |
| 205 | Name string `json:"stack_name"` |
| 206 | NotificationTopics []interface{} `json:"notification_topics"` |
| 207 | Parameters map[string]string `json:"parameters"` |
| 208 | Resources []interface{} `json:"resources"` |
| 209 | TemplateDescription string `json:"template_description"` |
| 210 | Timeout int `json:"timeout_mins"` |
| 211 | UpdatedTime time.Time `json:"-"` |
| 212 | } |
| 213 | |
| 214 | func (r *PreviewedStack) UnmarshalJSON(b []byte) error { |
| 215 | type tmp PreviewedStack |
| 216 | var s struct { |
| 217 | tmp |
Ildar Svetlov | d213969 | 2020-11-10 15:16:16 +0400 | [diff] [blame] | 218 | CreationTime string `json:"creation_time"` |
| 219 | UpdatedTime string `json:"updated_time"` |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 220 | } |
Ildar Svetlov | d213969 | 2020-11-10 15:16:16 +0400 | [diff] [blame] | 221 | |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 222 | err := json.Unmarshal(b, &s) |
| 223 | if err != nil { |
| 224 | return err |
| 225 | } |
Ildar Svetlov | d213969 | 2020-11-10 15:16:16 +0400 | [diff] [blame] | 226 | |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 227 | *r = PreviewedStack(s.tmp) |
| 228 | |
Ildar Svetlov | d213969 | 2020-11-10 15:16:16 +0400 | [diff] [blame] | 229 | if s.CreationTime != "" { |
| 230 | t, err := time.Parse(time.RFC3339, s.CreationTime) |
| 231 | if err != nil { |
| 232 | t, err = time.Parse(gophercloud.RFC3339NoZ, s.CreationTime) |
| 233 | if err != nil { |
| 234 | return err |
| 235 | } |
| 236 | } |
| 237 | r.CreationTime = t |
| 238 | } |
| 239 | |
| 240 | if s.UpdatedTime != "" { |
| 241 | t, err := time.Parse(time.RFC3339, s.UpdatedTime) |
| 242 | if err != nil { |
| 243 | t, err = time.Parse(gophercloud.RFC3339NoZ, s.UpdatedTime) |
| 244 | if err != nil { |
| 245 | return err |
| 246 | } |
| 247 | } |
| 248 | r.UpdatedTime = t |
| 249 | } |
jrperritt | 98d0162 | 2017-01-12 14:24:42 -0600 | [diff] [blame] | 250 | |
| 251 | return nil |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 252 | } |
| 253 | |
Jon Perritt | 37f9774 | 2015-02-04 18:55:05 -0700 | [diff] [blame] | 254 | // PreviewResult represents the result of a Preview operation. |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 255 | type PreviewResult struct { |
| 256 | gophercloud.Result |
| 257 | } |
| 258 | |
Jon Perritt | 37f9774 | 2015-02-04 18:55:05 -0700 | [diff] [blame] | 259 | // Extract returns a pointer to a PreviewedStack object and is called after a |
| 260 | // Preview operation. |
Jon Perritt | 22325f4 | 2015-01-29 14:48:18 -0700 | [diff] [blame] | 261 | func (r PreviewResult) Extract() (*PreviewedStack, error) { |
Jon Perritt | 3c16647 | 2016-02-25 03:07:41 -0600 | [diff] [blame] | 262 | var s struct { |
| 263 | PreviewedStack *PreviewedStack `json:"stack"` |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 264 | } |
Jon Perritt | 3c16647 | 2016-02-25 03:07:41 -0600 | [diff] [blame] | 265 | err := r.ExtractInto(&s) |
| 266 | return s.PreviewedStack, err |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 267 | } |
| 268 | |
Jon Perritt | 9209df4 | 2015-02-05 12:55:33 -0700 | [diff] [blame] | 269 | // AbandonedStack represents the result of an Abandon operation. |
Jon Perritt | 01972e2 | 2015-01-28 10:30:45 -0700 | [diff] [blame] | 270 | type AbandonedStack struct { |
Jon Perritt | 3c16647 | 2016-02-25 03:07:41 -0600 | [diff] [blame] | 271 | Status string `json:"status"` |
| 272 | Name string `json:"name"` |
| 273 | Template map[string]interface{} `json:"template"` |
| 274 | Action string `json:"action"` |
| 275 | ID string `json:"id"` |
| 276 | Resources map[string]interface{} `json:"resources"` |
| 277 | Files map[string]string `json:"files"` |
| 278 | StackUserProjectID string `json:"stack_user_project_id"` |
| 279 | ProjectID string `json:"project_id"` |
| 280 | Environment map[string]interface{} `json:"environment"` |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 281 | } |
| 282 | |
Jon Perritt | 9209df4 | 2015-02-05 12:55:33 -0700 | [diff] [blame] | 283 | // AbandonResult represents the result of an Abandon operation. |
Jon Perritt | 35e27e4 | 2014-12-05 11:10:46 -0700 | [diff] [blame] | 284 | type AbandonResult struct { |
| 285 | gophercloud.Result |
| 286 | } |
Jon Perritt | 9209df4 | 2015-02-05 12:55:33 -0700 | [diff] [blame] | 287 | |
| 288 | // Extract returns a pointer to an AbandonedStack object and is called after an |
| 289 | // Abandon operation. |
| 290 | func (r AbandonResult) Extract() (*AbandonedStack, error) { |
Jon Perritt | 3c16647 | 2016-02-25 03:07:41 -0600 | [diff] [blame] | 291 | var s *AbandonedStack |
| 292 | err := r.ExtractInto(&s) |
| 293 | return s, err |
Jon Perritt | 9209df4 | 2015-02-05 12:55:33 -0700 | [diff] [blame] | 294 | } |
Jon Perritt | 3d381d5 | 2015-02-09 13:04:48 -0700 | [diff] [blame] | 295 | |
Jon Perritt | db0d26a | 2015-02-09 13:06:16 -0700 | [diff] [blame] | 296 | // String converts an AbandonResult to a string. This is useful to when passing |
| 297 | // the result of an Abandon operation to an AdoptOpts AdoptStackData field. |
Jon Perritt | 3d381d5 | 2015-02-09 13:04:48 -0700 | [diff] [blame] | 298 | func (r AbandonResult) String() (string, error) { |
| 299 | out, err := json.Marshal(r) |
Jon Perritt | 31b6646 | 2016-02-25 22:25:30 -0600 | [diff] [blame] | 300 | return string(out), err |
Jon Perritt | 3d381d5 | 2015-02-09 13:04:48 -0700 | [diff] [blame] | 301 | } |