This file is indexed.

/usr/lib/ruby/vendor_ruby/AWS/EC2/images.rb is in ruby-amazon-ec2 0.9.17-3build1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  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
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
module AWS
  module EC2

    class Base < AWS::Base

      # Creates an AMI that uses an Amazon EBS root device from a "running" or "stopped" instance.
      #
      # AMIs that use an Amazon EBS root device boot faster than AMIs that use instance stores.
      # They can be up to 1 TiB in size, use storage that persists on instance failure, and can be
      # stopped and started.
      #
      # @option options [String] :instance_id ("") The ID of the instance.
      # @option options [String] :name ("") The name of the AMI that was provided during image creation. Constraints 3-128 alphanumeric characters, parenthesis (()), commas (,), slashes (/), dashes (-), or underscores(_)
      # @option options [optional,String] :description ("") The description of the AMI that was provided during image creation.
      # @option options [optional,Boolean] :no_reboot (false) By default this property is set to false, which means Amazon EC2 attempts to cleanly shut down the instance before image creation and reboots the instance afterwards. When set to true, Amazon EC2 does not shut down the instance before creating the image. When this option is used, file system integrity on the created image cannot be guaranteed.
      #
      def create_image( options = {} )
        options = { :instance_id => "", :name => "" }.merge(options)
        raise ArgumentError, "No :instance_id provided" if options.does_not_have? :instance_id
        raise ArgumentError, "No :name provided" if options.does_not_have? :name
        raise ArgumentError, "Invalid string length for :name provided" if options[:name] && options[:name].size < 3 || options[:name].size > 128
        raise ArgumentError, "Invalid string length for :description provided (too long)" if options[:description] && options[:description].size > 255
        raise ArgumentError, ":no_reboot option must be a Boolean" unless options[:no_reboot].nil? || [true, false].include?(options[:no_reboot])
        params = {}
        params["InstanceId"] = options[:instance_id].to_s
        params["Name"] = options[:name].to_s
        params["Description"] = options[:description].to_s
        params["NoReboot"] = options[:no_reboot].to_s
        return response_generator(:action => "CreateImage", :params => params)
      end


      # The DeregisterImage operation deregisters an AMI. Once deregistered, instances of the AMI may no
      # longer be launched.
      #
      # @option options [String] :image_id ("")
      #
      def deregister_image( options = {} )
        options = { :image_id => "" }.merge(options)
        raise ArgumentError, "No :image_id provided" if options[:image_id].nil? || options[:image_id].empty?
        params = { "ImageId" => options[:image_id] }
        return response_generator(:action => "DeregisterImage", :params => params)
      end


      # Registers an AMI with Amazon EC2. Images must be registered before they can be launched.
      # To launch instances, use the RunInstances operation.  Each AMI is associated with an unique ID
      # which is provided by the Amazon EC2 service through this operation. If needed, you can deregister
      # an AMI at any time.
      #
      # AMIs backed by Amazon EBS are automatically registered when you create the image.
      # However, you can use this to register a snapshot of an instance backed by Amazon EBS.
      #
      # Amazon EBS snapshots are not guaranteed to be bootable. For information on creating AMIs
      # backed by Amazon EBS, go to the Amazon Elastic Compute Cloud Developer Guide or Amazon
      # Elastic Compute Cloud User Guide.
      #
      # Any modifications to an AMI backed by Amazon S3 invalidates this registration.
      # If you make changes to an image, deregister the previous image and register the new image.
      #
      # If an :image_location is specified then an old-style S3-backed AMI is created. If the other
      # parameters are used then a new style EBS-backed AMI is created from a pre-existing snapshot.
      #
      # @option options [optional, String] :image_location ("") S3 URL for the XML manifest
      # @option options [optional, String] :name ("") Name of EBS image
      # @option options [optional, String] :description ("") Description of EBS image
      # @option options [optional, String] :architecture ("") Architecture of EBS image, currently 'i386' or 'x86_64'
      # @option options [optional, String] :kernel_id ("") Kernel ID of EBS image
      # @option options [optional, String] :ramdisk_id ("") Ramdisk ID of EBS image
      # @option options [optional, String] :root_device_name ("") Root device name of EBS image, eg '/dev/sda1'
      # @option options [optional, Array] :block_device_mapping ([]) An array of Hashes representing the elements of the block device mapping.  e.g. [{:device_name => '/dev/sdh', :virtual_name => '', :ebs_snapshot_id => '', :ebs_volume_size => '', :ebs_delete_on_termination => ''},{},...]
      #
      def register_image( options = {} )
        params = {}
        if options.does_not_have?(:image_location) && options.does_not_have?(:root_device_name)
          raise ArgumentError, "No :image_location or :root_device_name"
        end
        params["ImageLocation"] = options[:image_location].to_s unless options[:image_location].nil?
        params["Name"] = options[:name].to_s unless options[:name].nil?
        params["Description"] = options[:description].to_s unless options[:description].nil?
        params["Architecture"] = options[:architecture].to_s unless options[:architecture].nil?
        params["KernelId"] = options[:kernel_id].to_s unless options[:kernel_id].nil?
        params["RamdiskId"] = options[:ramdisk_id].to_s unless options[:ramdisk_id].nil?
        params["RootDeviceName"] = options[:root_device_name].to_s unless options[:root_device_name].nil?
        if options[:block_device_mapping]
          params.merge!(pathhashlist("BlockDeviceMapping", options[:block_device_mapping].flatten, {
            :device_name => "DeviceName",
            :virtual_name => "VirtualName",
            :ebs_snapshot_id => "Ebs.SnapshotId",
            :ebs_volume_size => "Ebs.VolumeSize",
            :ebs_delete_on_termination => "Ebs.DeleteOnTermination"
          }))
        end
        return response_generator(:action => "RegisterImage", :params => params)
      end


      # The DescribeImages operation returns information about AMIs available for use by the user. This
      # includes both public AMIs (those available for any user to launch) and private AMIs (those owned by
      # the user making the request and those owned by other users that the user making the request has explicit
      # launch permissions for).
      #
      # The list of AMIs returned can be modified via optional lists of AMI IDs, owners or users with launch
      # permissions. If all three optional lists are empty all AMIs the user has launch permissions for are
      # returned. Launch permissions fall into three categories:
      #
      # Launch Permission Description
      #
      # public - The all group has launch permissions for the AMI. All users have launch permissions for these AMIs.
      # explicit - The owner of the AMIs has granted a specific user launch permissions for the AMI.
      # implicit - A user has implicit launch permissions for all AMIs he or she owns.
      #
      # If one or more of the lists are specified the result set is the intersection of AMIs matching the criteria of
      # the individual lists.
      #
      # Providing the list of AMI IDs requests information for those AMIs only. If no AMI IDs are provided,
      # information of all relevant AMIs will be returned. If an AMI is specified that does not exist a fault is
      # returned. If an AMI is specified that exists but the user making the request does not have launch
      # permissions for, then that AMI will not be included in the returned results.
      #
      # Providing the list of owners requests information for AMIs owned by the specified owners only. Only
      # AMIs the user has launch permissions for are returned. The items of the list may be account ids for
      # AMIs owned by users with those account ids, amazon for AMIs owned by Amazon or self for AMIs
      # owned by the user making the request.
      #
      # The executable list may be provided to request information for AMIs that only the specified users have
      # launch permissions for. The items of the list may be account ids for AMIs owned by the user making the
      # request that the users with the specified account ids have explicit launch permissions for, self for AMIs
      # the user making the request has explicit launch permissions for or all for public AMIs.
      #
      # Deregistered images will be included in the returned results for an unspecified interval subsequent to
      # deregistration.
      #
      # @option options [Array] :image_id ([])
      # @option options [Array] :owner_id ([])
      # @option options [Array] :executable_by ([])
      #
      def describe_images( options = {} )
        options = { :image_id => [], :owner_id => [], :executable_by => [] }.merge(options)
        params = pathlist( "ImageId", options[:image_id] )
        params.merge!(pathlist( "Owner", options[:owner_id] ))
        params.merge!(pathlist( "ExecutableBy", options[:executable_by] ))
        return response_generator(:action => "DescribeImages", :params => params)
      end


    end
  end
end