2014-12-30 17:25:09 -05:00
module Fog
module CDN
2015-01-02 12:34:40 -05:00
class AWS
2014-12-30 17:25:09 -05:00
class Real
require 'fog/aws/parsers/cdn/distribution'
# Update a distribution in CloudFront.
#
# @param distribution_id [String] Id of distribution to update config for.
# @param options [Hash] Config for distribution.
#
# REQUIRED:
# * S3Origin [Hash]:
# * DNSName [String] - origin to associate with distribution, ie 'mybucket.s3.amazonaws.com'.
# * OriginAccessIdentity [String] - Optional: Used when serving private content.
# or
# * CustomOrigin [Hash]:
# * DNSName [String] - Origin to associate with distribution, ie 'www.example.com'.
# * HTTPPort [Integer] - HTTP port of origin, in [80, 443] or (1024...65535).
# * HTTPSPort [Integer] - HTTPS port of origin, in [80, 443] or (1024...65535).
# * OriginProtocolPolicy [String] - Policy on using http vs https, in ['http-only', 'match-viewer'].
# OPTIONAL:
# * CallerReference [String] Used to prevent replay, defaults to Time.now.to_i.to_s.
# * Comment [String] Optional comment about distribution.
# * CNAME [Array] Optional array of strings to set as CNAMEs.
# * DefaultRootObject [String] Optional default object to return for '/'.
# * Enabled [Boolean] Whether or not distribution should accept requests, defaults to true.
# * Logging [Hash]: Optional logging config.
# * Bucket [String] Bucket to store logs in, ie 'mylogs.s3.amazonaws.com'.
# * Prefix [String] Optional prefix for log filenames, ie 'myprefix/'.
# * OriginAccessIdentity [String] Used for serving private content, in format 'origin-access-identity/cloudfront/ID'.
# * RequiredProtocols [String] Optional, set to 'https' to force https connections.
2015-01-02 12:34:40 -05:00
# * TrustedSigners [Array] Optional grant of rights to up to 5 aws accounts to generate signed URLs for private content, elements are either 'Self' for your own account or an AWS Account Number.
2014-12-30 17:25:09 -05:00
#
# @return [Excon::Response]
# * body [Hash]:
# * DomainName [String]: Domain name of distribution.
# * Id [String] - Id of distribution.
# * LastModifiedTime [String] - Timestamp of last modification of distribution.
# * Status [String] - Status of distribution.
# * DistributionConfig [Array]:
# * CallerReference [String] - Used to prevent replay, defaults to Time.now.to_i.to_s.
# * CNAME [Array] - Array of associated cnames.
# * Comment [String] - Comment associated with distribution.
# * Enabled [Boolean] - Whether or not distribution is enabled.
# * Logging [Hash]:
# * Bucket [String] - Bucket logs are stored in.
# * Prefix [String] - Prefix logs are stored with.
# * Origin [String] - S3 origin bucket.
# * TrustedSigners [Array] - Trusted signers.
#
# @see http://docs.amazonwebservices.com/AmazonCloudFront/latest/APIReference/CreateDistribution.html
def put_distribution_config ( distribution_id , etag , options = { } )
data = '<?xml version="1.0" encoding="UTF-8"?>'
data << " <DistributionConfig xmlns= \" http://cloudfront.amazonaws.com/doc/ #{ @version } / \" > "
for key , value in options
case value
when Array
for item in value
data << " < #{ key } > #{ item } </ #{ key } > "
end
when Hash
data << " < #{ key } > "
for inner_key , inner_value in value
data << " < #{ inner_key } > #{ inner_value } </ #{ inner_key } > "
end
data << " </ #{ key } > "
else
data << " < #{ key } > #{ value } </ #{ key } > "
end
end
data << " </DistributionConfig> "
request ( {
:body = > data ,
:expects = > 200 ,
:headers = > {
'Content-Type' = > 'text/xml' ,
'If-Match' = > etag
} ,
:idempotent = > true ,
:method = > 'PUT' ,
:parser = > Fog :: Parsers :: CDN :: AWS :: Distribution . new ,
:path = > " /distribution/ #{ distribution_id } /config "
} )
end
end
class Mock
def put_distribution_config ( distribution_id , etag , options = { } )
distribution = self . data [ :distributions ] [ distribution_id ]
if distribution
if distribution [ 'ETag' ] != etag
Fog :: CDN :: AWS :: Mock . error ( :invalid_if_match_version )
end
unless distribution [ 'DistributionConfig' ] [ 'CallerReference' ]
Fog :: CDN :: AWS :: Mock . error ( :illegal_update )
end
distribution [ 'DistributionConfig' ] . merge! ( options )
distribution [ 'Status' ] = 'InProgress'
response = Excon :: Response . new
response . status = 200
response . headers [ 'ETag' ] = Fog :: CDN :: AWS :: Mock . generic_id
response . body = distribution . merge ( { 'LastModifiedTime' = > Time . now . utc . iso8601 } ) . reject { | k , v | k == 'ETag' }
response
else
Fog :: CDN :: AWS :: Mock . error ( :no_such_distribution )
end
end
end
end
end
end