Class: Awspec::Type::S3Bucket
Instance Attribute Summary
Attributes inherited from Base
Attributes included from Helper::Finder
Instance Method Summary collapse
- #acl_grants_count ⇒ Object
- #acl_owner ⇒ Object
- #cors_rules_count ⇒ Object
- #has_acl_grant?(grantee:, permission:) ⇒ Boolean
- #has_cors_rule?(allowed_headers: [], allowed_methods:, allowed_origins:, expose_headers: [], max_age_seconds: nil) ⇒ Boolean
- #has_object?(key) ⇒ Boolean
- #has_policy?(policy) ⇒ Boolean
-
#initialize(id) ⇒ S3Bucket
constructor
A new instance of S3Bucket.
Methods inherited from Base
#exists?, #inspect, #method_missing, #to_s
Methods included from Helper::Finder::Directconnect
#find_virtual_interface, #select_virtual_interfaces
Methods included from Helper::Finder::Ses
Methods included from Helper::Finder::Cloudwatch
#find_cloudwatch_alarm, #select_all_cloudwatch_alarms
Methods included from Helper::Finder::Elasticache
#find_cache_cluster, #find_cache_subnet_group
Methods included from Helper::Finder::Iam
#select_all_attached_policies, #select_attached_entities, #select_attached_groups, #select_attached_roles, #select_attached_users, #select_iam_group_by_user_name, #select_iam_policy_by_group_name, #select_iam_policy_by_role_name, #select_iam_policy_by_user_name, #select_policy_evaluation_results
Methods included from Helper::Finder::Lambda
#find_lambda, #select_event_source_by_function_arn
Methods included from Helper::Finder::Elb
#find_elb, #select_elb_by_vpc_id
Methods included from Helper::Finder::Ebs
#find_ebs, #select_all_attached_ebs, #select_ebs_by_instance_id
Methods included from Helper::Finder::Autoscaling
Methods included from Helper::Finder::S3
#find_bucket, #find_bucket_acl, #find_bucket_cors, #find_bucket_policy, #select_all_buckets
Methods included from Helper::Finder::Route53
Methods included from Helper::Finder::Rds
#find_rds, #select_rds_by_vpc_id
Methods included from Helper::Finder::SecurityGroup
#find_security_group, #select_security_group_by_vpc_id
Methods included from Helper::Finder::Ec2
#find_ec2, #find_ec2_attribute, #find_security_group, #select_ec2_by_vpc_id, #select_eip_by_instance_id
Methods included from Helper::Finder::Vpc
#find_network_acl, #find_route_table, #find_subnet, #find_vpc, #find_vpc_peering_connection, #select_network_acl_by_vpc_id, #select_route_table_by_vpc_id, #select_subnet_by_vpc_id
Constructor Details
#initialize(id) ⇒ S3Bucket
Returns a new instance of S3Bucket.
3 4 5 6 7 |
# File 'lib/awspec/type/s3_bucket.rb', line 3 def initialize(id) super @resource = find_bucket(id) @id = id if @resource end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method in the class Awspec::Type::Base
Instance Method Details
#acl_grants_count ⇒ Object
32 33 34 35 |
# File 'lib/awspec/type/s3_bucket.rb', line 32 def acl_grants_count @acl = find_bucket_acl(@id) @acl.grants.count end |
#acl_owner ⇒ Object
27 28 29 30 |
# File 'lib/awspec/type/s3_bucket.rb', line 27 def acl_owner @acl = find_bucket_acl(@id) @acl.owner.display_name end |
#cors_rules_count ⇒ Object
51 52 53 |
# File 'lib/awspec/type/s3_bucket.rb', line 51 def cors_rules_count cors_rules.count end |
#has_acl_grant?(grantee:, permission:) ⇒ Boolean
19 20 21 22 23 24 25 |
# File 'lib/awspec/type/s3_bucket.rb', line 19 def has_acl_grant?(grantee:, permission:) @acl = find_bucket_acl(@id) @acl.grants.find do |grant| grant. == && (grant.grantee.display_name == grantee || grant.grantee.uri == grantee || grant.grantee.id == grantee) end end |
#has_cors_rule?(allowed_headers: [], allowed_methods:, allowed_origins:, expose_headers: [], max_age_seconds: nil) ⇒ Boolean
37 38 39 40 41 42 43 44 45 46 47 48 49 |
# File 'lib/awspec/type/s3_bucket.rb', line 37 def has_cors_rule?(allowed_headers: [], allowed_methods:, allowed_origins:, expose_headers: [], max_age_seconds: nil) cors_rules.any? do |rule| (rule.allowed_headers - allowed_headers).empty? && (rule.allowed_methods - allowed_methods).empty? && (rule.allowed_origins - allowed_origins).empty? && (rule.expose_headers - expose_headers).empty? && rule.max_age_seconds == max_age_seconds end end |
#has_object?(key) ⇒ Boolean
9 10 11 12 13 14 15 16 17 |
# File 'lib/awspec/type/s3_bucket.rb', line 9 def has_object?(key) res = @s3_client.head_object({ bucket: @id, key: key.sub(%r(\A/), '') }) res rescue false end |
#has_policy?(policy) ⇒ Boolean
55 56 57 58 59 |
# File 'lib/awspec/type/s3_bucket.rb', line 55 def has_policy?(policy) bp = find_bucket_policy(@id) # newlines, spaces, etc.. are removed from policy which is returned from API bp ? (bp.policy.read == policy.gsub(/(\n|\r|\r\n|\s|\t)/, '')) : false end |