amazonka-ec2-1.6.1: Amazon Elastic Compute Cloud SDK.

Copyright(c) 2013-2018 Brendan Hay
LicenseMozilla Public License, v. 2.0.
MaintainerBrendan Hay <brendan.g.hay+amazonka@gmail.com>
Stabilityauto-generated
Portabilitynon-portable (GHC extensions)
Safe HaskellNone
LanguageHaskell2010

Network.AWS.EC2.CopyImage

Contents

Description

Initiates the copy of an AMI from the specified source region to the current region. You specify the destination region by using its endpoint when making the request.

For more information about the prerequisites and limits when copying an AMI, see Copying an AMI in the Amazon Elastic Compute Cloud User Guide .

Synopsis

Creating a Request

copyImage Source #

Creates a value of CopyImage with the minimum fields required to make a request.

Use one of the following lenses to modify other fields as desired:

  • ciClientToken - Unique, case-sensitive identifier you provide to ensure idempotency of the request. For more information, see How to Ensure Idempotency in the Amazon Elastic Compute Cloud User Guide .
  • ciEncrypted - Specifies whether the destination snapshots of the copied image should be encrypted. The default CMK for EBS is used unless a non-default AWS Key Management Service (AWS KMS) CMK is specified with KmsKeyId . For more information, see Amazon EBS Encryption in the Amazon Elastic Compute Cloud User Guide .
  • ciKMSKeyId - An identifier for the AWS Key Management Service (AWS KMS) customer master key (CMK) to use when creating the encrypted volume. This parameter is only required if you want to use a non-default CMK; if this parameter is not specified, the default CMK for EBS is used. If a KmsKeyId is specified, the Encrypted flag must also be set. The CMK identifier may be provided in any of the following formats: * Key ID * Key alias, in the form alias/ExampleAlias * ARN using key ID. The ID ARN contains the arn:aws:kms namespace, followed by the region of the CMK, the AWS account ID of the CMK owner, the key namespace, and then the CMK ID. For example, arn:aws:kms:us-east-1 :012345678910 :key/abcd1234-a123-456a-a12b-a123b4cd56ef . * ARN using key alias. The alias ARN contains the arn:aws:kms namespace, followed by the region of the CMK, the AWS account ID of the CMK owner, the alias namespace, and then the CMK alias. For example, arn:aws:kms:us-east-1 :012345678910 :alias/ExampleAlias . AWS parses KmsKeyId asynchronously, meaning that the action you call may appear to complete even though you provided an invalid identifier. This action will eventually report failure. The specified CMK must exist in the region that the snapshot is being copied to.
  • ciDescription - A description for the new AMI in the destination region.
  • ciDryRun - Checks whether you have the required permissions for the action, without actually making the request, and provides an error response. If you have the required permissions, the error response is DryRunOperation . Otherwise, it is UnauthorizedOperation .
  • ciName - The name of the new AMI in the destination region.
  • ciSourceImageId - The ID of the AMI to copy.
  • ciSourceRegion - The name of the region that contains the AMI to copy.

data CopyImage Source #

Contains the parameters for CopyImage.

See: copyImage smart constructor.

Instances
Eq CopyImage Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Data CopyImage Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> CopyImage -> c CopyImage #

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c CopyImage #

toConstr :: CopyImage -> Constr #

dataTypeOf :: CopyImage -> DataType #

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c CopyImage) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c CopyImage) #

gmapT :: (forall b. Data b => b -> b) -> CopyImage -> CopyImage #

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> CopyImage -> r #

gmapQr :: (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> CopyImage -> r #

gmapQ :: (forall d. Data d => d -> u) -> CopyImage -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> CopyImage -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> CopyImage -> m CopyImage #

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> CopyImage -> m CopyImage #

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> CopyImage -> m CopyImage #

Read CopyImage Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Show CopyImage Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Generic CopyImage Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Associated Types

type Rep CopyImage :: Type -> Type #

Hashable CopyImage Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

AWSRequest CopyImage Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Associated Types

type Rs CopyImage :: Type #

ToHeaders CopyImage Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Methods

toHeaders :: CopyImage -> [Header] #

ToPath CopyImage Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

ToQuery CopyImage Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

NFData CopyImage Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Methods

rnf :: CopyImage -> () #

type Rep CopyImage Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

type Rs CopyImage Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Request Lenses

ciClientToken :: Lens' CopyImage (Maybe Text) Source #

Unique, case-sensitive identifier you provide to ensure idempotency of the request. For more information, see How to Ensure Idempotency in the Amazon Elastic Compute Cloud User Guide .

ciEncrypted :: Lens' CopyImage (Maybe Bool) Source #

Specifies whether the destination snapshots of the copied image should be encrypted. The default CMK for EBS is used unless a non-default AWS Key Management Service (AWS KMS) CMK is specified with KmsKeyId . For more information, see Amazon EBS Encryption in the Amazon Elastic Compute Cloud User Guide .

ciKMSKeyId :: Lens' CopyImage (Maybe Text) Source #

An identifier for the AWS Key Management Service (AWS KMS) customer master key (CMK) to use when creating the encrypted volume. This parameter is only required if you want to use a non-default CMK; if this parameter is not specified, the default CMK for EBS is used. If a KmsKeyId is specified, the Encrypted flag must also be set. The CMK identifier may be provided in any of the following formats: * Key ID * Key alias, in the form alias/ExampleAlias * ARN using key ID. The ID ARN contains the arn:aws:kms namespace, followed by the region of the CMK, the AWS account ID of the CMK owner, the key namespace, and then the CMK ID. For example, arn:aws:kms:us-east-1 :012345678910 :key/abcd1234-a123-456a-a12b-a123b4cd56ef . * ARN using key alias. The alias ARN contains the arn:aws:kms namespace, followed by the region of the CMK, the AWS account ID of the CMK owner, the alias namespace, and then the CMK alias. For example, arn:aws:kms:us-east-1 :012345678910 :alias/ExampleAlias . AWS parses KmsKeyId asynchronously, meaning that the action you call may appear to complete even though you provided an invalid identifier. This action will eventually report failure. The specified CMK must exist in the region that the snapshot is being copied to.

ciDescription :: Lens' CopyImage (Maybe Text) Source #

A description for the new AMI in the destination region.

ciDryRun :: Lens' CopyImage (Maybe Bool) Source #

Checks whether you have the required permissions for the action, without actually making the request, and provides an error response. If you have the required permissions, the error response is DryRunOperation . Otherwise, it is UnauthorizedOperation .

ciName :: Lens' CopyImage Text Source #

The name of the new AMI in the destination region.

ciSourceImageId :: Lens' CopyImage Text Source #

The ID of the AMI to copy.

ciSourceRegion :: Lens' CopyImage Text Source #

The name of the region that contains the AMI to copy.

Destructuring the Response

copyImageResponse Source #

Creates a value of CopyImageResponse with the minimum fields required to make a request.

Use one of the following lenses to modify other fields as desired:

data CopyImageResponse Source #

Contains the output of CopyImage.

See: copyImageResponse smart constructor.

Instances
Eq CopyImageResponse Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Data CopyImageResponse Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> CopyImageResponse -> c CopyImageResponse #

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c CopyImageResponse #

toConstr :: CopyImageResponse -> Constr #

dataTypeOf :: CopyImageResponse -> DataType #

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c CopyImageResponse) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c CopyImageResponse) #

gmapT :: (forall b. Data b => b -> b) -> CopyImageResponse -> CopyImageResponse #

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> CopyImageResponse -> r #

gmapQr :: (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> CopyImageResponse -> r #

gmapQ :: (forall d. Data d => d -> u) -> CopyImageResponse -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> CopyImageResponse -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> CopyImageResponse -> m CopyImageResponse #

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> CopyImageResponse -> m CopyImageResponse #

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> CopyImageResponse -> m CopyImageResponse #

Read CopyImageResponse Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Show CopyImageResponse Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Generic CopyImageResponse Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Associated Types

type Rep CopyImageResponse :: Type -> Type #

NFData CopyImageResponse Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

Methods

rnf :: CopyImageResponse -> () #

type Rep CopyImageResponse Source # 
Instance details

Defined in Network.AWS.EC2.CopyImage

type Rep CopyImageResponse = D1 (MetaData "CopyImageResponse" "Network.AWS.EC2.CopyImage" "amazonka-ec2-1.6.1-GgG1M0FWcBrE5I5IM2QktE" False) (C1 (MetaCons "CopyImageResponse'" PrefixI True) (S1 (MetaSel (Just "_coprsImageId") NoSourceUnpackedness SourceStrict DecidedStrict) (Rec0 (Maybe Text)) :*: S1 (MetaSel (Just "_coprsResponseStatus") NoSourceUnpackedness SourceStrict DecidedStrict) (Rec0 Int)))

Response Lenses

coprsResponseStatus :: Lens' CopyImageResponse Int Source #

  • - | The response status code.