-
Notifications
You must be signed in to change notification settings - Fork 1.2k
/
Copy pathexport_task.rb
120 lines (99 loc) · 3.34 KB
/
export_task.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
# Copyright 2011-2013 Amazon.com, Inc. or its affiliates. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"). You
# may not use this file except in compliance with the License. A copy of
# the License is located at
#
# http://aws.amazon.com/apache2.0/
#
# or in the "license" file accompanying this file. This file is
# distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
# ANY KIND, either express or implied. See the License for the specific
# language governing permissions and limitations under the License.
module AWS
class EC2
# @attr_reader [String] description
# Description of the resource being exported.
#
# @attr_reader [Symbol] state State of the conversion task.
# Valid values :active, :cancelling, :cancelled and :completed.
#
# @attr_reader [String] status_message Status message related to the
# export task.
#
# @attr_reader [String] instance_id ID of instance being exported.
#
# @attr_reader [String] target_environment The target virtualization
# environment.
#
# @attr_reader [String] disk_image_format The format for the exported
# image.
#
# @attr_reader [String] container_format The container format used to
# combine disk images with metadata (such as OVF).
#
# @attr_reader [String] s3_bucket The name of the Amazon S3 bucket
# the image will be exported to.
#
# @attr_reader [String] s3_key The key of the Amazon S3 object
# the image will be exported to.
#
class ExportTask < Resource
# @api private
def initialize export_task_id, options = {}
@export_task_id = export_task_id
super
end
# @return [String]
attr_reader :export_task_id
alias_method :id, :export_task_id
attribute :description, :static => true
attribute :state, :to_sym => true
attribute :status_message
attribute :instance_id,
:from => [:instance_export, :instance_id],
:static => true
attribute :target_environment,
:from => [:instance_export, :target_environment],
:static => true
attribute :disk_image_format,
:from => [:export_to_s3, :disk_image_format],
:static => true
attribute :container_format,
:from => [:export_to_s3, :container_format],
:static => true
attribute :s3_bucket_name,
:from => [:export_to_s3, :s3_bucket],
:static => true
attribute :s3_key,
:from => [:export_to_s3, :s3_key],
:static => true
populates_from(:create_instance_export_task) do |resp|
resp[:export_task] if resp[:export_task][:export_task_id] == id
end
populates_from(:describe_export_tasks) do |resp|
resp[:export_task_set].find do |task|
task[:export_task_id] == id
end
end
# @return [Instance]
def instance
Instance.new(instance_id, :config => config)
end
# @return [S3::Bucket]
def s3_bucket
S3::Bucket.new(s3_bucket_name, :config => config)
end
# @return [S3::S3Object]
def s3_object
s3_bucket.objects[s3_key]
end
# Cancels the export task.
# @return [nil]
def cancel
client.cancel_export_task(:export_task_id => export_task_id)
nil
end
end
end
end