aws-sdk 1.8.5 → 1.9.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.yardopts +1 -0
- data/README.rdoc +8 -0
- data/lib/aws-sdk.rb +39 -35
- data/lib/aws/api_config/CloudFront-2012-07-01.yml +2398 -0
- data/lib/aws/api_config/DirectConnect-2012-10-25.yml +475 -0
- data/lib/aws/api_config/DynamoDB-2011-12-05.yml +8 -0
- data/lib/aws/api_config/DynamoDB-2012-08-10.yml +1516 -0
- data/lib/aws/api_config/OpsWorks-2013-02-18.yml +2 -2
- data/lib/aws/auto_scaling.rb +44 -44
- data/lib/aws/auto_scaling/activity.rb +1 -1
- data/lib/aws/auto_scaling/activity_collection.rb +14 -15
- data/lib/aws/auto_scaling/client.rb +277 -277
- data/lib/aws/auto_scaling/config.rb +1 -1
- data/lib/aws/auto_scaling/group.rb +35 -36
- data/lib/aws/auto_scaling/group_collection.rb +10 -10
- data/lib/aws/auto_scaling/group_options.rb +19 -19
- data/lib/aws/auto_scaling/instance.rb +27 -27
- data/lib/aws/auto_scaling/instance_collection.rb +10 -10
- data/lib/aws/auto_scaling/launch_configuration.rb +3 -3
- data/lib/aws/auto_scaling/launch_configuration_collection.rb +1 -1
- data/lib/aws/auto_scaling/notification_configuration.rb +2 -2
- data/lib/aws/auto_scaling/notification_configuration_collection.rb +37 -38
- data/lib/aws/auto_scaling/scaling_policy.rb +3 -3
- data/lib/aws/auto_scaling/scaling_policy_collection.rb +6 -6
- data/lib/aws/auto_scaling/scaling_policy_options.rb +8 -7
- data/lib/aws/auto_scaling/scheduled_action.rb +3 -3
- data/lib/aws/auto_scaling/scheduled_action_collection.rb +28 -28
- data/lib/aws/auto_scaling/tag_collection.rb +30 -28
- data/lib/aws/cloud_formation.rb +95 -94
- data/lib/aws/cloud_formation/client.rb +136 -133
- data/lib/aws/cloud_formation/config.rb +1 -1
- data/lib/aws/cloud_formation/stack.rb +37 -37
- data/lib/aws/cloud_formation/stack_collection.rb +28 -27
- data/lib/aws/cloud_formation/stack_event.rb +9 -11
- data/lib/aws/cloud_formation/stack_output.rb +1 -1
- data/lib/aws/cloud_formation/stack_resource.rb +6 -6
- data/lib/aws/cloud_formation/stack_resource_collection.rb +11 -12
- data/lib/aws/cloud_formation/stack_resource_summary_collection.rb +11 -11
- data/lib/aws/cloud_formation/stack_summary_collection.rb +39 -39
- data/lib/aws/cloud_front.rb +21 -21
- data/lib/aws/cloud_front/client.rb +853 -652
- data/lib/aws/cloud_front/request.rb +3 -0
- data/lib/aws/cloud_search.rb +22 -22
- data/lib/aws/cloud_search/client.rb +322 -315
- data/lib/aws/cloud_search/config.rb +1 -1
- data/lib/aws/cloud_watch.rb +39 -39
- data/lib/aws/cloud_watch/alarm.rb +55 -37
- data/lib/aws/cloud_watch/alarm_collection.rb +18 -18
- data/lib/aws/cloud_watch/alarm_history_item_collection.rb +2 -2
- data/lib/aws/cloud_watch/client.rb +360 -146
- data/lib/aws/cloud_watch/config.rb +1 -1
- data/lib/aws/cloud_watch/metric.rb +15 -15
- data/lib/aws/cloud_watch/metric_alarm_collection.rb +17 -17
- data/lib/aws/cloud_watch/metric_collection.rb +16 -16
- data/lib/aws/cloud_watch/metric_statistics.rb +11 -11
- data/lib/aws/core.rb +243 -225
- data/lib/aws/core/async_handle.rb +13 -13
- data/lib/aws/core/cacheable.rb +14 -15
- data/lib/aws/core/client.rb +40 -15
- data/lib/aws/core/collection.rb +42 -46
- data/lib/aws/core/collection/with_limit_and_next_token.rb +1 -1
- data/lib/aws/core/collection/with_next_token.rb +1 -1
- data/lib/aws/core/configuration.rb +97 -133
- data/lib/aws/core/credential_providers.rb +16 -16
- data/lib/aws/core/data.rb +23 -23
- data/lib/aws/core/http/connection_pool.rb +348 -0
- data/lib/aws/core/http/net_http_handler.rb +17 -26
- data/lib/aws/core/http/patch.rb +102 -0
- data/lib/aws/core/http/request.rb +13 -19
- data/lib/aws/core/http/response.rb +2 -2
- data/lib/aws/core/lazy_error_classes.rb +17 -17
- data/lib/aws/core/log_formatter.rb +70 -104
- data/lib/aws/core/options/json_serializer.rb +1 -1
- data/lib/aws/core/options/validator.rb +4 -4
- data/lib/aws/core/page_result.rb +8 -8
- data/lib/aws/core/policy.rb +49 -49
- data/lib/aws/core/region.rb +72 -0
- data/lib/aws/core/region_collection.rb +106 -0
- data/lib/aws/core/resource.rb +5 -5
- data/lib/aws/core/response.rb +20 -17
- data/lib/aws/core/rest_request_builder.rb +4 -4
- data/lib/aws/core/service_interface.rb +24 -2
- data/lib/aws/core/signature/version_3.rb +2 -2
- data/lib/aws/core/uri_escape.rb +1 -1
- data/lib/aws/core/xml/frame_stack.rb +1 -1
- data/lib/aws/core/xml/grammar.rb +3 -4
- data/lib/aws/core/xml/sax_handlers/libxml.rb +2 -2
- data/lib/aws/core/xml/sax_handlers/nokogiri.rb +3 -3
- data/lib/aws/core/xml/sax_handlers/rexml.rb +5 -5
- data/lib/aws/core/xml/stub.rb +9 -9
- data/lib/aws/data_pipeline.rb +21 -21
- data/lib/aws/data_pipeline/client.rb +189 -133
- data/lib/aws/data_pipeline/config.rb +1 -1
- data/lib/aws/direct_connect.rb +74 -0
- data/lib/aws/direct_connect/client.rb +253 -0
- data/lib/aws/direct_connect/config.rb +18 -0
- data/lib/aws/direct_connect/errors.rb +22 -0
- data/lib/aws/direct_connect/request.rb +27 -0
- data/lib/aws/dynamo_db.rb +71 -69
- data/lib/aws/dynamo_db/attribute_collection.rb +53 -58
- data/lib/aws/dynamo_db/batch_get.rb +23 -23
- data/lib/aws/dynamo_db/batch_write.rb +43 -43
- data/lib/aws/dynamo_db/binary.rb +9 -9
- data/lib/aws/dynamo_db/client.rb +494 -509
- data/lib/aws/dynamo_db/client_base.rb +91 -0
- data/lib/aws/dynamo_db/client_v2.rb +825 -0
- data/lib/aws/dynamo_db/config.rb +1 -1
- data/lib/aws/dynamo_db/item.rb +10 -10
- data/lib/aws/dynamo_db/item_collection.rb +75 -75
- data/lib/aws/dynamo_db/table.rb +85 -85
- data/lib/aws/dynamo_db/table_collection.rb +13 -13
- data/lib/aws/ec2.rb +132 -142
- data/lib/aws/ec2/attachment.rb +31 -36
- data/lib/aws/ec2/attachment_collection.rb +1 -1
- data/lib/aws/ec2/availability_zone.rb +4 -4
- data/lib/aws/ec2/client.rb +2272 -2125
- data/lib/aws/ec2/config.rb +1 -1
- data/lib/aws/ec2/customer_gateway.rb +6 -6
- data/lib/aws/ec2/customer_gateway_collection.rb +6 -6
- data/lib/aws/ec2/dhcp_options.rb +3 -3
- data/lib/aws/ec2/dhcp_options_collection.rb +10 -10
- data/lib/aws/ec2/elastic_ip.rb +15 -15
- data/lib/aws/ec2/elastic_ip_collection.rb +11 -15
- data/lib/aws/ec2/export_task.rb +4 -4
- data/lib/aws/ec2/export_task_collection.rb +11 -11
- data/lib/aws/ec2/filtered_collection.rb +6 -8
- data/lib/aws/ec2/image.rb +46 -40
- data/lib/aws/ec2/image_collection.rb +44 -52
- data/lib/aws/ec2/instance.rb +64 -62
- data/lib/aws/ec2/instance_collection.rb +47 -50
- data/lib/aws/ec2/internet_gateway.rb +6 -6
- data/lib/aws/ec2/internet_gateway/attachment.rb +13 -13
- data/lib/aws/ec2/internet_gateway_collection.rb +3 -3
- data/lib/aws/ec2/key_pair.rb +3 -3
- data/lib/aws/ec2/key_pair_collection.rb +12 -12
- data/lib/aws/ec2/network_acl.rb +39 -39
- data/lib/aws/ec2/network_acl/association.rb +2 -2
- data/lib/aws/ec2/network_acl/entry.rb +22 -22
- data/lib/aws/ec2/network_acl_collection.rb +2 -2
- data/lib/aws/ec2/network_interface.rb +13 -4
- data/lib/aws/ec2/network_interface/attachment.rb +3 -3
- data/lib/aws/ec2/network_interface_collection.rb +5 -5
- data/lib/aws/ec2/permission_collection.rb +1 -1
- data/lib/aws/ec2/region.rb +6 -6
- data/lib/aws/ec2/region_collection.rb +1 -1
- data/lib/aws/ec2/reserved_instances_collection.rb +2 -2
- data/lib/aws/ec2/reserved_instances_offering_collection.rb +2 -2
- data/lib/aws/ec2/resource_tag_collection.rb +5 -5
- data/lib/aws/ec2/route_table.rb +14 -14
- data/lib/aws/ec2/route_table/association.rb +22 -22
- data/lib/aws/ec2/route_table/route.rb +8 -8
- data/lib/aws/ec2/route_table_collection.rb +3 -3
- data/lib/aws/ec2/security_group.rb +39 -41
- data/lib/aws/ec2/security_group_collection.rb +19 -21
- data/lib/aws/ec2/snapshot.rb +3 -3
- data/lib/aws/ec2/snapshot_collection.rb +11 -12
- data/lib/aws/ec2/subnet.rb +2 -2
- data/lib/aws/ec2/subnet_collection.rb +17 -17
- data/lib/aws/ec2/tag_collection.rb +1 -1
- data/lib/aws/ec2/tagged_collection.rb +7 -7
- data/lib/aws/ec2/tagged_item.rb +10 -10
- data/lib/aws/ec2/volume.rb +16 -16
- data/lib/aws/ec2/volume_collection.rb +9 -12
- data/lib/aws/ec2/vpc.rb +6 -6
- data/lib/aws/ec2/vpc_collection.rb +10 -10
- data/lib/aws/ec2/vpn_connection.rb +4 -4
- data/lib/aws/ec2/vpn_connection/telemetry.rb +1 -1
- data/lib/aws/ec2/vpn_connection_collection.rb +6 -6
- data/lib/aws/ec2/vpn_gateway.rb +2 -2
- data/lib/aws/ec2/vpn_gateway_collection.rb +5 -5
- data/lib/aws/elastic_beanstalk.rb +12 -12
- data/lib/aws/elastic_beanstalk/client.rb +376 -368
- data/lib/aws/elastic_beanstalk/config.rb +1 -1
- data/lib/aws/elastic_transcoder.rb +5 -5
- data/lib/aws/elastic_transcoder/client.rb +283 -283
- data/lib/aws/elastic_transcoder/config.rb +1 -1
- data/lib/aws/elasticache.rb +12 -12
- data/lib/aws/elasticache/client.rb +484 -479
- data/lib/aws/elasticache/config.rb +1 -1
- data/lib/aws/elb.rb +23 -23
- data/lib/aws/elb/availability_zone_collection.rb +34 -34
- data/lib/aws/elb/backend_server_policy_collection.rb +24 -24
- data/lib/aws/elb/client.rb +153 -153
- data/lib/aws/elb/config.rb +1 -1
- data/lib/aws/elb/errors.rb +1 -1
- data/lib/aws/elb/instance_collection.rb +20 -25
- data/lib/aws/elb/listener.rb +3 -3
- data/lib/aws/elb/listener_collection.rb +8 -8
- data/lib/aws/elb/load_balancer.rb +15 -16
- data/lib/aws/elb/load_balancer_collection.rb +36 -24
- data/lib/aws/elb/load_balancer_policy.rb +1 -1
- data/lib/aws/elb/load_balancer_policy_collection.rb +5 -5
- data/lib/aws/emr.rb +28 -26
- data/lib/aws/emr/client.rb +165 -149
- data/lib/aws/emr/config.rb +1 -1
- data/lib/aws/emr/instance_group.rb +1 -1
- data/lib/aws/emr/instance_group_collection.rb +1 -1
- data/lib/aws/emr/job_flow.rb +27 -26
- data/lib/aws/emr/job_flow_collection.rb +34 -34
- data/lib/aws/errors.rb +7 -7
- data/lib/aws/glacier.rb +21 -21
- data/lib/aws/glacier/archive_collection.rb +2 -2
- data/lib/aws/glacier/client.rb +139 -140
- data/lib/aws/glacier/config.rb +1 -1
- data/lib/aws/glacier/vault.rb +2 -2
- data/lib/aws/glacier/vault_collection.rb +1 -1
- data/lib/aws/iam.rb +133 -144
- data/lib/aws/iam/access_key.rb +17 -17
- data/lib/aws/iam/access_key_collection.rb +22 -22
- data/lib/aws/iam/account_alias_collection.rb +2 -2
- data/lib/aws/iam/client.rb +429 -420
- data/lib/aws/iam/collection.rb +1 -1
- data/lib/aws/iam/config.rb +2 -2
- data/lib/aws/iam/group.rb +8 -8
- data/lib/aws/iam/group_collection.rb +16 -16
- data/lib/aws/iam/group_policy_collection.rb +6 -6
- data/lib/aws/iam/group_user_collection.rb +3 -3
- data/lib/aws/iam/mfa_device.rb +1 -1
- data/lib/aws/iam/mfa_device_collection.rb +9 -9
- data/lib/aws/iam/policy_collection.rb +4 -4
- data/lib/aws/iam/resource.rb +2 -2
- data/lib/aws/iam/server_certificate.rb +1 -1
- data/lib/aws/iam/server_certificate_collection.rb +15 -15
- data/lib/aws/iam/signing_certificate.rb +29 -29
- data/lib/aws/iam/signing_certificate_collection.rb +23 -23
- data/lib/aws/iam/user.rb +33 -38
- data/lib/aws/iam/user_collection.rb +27 -27
- data/lib/aws/iam/user_group_collection.rb +3 -3
- data/lib/aws/iam/user_policy_collection.rb +6 -6
- data/lib/aws/iam/virtual_mfa_device.rb +12 -12
- data/lib/aws/iam/virtual_mfa_device_collection.rb +4 -4
- data/lib/aws/import_export.rb +22 -21
- data/lib/aws/import_export/client.rb +47 -43
- data/lib/aws/ops_works.rb +5 -5
- data/lib/aws/ops_works/client.rb +484 -438
- data/lib/aws/ops_works/config.rb +1 -1
- data/lib/aws/rails.rb +34 -34
- data/lib/aws/rds.rb +18 -18
- data/lib/aws/rds/client.rb +1286 -1277
- data/lib/aws/rds/config.rb +1 -1
- data/lib/aws/rds/db_instance.rb +15 -4
- data/lib/aws/rds/db_snapshot.rb +1 -1
- data/lib/aws/record.rb +50 -24
- data/lib/aws/record/abstract_base.rb +52 -60
- data/lib/aws/record/attributes.rb +79 -79
- data/lib/aws/record/conversion.rb +1 -1
- data/lib/aws/record/dirty_tracking.rb +69 -67
- data/lib/aws/record/errors.rb +21 -21
- data/lib/aws/record/exceptions.rb +2 -2
- data/lib/aws/record/hash_model.rb +20 -21
- data/lib/aws/record/hash_model/attributes.rb +13 -15
- data/lib/aws/record/hash_model/finder_methods.rb +46 -46
- data/lib/aws/record/hash_model/scope.rb +31 -31
- data/lib/aws/record/model.rb +136 -136
- data/lib/aws/record/model/attributes.rb +57 -59
- data/lib/aws/record/model/finder_methods.rb +67 -67
- data/lib/aws/record/model/scope.rb +48 -49
- data/lib/aws/record/naming.rb +1 -1
- data/lib/aws/record/scope.rb +23 -19
- data/lib/aws/record/validations.rb +253 -271
- data/lib/aws/record/validator.rb +3 -3
- data/lib/aws/record/validators/acceptance.rb +1 -3
- data/lib/aws/record/validators/block.rb +1 -3
- data/lib/aws/record/validators/confirmation.rb +1 -3
- data/lib/aws/record/validators/count.rb +2 -4
- data/lib/aws/record/validators/exclusion.rb +2 -4
- data/lib/aws/record/validators/format.rb +2 -4
- data/lib/aws/record/validators/inclusion.rb +1 -3
- data/lib/aws/record/validators/length.rb +5 -7
- data/lib/aws/record/validators/method.rb +1 -3
- data/lib/aws/record/validators/numericality.rb +6 -8
- data/lib/aws/record/validators/presence.rb +1 -3
- data/lib/aws/redshift.rb +14 -14
- data/lib/aws/redshift/client.rb +596 -592
- data/lib/aws/redshift/config.rb +1 -1
- data/lib/aws/route_53.rb +30 -30
- data/lib/aws/route_53/change_batch.rb +7 -7
- data/lib/aws/route_53/client.rb +188 -152
- data/lib/aws/route_53/hosted_zone.rb +4 -4
- data/lib/aws/route_53/hosted_zone_collection.rb +7 -7
- data/lib/aws/route_53/resource_record_set.rb +10 -10
- data/lib/aws/route_53/resource_record_set_collection.rb +6 -6
- data/lib/aws/s3.rb +79 -79
- data/lib/aws/s3/access_control_list.rb +44 -36
- data/lib/aws/s3/acl_options.rb +51 -51
- data/lib/aws/s3/bucket.rb +146 -146
- data/lib/aws/s3/bucket_collection.rb +21 -21
- data/lib/aws/s3/bucket_lifecycle_configuration.rb +81 -82
- data/lib/aws/s3/bucket_tag_collection.rb +4 -2
- data/lib/aws/s3/cipher_io.rb +5 -4
- data/lib/aws/s3/client.rb +89 -84
- data/lib/aws/s3/client/xml.rb +1 -1
- data/lib/aws/s3/config.rb +7 -1
- data/lib/aws/s3/cors_rule.rb +2 -0
- data/lib/aws/s3/cors_rule_collection.rb +42 -40
- data/lib/aws/s3/data_options.rb +16 -11
- data/lib/aws/s3/encryption_utils.rb +2 -2
- data/lib/aws/s3/errors.rb +7 -7
- data/lib/aws/s3/multipart_upload.rb +30 -33
- data/lib/aws/s3/multipart_upload_collection.rb +8 -6
- data/lib/aws/s3/object_collection.rb +35 -35
- data/lib/aws/s3/object_metadata.rb +6 -6
- data/lib/aws/s3/object_version.rb +4 -4
- data/lib/aws/s3/object_version_collection.rb +15 -15
- data/lib/aws/s3/policy.rb +2 -2
- data/lib/aws/s3/prefixed_collection.rb +9 -5
- data/lib/aws/s3/presigned_post.rb +39 -37
- data/lib/aws/s3/request.rb +11 -11
- data/lib/aws/s3/s3_object.rb +210 -200
- data/lib/aws/s3/tree.rb +25 -27
- data/lib/aws/s3/tree/child_collection.rb +3 -3
- data/lib/aws/s3/tree/leaf_node.rb +2 -2
- data/lib/aws/s3/tree/parent.rb +1 -1
- data/lib/aws/s3/website_configuration.rb +13 -13
- data/lib/aws/simple_db.rb +83 -83
- data/lib/aws/simple_db/attribute.rb +9 -7
- data/lib/aws/simple_db/attribute_collection.rb +22 -13
- data/lib/aws/simple_db/client.rb +107 -107
- data/lib/aws/simple_db/config.rb +7 -1
- data/lib/aws/simple_db/consistent_read_option.rb +5 -5
- data/lib/aws/simple_db/domain.rb +4 -2
- data/lib/aws/simple_db/domain_collection.rb +4 -4
- data/lib/aws/simple_db/domain_metadata.rb +5 -5
- data/lib/aws/simple_db/errors.rb +9 -9
- data/lib/aws/simple_db/item.rb +5 -5
- data/lib/aws/simple_db/item_collection.rb +83 -81
- data/lib/aws/simple_db/item_data.rb +4 -4
- data/lib/aws/simple_db/put_attributes.rb +3 -3
- data/lib/aws/simple_email_service.rb +140 -140
- data/lib/aws/simple_email_service/client.rb +82 -76
- data/lib/aws/simple_email_service/config.rb +1 -2
- data/lib/aws/simple_email_service/email_address_collection.rb +3 -3
- data/lib/aws/simple_email_service/identity.rb +8 -8
- data/lib/aws/simple_email_service/quotas.rb +8 -6
- data/lib/aws/simple_workflow.rb +106 -106
- data/lib/aws/simple_workflow/activity_task.rb +15 -22
- data/lib/aws/simple_workflow/activity_task_collection.rb +15 -15
- data/lib/aws/simple_workflow/activity_type.rb +23 -23
- data/lib/aws/simple_workflow/activity_type_collection.rb +23 -23
- data/lib/aws/simple_workflow/client.rb +1004 -956
- data/lib/aws/simple_workflow/config.rb +1 -1
- data/lib/aws/simple_workflow/count.rb +5 -5
- data/lib/aws/simple_workflow/decision_task.rb +129 -129
- data/lib/aws/simple_workflow/decision_task_collection.rb +59 -59
- data/lib/aws/simple_workflow/domain.rb +11 -11
- data/lib/aws/simple_workflow/domain_collection.rb +26 -26
- data/lib/aws/simple_workflow/history_event.rb +32 -32
- data/lib/aws/simple_workflow/history_event_collection.rb +3 -3
- data/lib/aws/simple_workflow/option_formatters.rb +5 -5
- data/lib/aws/simple_workflow/request.rb +1 -1
- data/lib/aws/simple_workflow/resource.rb +1 -1
- data/lib/aws/simple_workflow/type.rb +8 -8
- data/lib/aws/simple_workflow/type_collection.rb +15 -15
- data/lib/aws/simple_workflow/workflow_execution.rb +70 -72
- data/lib/aws/simple_workflow/workflow_execution_collection.rb +130 -130
- data/lib/aws/simple_workflow/workflow_type.rb +27 -25
- data/lib/aws/simple_workflow/workflow_type_collection.rb +20 -20
- data/lib/aws/sns.rb +25 -25
- data/lib/aws/sns/client.rb +55 -55
- data/lib/aws/sns/config.rb +1 -1
- data/lib/aws/sns/policy.rb +1 -1
- data/lib/aws/sns/subscription.rb +7 -7
- data/lib/aws/sns/subscription_collection.rb +5 -5
- data/lib/aws/sns/topic.rb +49 -49
- data/lib/aws/sns/topic_collection.rb +2 -2
- data/lib/aws/sns/topic_subscription_collection.rb +5 -5
- data/lib/aws/sqs.rb +20 -20
- data/lib/aws/sqs/client.rb +78 -78
- data/lib/aws/sqs/config.rb +1 -1
- data/lib/aws/sqs/errors.rb +12 -12
- data/lib/aws/sqs/queue.rb +66 -67
- data/lib/aws/sqs/queue_collection.rb +16 -8
- data/lib/aws/sqs/received_message.rb +7 -6
- data/lib/aws/storage_gateway.rb +21 -21
- data/lib/aws/storage_gateway/client.rb +269 -202
- data/lib/aws/storage_gateway/config.rb +1 -1
- data/lib/aws/sts.rb +10 -8
- data/lib/aws/sts/client.rb +35 -35
- data/lib/aws/sts/session.rb +3 -3
- data/lib/aws/version.rb +1 -2
- metadata +23 -21
- data/lib/aws/core/autoloader.rb +0 -64
- data/lib/net/http/connection_pool.rb +0 -226
- data/lib/net/http/connection_pool/connection.rb +0 -189
- data/lib/net/http/connection_pool/session.rb +0 -126
@@ -21,50 +21,50 @@ module AWS
|
|
21
21
|
# Provides an interface to count, and receive decision tasks
|
22
22
|
# ({DecisionTask} objects) from the service.
|
23
23
|
#
|
24
|
-
#
|
24
|
+
# ## Counting
|
25
25
|
#
|
26
26
|
# To get a count of decision tasks needing attention, call {#count}
|
27
27
|
# with a task list name:
|
28
28
|
#
|
29
|
-
#
|
29
|
+
# domain.decision_tasks.count('my-task-list').to_i #=> 7
|
30
30
|
#
|
31
|
-
#
|
31
|
+
# ## Getting a single decision task
|
32
32
|
#
|
33
33
|
# To process a single task use {#poll_for_single_task}:
|
34
34
|
#
|
35
|
-
#
|
36
|
-
#
|
37
|
-
#
|
38
|
-
#
|
35
|
+
# domain.decision_tasks.poll_for_single_task('my-task-list') do |task|
|
36
|
+
# # this block is yielded to only if a task is found
|
37
|
+
# # within 60 seconds.
|
38
|
+
# end
|
39
39
|
#
|
40
40
|
# At the end of the block, the decision task is auto-completed.
|
41
|
-
# If you prefer you can omit the block and
|
41
|
+
# If you prefer you can omit the block and `nil` or a {DecisionTask}
|
42
42
|
# will be returned.
|
43
43
|
#
|
44
|
-
#
|
45
|
-
#
|
46
|
-
#
|
47
|
-
#
|
44
|
+
# if task = domain.decision_tasks.poll_for_single_task('my-task-list')
|
45
|
+
# # you need to call complete! or the decision task will time out
|
46
|
+
# task.complete!
|
47
|
+
# end
|
48
48
|
#
|
49
|
-
#
|
49
|
+
# ## Polling for Tasks in a Loop
|
50
50
|
#
|
51
51
|
# You can poll indefinitely for tasks in a loop with {#poll}:
|
52
52
|
#
|
53
|
-
#
|
54
|
-
#
|
55
|
-
#
|
53
|
+
# domain.decision_tasks.poll('my-task-list') do |task|
|
54
|
+
# # yields once for every decision task found
|
55
|
+
# end
|
56
56
|
#
|
57
57
|
# Just like the block form above, the decision task is auto completed at
|
58
|
-
# the end of the block. Please note, if you call
|
58
|
+
# the end of the block. Please note, if you call `break` or `return`
|
59
59
|
# from inside the block, you *MUST* call {DecisionTask#complete!} or
|
60
60
|
# the task will timeout.
|
61
61
|
#
|
62
|
-
#
|
62
|
+
# ## Events and Decisions
|
63
63
|
#
|
64
64
|
# Each decision task provides an enumerable collection of both
|
65
|
-
# new events ({DecisionTask#new_events}) and all events
|
66
|
-
# ({DecisionTask#events}).
|
67
|
-
#
|
65
|
+
# new events ({DecisionTask#new_events}) and all events
|
66
|
+
# ({DecisionTask#events}).
|
67
|
+
#
|
68
68
|
# Based on the events in the workflow execution history, you should
|
69
69
|
# call methods on the decision task. See {DecisionTask} for
|
70
70
|
# a complete list of decision methods.
|
@@ -83,16 +83,16 @@ module AWS
|
|
83
83
|
# @return [Domain]
|
84
84
|
attr_reader :domain
|
85
85
|
|
86
|
-
# Returns the number of decision tasks in the specified
|
86
|
+
# Returns the number of decision tasks in the specified `task_list`.
|
87
87
|
#
|
88
|
-
#
|
89
|
-
#
|
90
|
-
#
|
88
|
+
# count = decision_tasks.count('task-list-name')
|
89
|
+
# count.truncated? #=> false
|
90
|
+
# count.to_i #=> 7
|
91
91
|
#
|
92
|
-
# @note This operation is eventually consistent. The results are best
|
92
|
+
# @note This operation is eventually consistent. The results are best
|
93
93
|
# effort and may not exactly reflect recent updates and changes.
|
94
94
|
#
|
95
|
-
# @param [String] task_list Name of the task list to count
|
95
|
+
# @param [String] task_list Name of the task list to count
|
96
96
|
# decision tasks for.
|
97
97
|
#
|
98
98
|
# @return [Count] Returns a {Count} object that specifies the number
|
@@ -108,44 +108,44 @@ module AWS
|
|
108
108
|
end
|
109
109
|
|
110
110
|
# Polls the service for a single decision task. The service may
|
111
|
-
# hold the request for up to 60 seconds before responding.
|
111
|
+
# hold the request for up to 60 seconds before responding.
|
112
112
|
#
|
113
|
-
#
|
114
|
-
#
|
115
|
-
#
|
116
|
-
#
|
117
|
-
#
|
118
|
-
#
|
113
|
+
# # try to get a single task, may return nil when no tasks available
|
114
|
+
# task = domain.decision_tasks.poll_for_single_task('task-list')
|
115
|
+
# if task
|
116
|
+
# # make decisions ...
|
117
|
+
# task.complete!
|
118
|
+
# end
|
119
119
|
#
|
120
120
|
# You can optionally pass a block and that will only be yielded
|
121
121
|
# to when a decision task is available within the 60 seconds.
|
122
122
|
#
|
123
|
-
#
|
124
|
-
#
|
125
|
-
#
|
126
|
-
#
|
123
|
+
# domain.decision_tasks.poll_for_single_task('task-list') do |task|
|
124
|
+
# # make decisions
|
125
|
+
# # task.complete! is called for you at the end of the block
|
126
|
+
# end
|
127
127
|
#
|
128
|
-
# With the block form you do not need to call #complete! on the
|
128
|
+
# With the block form you do not need to call #complete! on the
|
129
129
|
# decision task. It will be called when the block exists.
|
130
130
|
#
|
131
|
-
# @note If you are not using the block form you must call
|
131
|
+
# @note If you are not using the block form you must call
|
132
132
|
# {DecisionTask#complete!} yourself or your decision task will
|
133
133
|
# timeout.
|
134
134
|
#
|
135
|
-
# @param [String] task_list Specifies the task list to poll for
|
135
|
+
# @param [String] task_list Specifies the task list to poll for
|
136
136
|
# decision tasks.
|
137
137
|
#
|
138
138
|
# @param [Hash] options
|
139
139
|
#
|
140
|
-
# @option options [String] :identity The identity of the decider
|
140
|
+
# @option options [String] :identity The identity of the decider
|
141
141
|
# requesting a decision task. This will be recorded in the
|
142
|
-
# DecisionTaskStarted event in the workflow history.
|
143
|
-
# If
|
142
|
+
# DecisionTaskStarted event in the workflow history.
|
143
|
+
# If `:identity` is not passed then the hostname and
|
144
144
|
# process id will be sent (e.g. "hostname:pid").
|
145
145
|
#
|
146
|
-
# @option options [Boolean] :reverse_event_order (false) When true,
|
147
|
-
# the history events on the decision task will enumerate in
|
148
|
-
# reverse chronological order (newest events first). By default
|
146
|
+
# @option options [Boolean] :reverse_event_order (false) When true,
|
147
|
+
# the history events on the decision task will enumerate in
|
148
|
+
# reverse chronological order (newest events first). By default
|
149
149
|
# the events are enumerated in chronological order (oldest first).
|
150
150
|
#
|
151
151
|
# @option options [Integer] :event_batch_size (1000) When enumerating
|
@@ -154,10 +154,10 @@ module AWS
|
|
154
154
|
# of events to request each time (must not be greater than 1000).
|
155
155
|
#
|
156
156
|
# @yieldparam [DecisionTask] decision_task
|
157
|
-
#
|
158
|
-
# @return [DecisionTask,nil] Returns a decision task or
|
159
|
-
# a block was passed then
|
160
|
-
# is not passed, then
|
157
|
+
#
|
158
|
+
# @return [DecisionTask,nil] Returns a decision task or `nil`. If
|
159
|
+
# a block was passed then `nil` is always returned. If a block
|
160
|
+
# is not passed, then `nil` or a {DecisionTask} will be returned.
|
161
161
|
#
|
162
162
|
def poll_for_single_task task_list, options = {}, &block
|
163
163
|
|
@@ -190,25 +190,25 @@ module AWS
|
|
190
190
|
# yielded to the block. At the end of the block the decision task
|
191
191
|
# is auto-completed ({DecisionTask#complete!} is called).
|
192
192
|
#
|
193
|
-
#
|
194
|
-
#
|
195
|
-
#
|
196
|
-
#
|
193
|
+
# # yields once for each decision task found, indefinitely
|
194
|
+
# domain.decision_tasks.poll do |decision_task|
|
195
|
+
# # make decisions here
|
196
|
+
# end
|
197
197
|
#
|
198
|
-
# @note If you to terminate the block (by calling
|
199
|
-
# then it is your responsibility to call #complete! on the decision
|
198
|
+
# @note If you to terminate the block (by calling `break` or `return`)
|
199
|
+
# then it is your responsibility to call #complete! on the decision
|
200
200
|
# task.
|
201
201
|
#
|
202
202
|
# @param (see #poll_for_single_task)
|
203
203
|
#
|
204
204
|
# @option (see #poll_for_single_task)
|
205
|
-
#
|
205
|
+
#
|
206
206
|
# @yieldparam [DecisionTask] decision_task
|
207
207
|
#
|
208
208
|
# @return [nil]
|
209
209
|
#
|
210
210
|
def poll task_list, options = {}, &block
|
211
|
-
loop do
|
211
|
+
loop do
|
212
212
|
begin
|
213
213
|
poll_for_single_task(task_list, options) do |decision_task|
|
214
214
|
yield(decision_task)
|
@@ -14,18 +14,18 @@
|
|
14
14
|
module AWS
|
15
15
|
class SimpleWorkflow
|
16
16
|
|
17
|
-
# Domains are used to organize workflows types and activities for
|
17
|
+
# Domains are used to organize workflows types and activities for
|
18
18
|
# an account.
|
19
19
|
#
|
20
|
-
# @attr_reader [String,nil] description Returns
|
20
|
+
# @attr_reader [String,nil] description Returns
|
21
21
|
#
|
22
22
|
# @attr_reader [Integer,Symbol] retention_period Returns the retention
|
23
23
|
# period for this domain. The return value may be an integer (number
|
24
|
-
# of days history is kept around) or the symbol
|
24
|
+
# of days history is kept around) or the symbol `:none`, implying
|
25
25
|
# no expiry of closed workflow executions.
|
26
26
|
#
|
27
27
|
# @attr_reader [Symbol] status Returns the domain's status. Status will
|
28
|
-
# be either
|
28
|
+
# be either `:registered` or `:deprecated`.
|
29
29
|
#
|
30
30
|
class Domain < Resource
|
31
31
|
|
@@ -44,7 +44,7 @@ module AWS
|
|
44
44
|
|
45
45
|
info_attribute :status, :to_sym => true
|
46
46
|
|
47
|
-
config_attribute :retention_period,
|
47
|
+
config_attribute :retention_period,
|
48
48
|
:from => 'workflowExecutionRetentionPeriodInDays',
|
49
49
|
:duration => true,
|
50
50
|
:static => true
|
@@ -79,15 +79,15 @@ module AWS
|
|
79
79
|
self.status == :deprecated
|
80
80
|
end
|
81
81
|
|
82
|
-
# Deprecates the domain. After a domain has been deprecated it cannot
|
83
|
-
# be used to create new workflow executions or register new types.
|
84
|
-
# However, you can still use visibility actions on this domain.
|
82
|
+
# Deprecates the domain. After a domain has been deprecated it cannot
|
83
|
+
# be used to create new workflow executions or register new types.
|
84
|
+
# However, you can still use visibility actions on this domain.
|
85
85
|
#
|
86
|
-
# Deprecating a domain also deprecates all activity and workflow
|
87
|
-
# types registered in the domain. Executions that were started
|
86
|
+
# Deprecating a domain also deprecates all activity and workflow
|
87
|
+
# types registered in the domain. Executions that were started
|
88
88
|
# before the domain was deprecated will continue to run.
|
89
89
|
#
|
90
|
-
# @return [nil]
|
90
|
+
# @return [nil]
|
91
91
|
#
|
92
92
|
def deprecate
|
93
93
|
client.deprecate_domain(:name => name)
|
@@ -17,34 +17,34 @@ module AWS
|
|
17
17
|
# The primary interface for registering, listing and deprecating
|
18
18
|
# domains.
|
19
19
|
#
|
20
|
-
#
|
20
|
+
# ## Creating a Domain
|
21
21
|
#
|
22
22
|
# To create a domain you need to pass a unique name to #create.
|
23
23
|
#
|
24
|
-
#
|
25
|
-
#
|
24
|
+
# domain = simple_workflow.domains.create('my-domain', :none)
|
25
|
+
# #=> #<AWS::SimpleWorkflow::Domain name:my-domain>
|
26
26
|
#
|
27
|
-
#
|
27
|
+
# ## Getting a Domain
|
28
28
|
#
|
29
29
|
# Domains are indexed by their name.
|
30
30
|
#
|
31
|
-
#
|
31
|
+
# domain = simple_workflow.domains['my-domain']
|
32
32
|
#
|
33
|
-
#
|
33
|
+
# ## Enumerating Domains
|
34
34
|
#
|
35
35
|
# You can call Enumerable methods on a domain collection to iterate
|
36
36
|
# the domains controlled by your account.
|
37
37
|
#
|
38
|
-
#
|
38
|
+
# simple_workflow.domains.each {|domain| ... }
|
39
39
|
#
|
40
40
|
# By default only registered domains are enumerated. If you would like
|
41
41
|
# to enumerate deprecated (deleted) domains you need to pass the
|
42
|
-
#
|
42
|
+
# `:deprecated` option.
|
43
43
|
#
|
44
|
-
#
|
45
|
-
#
|
44
|
+
# # returns an array of names for all deprecated domains
|
45
|
+
# simple_workflow.domains.deprecated.map(&:name)
|
46
46
|
#
|
47
|
-
# See {AWS::Core::Collection} to see other useful methods you can
|
47
|
+
# See {AWS::Core::Collection} to see other useful methods you can
|
48
48
|
# call against a domain collection (e.g. #enum, #page, #each_batch).
|
49
49
|
#
|
50
50
|
class DomainCollection
|
@@ -53,8 +53,8 @@ module AWS
|
|
53
53
|
include Core::Collection::WithLimitAndNextToken
|
54
54
|
|
55
55
|
def initialize options = {}
|
56
|
-
|
57
|
-
@registration_status = options[:registration_status] ?
|
56
|
+
|
57
|
+
@registration_status = options[:registration_status] ?
|
58
58
|
options[:registration_status].to_s.upcase : 'REGISTERED'
|
59
59
|
|
60
60
|
@reverse_order = options.key?(:reverse_order) ?
|
@@ -66,23 +66,23 @@ module AWS
|
|
66
66
|
|
67
67
|
# Registers a new domain.
|
68
68
|
#
|
69
|
-
#
|
70
|
-
#
|
71
|
-
#
|
69
|
+
# # register a domain named 'domain' that has no expiry on workflow
|
70
|
+
# # execution history
|
71
|
+
# domain = AWS::SimpleWorkflow.new.domains.register('domain', :none)
|
72
72
|
#
|
73
|
-
# @param [String] name Name of the domain to register. The name must
|
74
|
-
# be unique.
|
73
|
+
# @param [String] name Name of the domain to register. The name must
|
74
|
+
# be unique.
|
75
75
|
#
|
76
|
-
# @param [Integer,:none] retention_period A duration (in days)
|
77
|
-
# for which the record (including the history) of workflow
|
78
|
-
# executions in this domain should be kept by the service.
|
79
|
-
# After the retention period, the workflow execution will not be
|
76
|
+
# @param [Integer,:none] retention_period A duration (in days)
|
77
|
+
# for which the record (including the history) of workflow
|
78
|
+
# executions in this domain should be kept by the service.
|
79
|
+
# After the retention period, the workflow execution will not be
|
80
80
|
# available in the results of visibility calls.
|
81
81
|
#
|
82
|
-
# If you pass the symbol
|
82
|
+
# If you pass the symbol `:none` then there is no expiration for
|
83
83
|
# workflow execution history (effectively an infinite retention
|
84
84
|
# period).
|
85
|
-
#
|
85
|
+
#
|
86
86
|
# @param [Hash] options
|
87
87
|
#
|
88
88
|
# @option [String] :description (nil) Textual description of the domain.
|
@@ -146,7 +146,7 @@ module AWS
|
|
146
146
|
options[:maximum_page_size] = limit if limit
|
147
147
|
options[:next_page_token] = next_token if next_token
|
148
148
|
options[:registration_status] ||= @registration_status
|
149
|
-
options[:reverse_order] = @reverse_order unless
|
149
|
+
options[:reverse_order] = @reverse_order unless
|
150
150
|
options.has_key?(:reverse_order)
|
151
151
|
|
152
152
|
response = client.list_domains(options)
|
@@ -156,7 +156,7 @@ module AWS
|
|
156
156
|
desc['name'], :config => config)
|
157
157
|
|
158
158
|
yield(domain)
|
159
|
-
|
159
|
+
|
160
160
|
end
|
161
161
|
|
162
162
|
response.data['nextPageToken']
|
@@ -16,25 +16,25 @@ require 'json'
|
|
16
16
|
module AWS
|
17
17
|
class SimpleWorkflow
|
18
18
|
|
19
|
-
#
|
19
|
+
# ## Getting History Events
|
20
20
|
#
|
21
|
-
# History events belong to workflow executions. You can get them
|
21
|
+
# History events belong to workflow executions. You can get them
|
22
22
|
# from an execution two ways:
|
23
23
|
#
|
24
|
-
#
|
24
|
+
# * By enumerating events from the execution
|
25
25
|
#
|
26
|
-
#
|
27
|
-
#
|
28
|
-
#
|
26
|
+
# workflow_execution.events.each do |event|
|
27
|
+
# # ...
|
28
|
+
# end
|
29
29
|
#
|
30
|
-
#
|
30
|
+
# * By enumerating events from the context of a {DecisionTask}:
|
31
31
|
#
|
32
|
-
#
|
33
|
-
#
|
34
|
-
#
|
35
|
-
#
|
32
|
+
# workflow_execution.decision_tasks.poll do |decision_task|
|
33
|
+
# decision_task.events.each do |event|
|
34
|
+
# end
|
35
|
+
# end
|
36
36
|
#
|
37
|
-
#
|
37
|
+
# ## History Event Attributes
|
38
38
|
#
|
39
39
|
# All history events respond to the following 4 methods:
|
40
40
|
#
|
@@ -42,7 +42,7 @@ module AWS
|
|
42
42
|
# * {#event_id}
|
43
43
|
# * {#created_at}
|
44
44
|
# * {#attributes}
|
45
|
-
#
|
45
|
+
#
|
46
46
|
# For a complete list of event types and a complete list of attributes
|
47
47
|
# returned with each event type, see the service API documentation.
|
48
48
|
#
|
@@ -50,12 +50,12 @@ module AWS
|
|
50
50
|
# structure returned by {#attributes} allows you to access attributes
|
51
51
|
# by their snake_case name or their camelCase name:
|
52
52
|
#
|
53
|
-
#
|
54
|
-
#
|
53
|
+
# event.attributes.workflow_type
|
54
|
+
# event.attributes['workflowType']
|
55
55
|
#
|
56
56
|
# See {HistoryEvent::Attributes} for more information about working
|
57
57
|
# with the returned attributes.
|
58
|
-
#
|
58
|
+
#
|
59
59
|
class HistoryEvent
|
60
60
|
|
61
61
|
include Core::Model
|
@@ -63,7 +63,7 @@ module AWS
|
|
63
63
|
# @param [WorkflowExecution] workflow_execution
|
64
64
|
#
|
65
65
|
# @param [Hash,String] details A hash or JSON string describing
|
66
|
-
# the history event.
|
66
|
+
# the history event.
|
67
67
|
#
|
68
68
|
def initialize workflow_execution, details
|
69
69
|
|
@@ -129,28 +129,28 @@ module AWS
|
|
129
129
|
# the service API documentation that lists all history event types
|
130
130
|
# along with their returned attributes.
|
131
131
|
#
|
132
|
-
#
|
132
|
+
# ## Indifferent Access
|
133
133
|
#
|
134
|
-
# Here are a few examples showing the different ways to access an
|
134
|
+
# Here are a few examples showing the different ways to access an
|
135
135
|
# attribute:
|
136
136
|
#
|
137
|
-
#
|
137
|
+
# event = workflow_executions.events.first
|
138
138
|
#
|
139
|
-
#
|
140
|
-
#
|
141
|
-
#
|
142
|
-
#
|
143
|
-
#
|
139
|
+
# # equivalent
|
140
|
+
# event.attributes.task_list
|
141
|
+
# event.attributes[:task_list]
|
142
|
+
# event.attributes['task_list']
|
143
|
+
# event.attributes['taskList']
|
144
144
|
#
|
145
145
|
# As shown in the example above keys and method names can be
|
146
146
|
# snake_cased or camelCased (strings or symbols).
|
147
147
|
#
|
148
|
-
#
|
149
|
-
#
|
148
|
+
# ## Special Attributes
|
149
|
+
#
|
150
150
|
# The following list of attributes are treated specially. Generally this
|
151
|
-
# means they return
|
151
|
+
# means they return
|
152
152
|
#
|
153
|
-
# * timeout attributes (e.g. taskStartToCloseTimeout) are returned as
|
153
|
+
# * timeout attributes (e.g. taskStartToCloseTimeout) are returned as
|
154
154
|
# integers (number of seconds) or the special symbol :none, implying
|
155
155
|
# there is no timeout.
|
156
156
|
#
|
@@ -165,7 +165,7 @@ module AWS
|
|
165
165
|
# * taskList is returned as a string, not a hash.
|
166
166
|
#
|
167
167
|
class Attributes
|
168
|
-
|
168
|
+
|
169
169
|
# @private
|
170
170
|
def initialize workflow_execution, data
|
171
171
|
@workflow_execution = workflow_execution
|
@@ -184,7 +184,7 @@ module AWS
|
|
184
184
|
end
|
185
185
|
end
|
186
186
|
|
187
|
-
# @return [Array<Symbol>] Returns a list of valid keys for this
|
187
|
+
# @return [Array<Symbol>] Returns a list of valid keys for this
|
188
188
|
# set of attributes.
|
189
189
|
def keys
|
190
190
|
@data.keys.collect{|key| _snake_case(key) }
|
@@ -204,7 +204,7 @@ module AWS
|
|
204
204
|
self[method]
|
205
205
|
end
|
206
206
|
|
207
|
-
# @return [Hash] Returns all of the attributes in a hash with
|
207
|
+
# @return [Hash] Returns all of the attributes in a hash with
|
208
208
|
# snaked_cased and symbolized keys.
|
209
209
|
def to_h
|
210
210
|
@data.inject({}) do |h,(key,value)|
|