fog-google 0.1.3 → 0.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.editorconfig +11 -0
- data/.gitignore +1 -0
- data/.hound.yml +2 -0
- data/.rubocop.yml +225 -5
- data/.travis.yml +13 -11
- data/CONTRIBUTORS.md +1 -0
- data/Gemfile +1 -1
- data/README.md +31 -16
- data/Rakefile +15 -39
- data/examples/backend_services.rb +12 -11
- data/examples/bootstrap.rb +11 -1
- data/examples/{create.rb → create_instance.rb} +20 -11
- data/examples/dns/project.rb +2 -3
- data/examples/dns/zones.rb +21 -21
- data/examples/get_list_images.rb +31 -15
- data/examples/get_list_snapshots.rb +20 -10
- data/examples/image_create.rb +5 -5
- data/examples/l7_load_balance.rb +56 -58
- data/examples/load-balance.rb +22 -23
- data/examples/metadata.rb +17 -9
- data/examples/monitoring/metric_descriptors.rb +19 -6
- data/examples/monitoring/timeseries_collection.rb +23 -11
- data/examples/monitoring/timeseries_descriptors.rb +23 -11
- data/examples/network.rb +25 -29
- data/examples/precreated_client.rb +3 -6
- data/examples/sql/flags.rb +2 -2
- data/examples/sql/instances.rb +18 -18
- data/examples/sql/operations.rb +9 -9
- data/examples/sql/ssl_certs.rb +13 -13
- data/examples/sql/tiers.rb +2 -2
- data/examples/storage.rb +37 -0
- data/examples/storage_json.rb +37 -0
- data/fog-google.gemspec +24 -21
- data/lib/fog/bin/google.rb +34 -32
- data/lib/fog/{google/compute.rb → compute/google.rb} +207 -151
- data/lib/fog/{google/models/compute → compute/google/models}/address.rb +24 -28
- data/lib/fog/{google/models/compute → compute/google/models}/addresses.rb +10 -14
- data/lib/fog/{google/models/compute → compute/google/models}/backend_service.rb +28 -34
- data/lib/fog/{google/models/compute → compute/google/models}/backend_services.rb +2 -5
- data/lib/fog/{google/models/compute → compute/google/models}/disk.rb +35 -39
- data/lib/fog/{google/models/compute → compute/google/models}/disk_type.rb +4 -6
- data/lib/fog/{google/models/compute → compute/google/models}/disk_types.rb +7 -10
- data/lib/fog/{google/models/compute → compute/google/models}/disks.rb +9 -12
- data/lib/fog/{google/models/compute → compute/google/models}/firewall.rb +10 -14
- data/lib/fog/{google/models/compute → compute/google/models}/firewalls.rb +1 -4
- data/lib/fog/compute/google/models/flavor.rb +31 -0
- data/lib/fog/{google/models/compute → compute/google/models}/flavors.rb +2 -5
- data/lib/fog/{google/models/compute → compute/google/models}/forwarding_rule.rb +24 -28
- data/lib/fog/{google/models/compute → compute/google/models}/forwarding_rules.rb +8 -11
- data/lib/fog/compute/google/models/global_forwarding_rule.rb +82 -0
- data/lib/fog/{google/models/compute → compute/google/models}/global_forwarding_rules.rb +2 -5
- data/lib/fog/compute/google/models/http_health_check.rb +80 -0
- data/lib/fog/{google/models/compute → compute/google/models}/http_health_checks.rb +2 -5
- data/lib/fog/{google/models/compute → compute/google/models}/image.rb +18 -22
- data/lib/fog/{google/models/compute → compute/google/models}/images.rb +24 -17
- data/lib/fog/{google/models/compute → compute/google/models}/instance_group.rb +5 -8
- data/lib/fog/{google/models/compute → compute/google/models}/instance_groups.rb +10 -13
- data/lib/fog/{google/models/compute → compute/google/models}/network.rb +9 -13
- data/lib/fog/{google/models/compute → compute/google/models}/networks.rb +1 -4
- data/lib/fog/{google/models/compute → compute/google/models}/operation.rb +16 -18
- data/lib/fog/{google/models/compute → compute/google/models}/operations.rb +8 -11
- data/lib/fog/{google/models/compute → compute/google/models}/project.rb +5 -7
- data/lib/fog/{google/models/compute → compute/google/models}/projects.rb +0 -3
- data/lib/fog/{google/models/compute → compute/google/models}/region.rb +5 -7
- data/lib/fog/{google/models/compute → compute/google/models}/regions.rb +1 -4
- data/lib/fog/compute/google/models/resource_view.rb +108 -0
- data/lib/fog/compute/google/models/resource_views.rb +54 -0
- data/lib/fog/{google/models/compute → compute/google/models}/route.rb +12 -16
- data/lib/fog/{google/models/compute → compute/google/models}/routes.rb +1 -4
- data/lib/fog/{google/models/compute → compute/google/models}/server.rb +81 -92
- data/lib/fog/{google/models/compute → compute/google/models}/servers.rb +13 -16
- data/lib/fog/compute/google/models/snapshot.rb +44 -0
- data/lib/fog/{google/models/compute → compute/google/models}/snapshots.rb +1 -4
- data/lib/fog/compute/google/models/subnetwork.rb +49 -0
- data/lib/fog/compute/google/models/subnetworks.rb +29 -0
- data/lib/fog/{google/models/compute → compute/google/models}/target_http_proxies.rb +2 -5
- data/lib/fog/{google/models/compute → compute/google/models}/target_http_proxy.rb +18 -22
- data/lib/fog/{google/models/compute → compute/google/models}/target_instance.rb +23 -28
- data/lib/fog/{google/models/compute → compute/google/models}/target_instances.rb +9 -12
- data/lib/fog/{google/models/compute → compute/google/models}/target_pool.rb +24 -28
- data/lib/fog/{google/models/compute → compute/google/models}/target_pools.rb +6 -9
- data/lib/fog/{google/models/compute → compute/google/models}/url_map.rb +32 -36
- data/lib/fog/{google/models/compute → compute/google/models}/url_maps.rb +1 -4
- data/lib/fog/compute/google/models/zone.rb +21 -0
- data/lib/fog/{google/models/compute → compute/google/models}/zones.rb +0 -3
- data/lib/fog/{google/requests/compute → compute/google/requests}/add_backend_service_backends.rb +5 -5
- data/lib/fog/{google/requests/compute → compute/google/requests}/add_instance_group_instance.rb +4 -4
- data/lib/fog/compute/google/requests/add_region_view_resources.rb +27 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/add_server_access_config.rb +8 -8
- data/lib/fog/{google/requests/compute → compute/google/requests}/add_target_pool_health_checks.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/add_target_pool_instances.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/add_url_map_host_rules.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/add_url_map_path_matchers.rb +7 -7
- data/lib/fog/compute/google/requests/add_zone_view_resources.rb +27 -0
- data/lib/fog/compute/google/requests/attach_disk.rb +34 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_address.rb +4 -4
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_backend_service.rb +8 -8
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_disk.rb +9 -11
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_firewall.rb +3 -3
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_forwarding_rule.rb +8 -8
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_global_forwarding_rule.rb +12 -12
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_global_operation.rb +3 -3
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_http_health_check.rb +7 -7
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_image.rb +7 -7
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_instance_group.rb +4 -4
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_network.rb +3 -3
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_region_operation.rb +6 -6
- data/lib/fog/compute/google/requests/delete_region_view.rb +24 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_route.rb +3 -3
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_server.rb +15 -17
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_server_access_config.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_snapshot.rb +3 -3
- data/lib/fog/compute/google/requests/delete_subnetwork.rb +49 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_target_http_proxy.rb +7 -7
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_target_instance.rb +9 -11
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_target_pool.rb +8 -8
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_url_map.rb +7 -7
- data/lib/fog/{google/requests/compute → compute/google/requests}/delete_zone_operation.rb +5 -7
- data/lib/fog/compute/google/requests/delete_zone_view.rb +24 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/detach_disk.rb +5 -5
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_address.rb +4 -4
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_backend_service.rb +5 -7
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_backend_service_health.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_backend_services.rb +6 -6
- data/lib/fog/compute/google/requests/get_disk.rb +46 -0
- data/lib/fog/compute/google/requests/get_disk_type.rb +40 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_firewall.rb +3 -3
- data/lib/fog/compute/google/requests/get_forwarding_rule.rb +44 -0
- data/lib/fog/compute/google/requests/get_global_forwarding_rule.rb +30 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_global_operation.rb +8 -8
- data/lib/fog/compute/google/requests/get_http_health_check.rb +37 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_image.rb +4 -4
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_instance_group.rb +5 -5
- data/lib/fog/compute/google/requests/get_machine_type.rb +41 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_network.rb +3 -3
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_project.rb +2 -2
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_region.rb +9 -9
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_region_operation.rb +11 -11
- data/lib/fog/compute/google/requests/get_region_view.rb +24 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_route.rb +3 -3
- data/lib/fog/compute/google/requests/get_server.rb +71 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_server_serial_port_output.rb +4 -4
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_snapshot.rb +5 -7
- data/lib/fog/compute/google/requests/get_subnetwork.rb +45 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_target_http_proxy.rb +4 -6
- data/lib/fog/compute/google/requests/get_target_instance.rb +28 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_target_pool.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_target_pool_health.rb +7 -7
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_url_map.rb +4 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_zone.rb +8 -8
- data/lib/fog/{google/requests/compute → compute/google/requests}/get_zone_operation.rb +10 -12
- data/lib/fog/compute/google/requests/get_zone_view.rb +24 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_address.rb +5 -5
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_backend_service.rb +17 -17
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_disk.rb +26 -30
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_firewall.rb +4 -4
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_forwarding_rule.rb +13 -13
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_global_forwarding_rule.rb +13 -13
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_http_health_check.rb +11 -11
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_image.rb +14 -14
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_instance_group.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_network.rb +6 -6
- data/lib/fog/compute/google/requests/insert_region_view.rb +25 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_route.rb +11 -11
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_server.rb +57 -57
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_snapshot.rb +8 -8
- data/lib/fog/compute/google/requests/insert_subnetwork.rb +75 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_target_http_proxy.rb +9 -9
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_target_instance.rb +11 -11
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_target_pool.rb +11 -11
- data/lib/fog/{google/requests/compute → compute/google/requests}/insert_url_map.rb +9 -9
- data/lib/fog/compute/google/requests/insert_zone_view.rb +26 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_addresses.rb +3 -3
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_aggregated_addresses.rb +3 -3
- data/lib/fog/compute/google/requests/list_aggregated_disk_types.rb +38 -0
- data/lib/fog/compute/google/requests/list_aggregated_disks.rb +37 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_aggregated_instance_groups.rb +3 -3
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_aggregated_machine_types.rb +1 -1
- data/lib/fog/compute/google/requests/list_aggregated_servers.rb +37 -0
- data/lib/fog/compute/google/requests/list_aggregated_subnetworks.rb +34 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_aggregated_target_instances.rb +10 -13
- data/lib/fog/compute/google/requests/list_backend_services.rb +27 -0
- data/lib/fog/compute/google/requests/list_disk_types.rb +44 -0
- data/lib/fog/compute/google/requests/list_disks.rb +27 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_firewalls.rb +1 -1
- data/lib/fog/compute/google/requests/list_forwarding_rules.rb +27 -0
- data/lib/fog/compute/google/requests/list_global_forwarding_rules.rb +28 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_global_operations.rb +1 -1
- data/lib/fog/compute/google/requests/list_http_health_checks.rb +27 -0
- data/lib/fog/compute/google/requests/list_images.rb +27 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_instance_group_instances.rb +4 -4
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_instance_groups.rb +3 -3
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_machine_types.rb +6 -8
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_networks.rb +1 -1
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_region_operations.rb +3 -3
- data/lib/fog/compute/google/requests/list_region_view_resources.rb +24 -0
- data/lib/fog/compute/google/requests/list_region_views.rb +23 -0
- data/lib/fog/compute/google/requests/list_regions.rb +83 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_routes.rb +2 -2
- data/lib/fog/compute/google/requests/list_servers.rb +29 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_snapshots.rb +3 -3
- data/lib/fog/compute/google/requests/list_subnetworks.rb +35 -0
- data/lib/fog/compute/google/requests/list_target_http_proxies.rb +27 -0
- data/lib/fog/compute/google/requests/list_target_instances.rb +28 -0
- data/lib/fog/compute/google/requests/list_target_pools.rb +27 -0
- data/lib/fog/compute/google/requests/list_url_maps.rb +27 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/list_zone_operations.rb +3 -3
- data/lib/fog/compute/google/requests/list_zone_view_resources.rb +24 -0
- data/lib/fog/compute/google/requests/list_zone_views.rb +23 -0
- data/lib/fog/compute/google/requests/list_zones.rb +26 -0
- data/lib/fog/{google/requests/compute → compute/google/requests}/remove_instance_group_instance.rb +4 -4
- data/lib/fog/{google/requests/compute → compute/google/requests}/remove_target_pool_health_checks.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/remove_target_pool_instance.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/remove_target_pool_instances.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/reset_server.rb +4 -4
- data/lib/fog/{google/requests/compute → compute/google/requests}/set_common_instance_metadata.rb +3 -3
- data/lib/fog/{google/requests/compute → compute/google/requests}/set_forwarding_rule_target.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/set_global_forwarding_rule_target.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/set_metadata.rb +8 -8
- data/lib/fog/{google/requests/compute → compute/google/requests}/set_server_disk_auto_delete.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/set_server_scheduling.rb +7 -7
- data/lib/fog/{google/requests/compute → compute/google/requests}/set_tags.rb +6 -6
- data/lib/fog/{google/requests/compute → compute/google/requests}/set_target_http_proxy_url_map.rb +5 -5
- data/lib/fog/{google/requests/compute → compute/google/requests}/start_server.rb +4 -4
- data/lib/fog/{google/requests/compute → compute/google/requests}/stop_server.rb +4 -4
- data/lib/fog/{google/requests/compute → compute/google/requests}/update_url_map.rb +8 -8
- data/lib/fog/{google/requests/compute → compute/google/requests}/validate_url_map.rb +5 -5
- data/lib/fog/{google/dns.rb → dns/google.rb} +9 -9
- data/lib/fog/{google/models/dns → dns/google/models}/change.rb +5 -7
- data/lib/fog/{google/models/dns → dns/google/models}/changes.rb +1 -4
- data/lib/fog/{google/models/dns → dns/google/models}/project.rb +6 -8
- data/lib/fog/{google/models/dns → dns/google/models}/projects.rb +0 -3
- data/lib/fog/{google/models/dns → dns/google/models}/record.rb +17 -27
- data/lib/fog/{google/models/dns → dns/google/models}/records.rb +2 -5
- data/lib/fog/{google/models/dns → dns/google/models}/zone.rb +6 -8
- data/lib/fog/{google/models/dns → dns/google/models}/zones.rb +1 -4
- data/lib/fog/{google/requests/dns → dns/google/requests}/create_change.rb +17 -17
- data/lib/fog/dns/google/requests/create_managed_zone.rb +82 -0
- data/lib/fog/{google/requests/dns → dns/google/requests}/delete_managed_zone.rb +6 -6
- data/lib/fog/{google/requests/dns → dns/google/requests}/get_change.rb +7 -7
- data/lib/fog/{google/requests/dns → dns/google/requests}/get_managed_zone.rb +4 -4
- data/lib/fog/{google/requests/dns → dns/google/requests}/get_project.rb +12 -12
- data/lib/fog/{google/requests/dns → dns/google/requests}/list_changes.rb +7 -7
- data/lib/fog/{google/requests/dns → dns/google/requests}/list_managed_zones.rb +5 -5
- data/lib/fog/{google/requests/dns → dns/google/requests}/list_resource_record_sets.rb +11 -11
- data/lib/fog/google.rb +78 -71
- data/lib/fog/google/models/monitoring/metric_descriptor.rb +3 -3
- data/lib/fog/google/models/monitoring/metric_descriptors.rb +3 -3
- data/lib/fog/google/models/monitoring/timeseries.rb +2 -2
- data/lib/fog/google/models/monitoring/timeseries_collection.rb +3 -3
- data/lib/fog/google/models/monitoring/timeseries_descriptor.rb +1 -1
- data/lib/fog/google/models/monitoring/timeseries_descriptors.rb +3 -3
- data/lib/fog/google/models/sql/backup_run.rb +8 -8
- data/lib/fog/google/models/sql/backup_runs.rb +3 -3
- data/lib/fog/google/models/sql/flag.rb +5 -5
- data/lib/fog/google/models/sql/flags.rb +3 -3
- data/lib/fog/google/models/sql/instance.rb +54 -68
- data/lib/fog/google/models/sql/instances.rb +4 -4
- data/lib/fog/google/models/sql/operation.rb +15 -15
- data/lib/fog/google/models/sql/operations.rb +5 -5
- data/lib/fog/google/models/sql/ssl_cert.rb +17 -19
- data/lib/fog/google/models/sql/ssl_certs.rb +5 -5
- data/lib/fog/google/models/sql/tier.rb +3 -3
- data/lib/fog/google/models/sql/tiers.rb +3 -3
- data/lib/fog/google/monitoring.rb +8 -8
- data/lib/fog/google/requests/monitoring/list_metric_descriptors.rb +131 -131
- data/lib/fog/google/requests/monitoring/list_timeseries.rb +32 -32
- data/lib/fog/google/requests/monitoring/list_timeseries_descriptors.rb +50 -50
- data/lib/fog/google/requests/sql/clone_instance.rb +41 -41
- data/lib/fog/google/requests/sql/delete_instance.rb +26 -26
- data/lib/fog/google/requests/sql/delete_ssl_cert.rb +27 -27
- data/lib/fog/google/requests/sql/export_instance.rb +22 -22
- data/lib/fog/google/requests/sql/get_backup_run.rb +5 -5
- data/lib/fog/google/requests/sql/get_instance.rb +12 -12
- data/lib/fog/google/requests/sql/get_operation.rb +21 -21
- data/lib/fog/google/requests/sql/get_ssl_cert.rb +21 -21
- data/lib/fog/google/requests/sql/import_instance.rb +21 -21
- data/lib/fog/google/requests/sql/insert_instance.rb +76 -78
- data/lib/fog/google/requests/sql/insert_ssl_cert.rb +33 -33
- data/lib/fog/google/requests/sql/list_backup_runs.rb +4 -4
- data/lib/fog/google/requests/sql/list_flags.rb +84 -84
- data/lib/fog/google/requests/sql/list_instances.rb +3 -3
- data/lib/fog/google/requests/sql/list_operations.rb +13 -13
- data/lib/fog/google/requests/sql/list_ssl_certs.rb +13 -13
- data/lib/fog/google/requests/sql/list_tiers.rb +39 -39
- data/lib/fog/google/requests/sql/reset_instance_ssl_config.rb +16 -16
- data/lib/fog/google/requests/sql/restart_instance.rb +16 -16
- data/lib/fog/google/requests/sql/restore_instance_backup.rb +5 -5
- data/lib/fog/google/requests/sql/set_instance_root_password.rb +20 -20
- data/lib/fog/google/requests/sql/update_instance.rb +52 -52
- data/lib/fog/google/sql.rb +7 -7
- data/lib/fog/google/version.rb +1 -1
- data/lib/fog/parsers/storage/google.rb +15 -0
- data/lib/fog/{google/parsers/storage → parsers/storage/google}/access_control_list.rb +13 -13
- data/lib/fog/{google/parsers/storage → parsers/storage/google}/copy_object.rb +3 -3
- data/lib/fog/parsers/storage/google/get_bucket.rb +58 -0
- data/lib/fog/parsers/storage/google/get_bucket_logging.rb +36 -0
- data/lib/fog/parsers/storage/google/get_bucket_object_versions.rb +84 -0
- data/lib/fog/{google/parsers/storage → parsers/storage/google}/get_bucket_versioning.rb +3 -3
- data/lib/fog/{google/parsers/storage → parsers/storage/google}/get_request_payment.rb +1 -1
- data/lib/fog/{google/parsers/storage → parsers/storage/google}/get_service.rb +8 -8
- data/lib/fog/storage/google.rb +20 -0
- data/lib/fog/storage/google_json.rb +146 -0
- data/lib/fog/storage/google_json/models/directories.rb +26 -0
- data/lib/fog/storage/google_json/models/directory.rb +65 -0
- data/lib/fog/storage/google_json/models/file.rb +148 -0
- data/lib/fog/storage/google_json/models/files.rb +89 -0
- data/lib/fog/storage/google_json/requests/copy_object.rb +66 -0
- data/lib/fog/storage/google_json/requests/delete_bucket.rb +42 -0
- data/lib/fog/{google/requests/storage → storage/google_json/requests}/delete_object.rb +12 -12
- data/lib/fog/storage/google_json/requests/get_bucket.rb +86 -0
- data/lib/fog/{google/requests/storage → storage/google_json/requests}/get_bucket_acl.rb +12 -17
- data/lib/fog/storage/google_json/requests/get_object.rb +98 -0
- data/lib/fog/storage/google_json/requests/get_object_acl.rb +59 -0
- data/lib/fog/storage/google_json/requests/get_object_http_url.rb +40 -0
- data/lib/fog/storage/google_json/requests/get_object_https_url.rb +41 -0
- data/lib/fog/storage/google_json/requests/get_object_torrent.rb +13 -0
- data/lib/fog/storage/google_json/requests/get_object_url.rb +22 -0
- data/lib/fog/storage/google_json/requests/get_service.rb +54 -0
- data/lib/fog/storage/google_json/requests/head_object.rb +54 -0
- data/lib/fog/storage/google_json/requests/put_bucket.rb +68 -0
- data/lib/fog/storage/google_json/requests/put_bucket_acl.rb +34 -0
- data/lib/fog/storage/google_json/requests/put_object.rb +118 -0
- data/lib/fog/storage/google_json/requests/put_object_acl.rb +31 -0
- data/lib/fog/storage/google_json/requests/put_object_url.rb +45 -0
- data/lib/fog/{google/storage.rb → storage/google_xml.rb} +49 -53
- data/lib/fog/storage/google_xml/models/directories.rb +34 -0
- data/lib/fog/{google/models/storage → storage/google_xml/models}/directory.rb +13 -21
- data/lib/fog/{google/models/storage → storage/google_xml/models}/file.rb +34 -46
- data/lib/fog/{google/models/storage → storage/google_xml/models}/files.rb +21 -30
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/copy_object.rb +15 -21
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/delete_bucket.rb +10 -12
- data/lib/fog/storage/google_xml/requests/delete_object.rb +44 -0
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/get_bucket.rb +33 -43
- data/lib/fog/storage/google_xml/requests/get_bucket_acl.rb +53 -0
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/get_object.rb +25 -37
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/get_object_acl.rb +16 -24
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/get_object_http_url.rb +8 -12
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/get_object_https_url.rb +8 -12
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/get_object_torrent.rb +10 -16
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/get_object_url.rb +1 -1
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/get_service.rb +13 -17
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/head_object.rb +14 -20
- data/lib/fog/storage/google_xml/requests/put_bucket.rb +71 -0
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/put_bucket_acl.rb +12 -14
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/put_object.rb +23 -27
- data/lib/fog/{google/requests/storage → storage/google_xml/requests}/put_object_acl.rb +12 -14
- data/lib/fog/storage/google_xml/requests/put_object_url.rb +42 -0
- data/tasks/bundler.rake +3 -0
- data/tasks/console.rake +12 -0
- data/tasks/lint.rake +3 -0
- data/tasks/smoke.rake +15 -0
- data/tasks/test.rake +13 -0
- data/test/helpers/integration_test_helper.rb +3 -3
- data/test/helpers/test_collection.rb +1 -1
- data/test/helpers/test_helper.rb +8 -8
- data/test/integration/compute/test_servers.rb +1 -1
- data/test/integration/factories/backend_services_factory.rb +2 -2
- data/test/integration/factories/collection_factory.rb +4 -4
- data/test/integration/factories/disks_factory.rb +3 -3
- data/test/integration/factories/forwarding_rules_factory.rb +3 -4
- data/test/integration/factories/global_forwarding_rules_factory.rb +2 -2
- data/test/integration/factories/http_health_checks_factory.rb +1 -1
- data/test/integration/factories/images_factory.rb +2 -2
- data/test/integration/factories/servers_factory.rb +4 -4
- data/test/integration/factories/target_http_proxies_factory.rb +2 -2
- data/test/integration/factories/target_instances_factory.rb +3 -3
- data/test/integration/factories/target_pools_factory.rb +4 -4
- data/test/integration/factories/url_maps_factory.rb +2 -2
- data/test/integration/storage/test_buckets.rb +56 -0
- data/test/integration/storage/test_directories.rb +60 -0
- data/test/integration/storage/test_files.rb +132 -0
- data/test/integration/storage/test_objects.rb +111 -0
- data/test/integration/test_authentication.rb +14 -10
- data/tests/helper.rb +40 -42
- data/tests/helpers/collection_helper.rb +26 -37
- data/tests/helpers/compute/flavors_helper.rb +4 -8
- data/tests/helpers/compute/server_helper.rb +1 -5
- data/tests/helpers/compute/servers_helper.rb +0 -2
- data/tests/helpers/formats_helper.rb +12 -12
- data/tests/helpers/formats_helper_tests.rb +43 -47
- data/tests/helpers/mock_helper.rb +6 -8
- data/tests/helpers/model_helper.rb +6 -10
- data/tests/helpers/schema_validator_tests.rb +41 -47
- data/tests/helpers/succeeds_helper.rb +1 -1
- data/tests/models/dns/change_tests.rb +8 -10
- data/tests/models/dns/changes_tests.rb +8 -12
- data/tests/models/dns/projects_tests.rb +2 -5
- data/tests/models/dns/record_tests.rb +9 -10
- data/tests/models/dns/records_tests.rb +9 -13
- data/tests/models/dns/zone_tests.rb +6 -6
- data/tests/models/dns/zones_tests.rb +5 -5
- data/tests/models/monitoring/metric_descriptors_tests.rb +2 -5
- data/tests/models/monitoring/timeseries_collection_tests.rb +3 -6
- data/tests/models/monitoring/timeseries_descriptors_tests.rb +3 -6
- data/tests/models/sql/flags_tests.rb +2 -5
- data/tests/models/sql/instance_tests.rb +4 -7
- data/tests/models/sql/instances_tests.rb +4 -9
- data/tests/models/sql/operation_tests.rb +3 -6
- data/tests/models/sql/operations_tests.rb +4 -9
- data/tests/models/sql/ssl_cert_tests.rb +3 -6
- data/tests/models/sql/ssl_certs_tests.rb +4 -9
- data/tests/models/sql/tiers_tests.rb +2 -5
- data/tests/requests/compute/backend_service_tests.rb +43 -47
- data/tests/requests/compute/disk_tests.rb +42 -46
- data/tests/requests/compute/disk_type_tests.rb +18 -21
- data/tests/requests/compute/firewall_tests.rb +42 -45
- data/tests/requests/compute/forwarding_rules_tests.rb +44 -48
- data/tests/requests/compute/global_forwarding_rules_tests.rb +44 -48
- data/tests/requests/compute/http_health_checks_tests.rb +44 -48
- data/tests/requests/compute/image_tests.rb +41 -45
- data/tests/requests/compute/network_tests.rb +38 -41
- data/tests/requests/compute/operation_tests.rb +2 -3
- data/tests/requests/compute/region_tests.rb +18 -18
- data/tests/requests/compute/server_tests.rb +45 -47
- data/tests/requests/compute/target_http_proxies_test.rb +39 -43
- data/tests/requests/compute/target_instances_tests.rb +43 -47
- data/tests/requests/compute/target_pools_tests.rb +43 -47
- data/tests/requests/compute/url_maps_tests.rb +42 -46
- data/tests/requests/compute/zone_tests.rb +15 -19
- data/tests/requests/dns/change_tests.rb +18 -22
- data/tests/requests/dns/managed_zone_tests.rb +27 -30
- data/tests/requests/dns/project_tests.rb +13 -16
- data/tests/requests/dns/record_tests.rb +15 -18
- data/tests/requests/monitoring/metric_descriptor_tests.rb +9 -12
- data/tests/requests/monitoring/timeseries_collection_tests.rb +9 -12
- data/tests/requests/monitoring/timeseries_descriptor_tests.rb +10 -13
- data/tests/requests/sql/flag_tests.rb +11 -14
- data/tests/requests/sql/instance_tests.rb +36 -39
- data/tests/requests/sql/operation_tests.rb +17 -20
- data/tests/requests/sql/ssl_cert_tests.rb +21 -24
- data/tests/requests/sql/tier_tests.rb +9 -12
- data/tests/requests/storage/bucket_tests.rb +30 -36
- data/tests/requests/storage/object_tests.rb +21 -27
- metadata +309 -235
- data/examples/eric-fail.rb +0 -36
- data/examples/image_all.rb +0 -6
- data/examples/launch_micro_instance.rb +0 -29
- data/gemfiles/Gemfile.2.0.0+ +0 -6
- data/gemfiles/Gemfile.2.0.0- +0 -10
- data/lib/fog/google/models/compute/flavor.rb +0 -33
- data/lib/fog/google/models/compute/global_forwarding_rule.rb +0 -86
- data/lib/fog/google/models/compute/http_health_check.rb +0 -84
- data/lib/fog/google/models/compute/snapshot.rb +0 -48
- data/lib/fog/google/models/compute/zone.rb +0 -23
- data/lib/fog/google/models/storage/directories.rb +0 -39
- data/lib/fog/google/parsers/storage/get_bucket.rb +0 -58
- data/lib/fog/google/parsers/storage/get_bucket_logging.rb +0 -36
- data/lib/fog/google/parsers/storage/get_bucket_object_versions.rb +0 -84
- data/lib/fog/google/requests/compute/attach_disk.rb +0 -34
- data/lib/fog/google/requests/compute/get_disk.rb +0 -52
- data/lib/fog/google/requests/compute/get_disk_type.rb +0 -42
- data/lib/fog/google/requests/compute/get_forwarding_rule.rb +0 -46
- data/lib/fog/google/requests/compute/get_global_forwarding_rule.rb +0 -32
- data/lib/fog/google/requests/compute/get_http_health_check.rb +0 -39
- data/lib/fog/google/requests/compute/get_machine_type.rb +0 -43
- data/lib/fog/google/requests/compute/get_server.rb +0 -75
- data/lib/fog/google/requests/compute/get_target_instance.rb +0 -32
- data/lib/fog/google/requests/compute/list_aggregated_disk_types.rb +0 -40
- data/lib/fog/google/requests/compute/list_aggregated_disks.rb +0 -40
- data/lib/fog/google/requests/compute/list_aggregated_servers.rb +0 -40
- data/lib/fog/google/requests/compute/list_backend_services.rb +0 -29
- data/lib/fog/google/requests/compute/list_disk_types.rb +0 -46
- data/lib/fog/google/requests/compute/list_disks.rb +0 -29
- data/lib/fog/google/requests/compute/list_forwarding_rules.rb +0 -29
- data/lib/fog/google/requests/compute/list_global_forwarding_rules.rb +0 -30
- data/lib/fog/google/requests/compute/list_http_health_checks.rb +0 -29
- data/lib/fog/google/requests/compute/list_images.rb +0 -29
- data/lib/fog/google/requests/compute/list_regions.rb +0 -85
- data/lib/fog/google/requests/compute/list_servers.rb +0 -31
- data/lib/fog/google/requests/compute/list_target_http_proxies.rb +0 -30
- data/lib/fog/google/requests/compute/list_target_instances.rb +0 -30
- data/lib/fog/google/requests/compute/list_target_pools.rb +0 -29
- data/lib/fog/google/requests/compute/list_url_maps.rb +0 -29
- data/lib/fog/google/requests/compute/list_zones.rb +0 -28
- data/lib/fog/google/requests/dns/create_managed_zone.rb +0 -82
- data/lib/fog/google/requests/storage/put_bucket.rb +0 -71
- data/lib/fog/google/requests/storage/put_object_url.rb +0 -50
@@ -1,21 +1,22 @@
|
|
1
|
-
require
|
2
|
-
require
|
1
|
+
require "rubygems"
|
2
|
+
require "fog"
|
3
3
|
|
4
4
|
def test
|
5
|
-
connection = Fog::Compute.new(
|
6
|
-
health = connection.http_health_checks.create(
|
7
|
-
:name => 'test-checks'
|
8
|
-
})
|
5
|
+
connection = Fog::Compute.new(:provider => "google")
|
6
|
+
health = connection.http_health_checks.create(:name => "test-checks")
|
9
7
|
health.wait_for { health.ready? }
|
10
|
-
backend= connection.backend_services.create(
|
11
|
-
:name =>
|
8
|
+
backend = connection.backend_services.create(
|
9
|
+
:name => "backend-test",
|
12
10
|
:health_checks => [health.self_link],
|
13
11
|
:port => 8080,
|
14
12
|
:timeout_sec => 40,
|
15
|
-
:backends => [{
|
16
|
-
|
13
|
+
:backends => [{ "group" => "resource_view self_link" }]
|
14
|
+
)
|
15
|
+
backend.get_health
|
16
|
+
|
17
17
|
puts connection.backend_services.all
|
18
|
-
|
18
|
+
|
19
|
+
backend = connection.backend_services.get("backend-test")
|
19
20
|
backend.get_health
|
20
21
|
end
|
21
22
|
|
data/examples/bootstrap.rb
CHANGED
@@ -1,5 +1,13 @@
|
|
1
|
+
# All examples presume that you have a ~/.fog credentials file set up.
|
2
|
+
# More info on it can be found here: http://fog.io/about/getting_started.html
|
3
|
+
|
4
|
+
require "bundler"
|
5
|
+
Bundler.require(:default, :development)
|
6
|
+
# Uncomment this if you want to make real requests to GCE (you _will_ be billed!)
|
7
|
+
# WebMock.disable!
|
8
|
+
|
1
9
|
def test
|
2
|
-
connection = Fog::Compute.new(
|
10
|
+
connection = Fog::Compute.new(:provider => "Google")
|
3
11
|
|
4
12
|
server = connection.servers.bootstrap
|
5
13
|
server.wait_for { sshable? }
|
@@ -7,3 +15,5 @@ def test
|
|
7
15
|
raise "Could not bootstrap sshable server." unless server.ssh("whoami")
|
8
16
|
raise "Could not delete server." unless server.destroy
|
9
17
|
end
|
18
|
+
|
19
|
+
test
|
@@ -1,29 +1,36 @@
|
|
1
|
+
# All examples presume that you have a ~/.fog credentials file set up.
|
2
|
+
# More info on it can be found here: http://fog.io/about/getting_started.html
|
3
|
+
|
4
|
+
require "bundler"
|
5
|
+
Bundler.require(:default, :development)
|
6
|
+
# Uncomment this if you want to make real requests to GCE (you _will_ be billed!)
|
7
|
+
# WebMock.disable!
|
8
|
+
|
1
9
|
def test
|
2
|
-
connection = Fog::Compute.new(
|
10
|
+
connection = Fog::Compute.new(:provider => "Google")
|
3
11
|
|
4
12
|
name = "fog-smoke-test-#{Time.now.to_i}"
|
5
13
|
|
6
|
-
disk = connection.disks.create(
|
14
|
+
disk = connection.disks.create(
|
7
15
|
:name => name,
|
8
16
|
:size_gb => 10,
|
9
|
-
:zone_name =>
|
10
|
-
:source_image =>
|
11
|
-
})
|
17
|
+
:zone_name => "us-central1-f",
|
18
|
+
:source_image => "debian-7-wheezy-v20151104")
|
12
19
|
|
13
20
|
disk.wait_for { disk.ready? }
|
14
21
|
|
15
|
-
server = connection.servers.create(
|
22
|
+
server = connection.servers.create(
|
16
23
|
:name => "fog-smoke-test-#{Time.now.to_i}",
|
17
24
|
:disks => [disk],
|
18
25
|
:machine_type => "n1-standard-1",
|
19
26
|
:private_key_path => File.expand_path("~/.ssh/id_rsa"),
|
20
27
|
:public_key_path => File.expand_path("~/.ssh/id_rsa.pub"),
|
21
|
-
:zone_name => "us-central1-
|
22
|
-
:user => ENV[
|
23
|
-
:tags => ["fog"]
|
24
|
-
|
28
|
+
:zone_name => "us-central1-f",
|
29
|
+
:user => ENV["USER"],
|
30
|
+
:tags => ["fog"],
|
31
|
+
:service_accounts => %w(sql-admin bigquery https://www.googleapis.com/auth/compute))
|
25
32
|
|
26
|
-
#
|
33
|
+
# Wait_for routine copied here to show errors, if necessary.
|
27
34
|
duration = 0
|
28
35
|
interval = 5
|
29
36
|
timeout = 600
|
@@ -47,3 +54,5 @@ def test
|
|
47
54
|
raise "Could not bootstrap sshable server." unless server.ssh("whoami")
|
48
55
|
raise "Could not delete server." unless server.destroy
|
49
56
|
end
|
57
|
+
|
58
|
+
test
|
data/examples/dns/project.rb
CHANGED
data/examples/dns/zones.rb
CHANGED
@@ -1,43 +1,43 @@
|
|
1
1
|
def test
|
2
2
|
connection = Fog::DNS::Google.new
|
3
3
|
|
4
|
-
puts
|
5
|
-
puts
|
6
|
-
zone = connection.zones.create(name
|
4
|
+
puts "Create a Zone..."
|
5
|
+
puts "----------------"
|
6
|
+
zone = connection.zones.create(:name => "mytestdomain", :domain => "example.org.", :description => "This is my test domain")
|
7
7
|
|
8
|
-
puts
|
9
|
-
puts
|
8
|
+
puts "List all Zones..."
|
9
|
+
puts "-----------------"
|
10
10
|
connection.zones.all
|
11
11
|
|
12
|
-
puts
|
13
|
-
puts
|
12
|
+
puts "Get the Zone..."
|
13
|
+
puts "---------------"
|
14
14
|
zone = connection.zones.get(zone.id)
|
15
15
|
|
16
16
|
puts 'Create an "A" Record...'
|
17
|
-
puts
|
18
|
-
|
17
|
+
puts "-----------------------"
|
18
|
+
zone.records.create(:name => "test.example.org.", :type => "A", :ttl => 3600, :rrdatas => ["192.168.1.1"])
|
19
19
|
|
20
|
-
puts
|
21
|
-
puts
|
20
|
+
puts "Get the Zone Resource Record Sets..."
|
21
|
+
puts "------------------------------------"
|
22
22
|
zone.records
|
23
23
|
|
24
|
-
puts
|
25
|
-
puts
|
26
|
-
record = connection.records(zone
|
24
|
+
puts "Get the Record..."
|
25
|
+
puts "-----------------"
|
26
|
+
record = connection.records(:zone => zone).get("test.example.org.", "A")
|
27
27
|
|
28
28
|
puts 'Modify the "A" Record...'
|
29
|
-
puts
|
30
|
-
record.modify(ttl
|
29
|
+
puts "------------------------"
|
30
|
+
record.modify(:ttl => 2600)
|
31
31
|
|
32
32
|
puts 'Delete the "A" Record...'
|
33
|
-
puts
|
33
|
+
puts "------------------------"
|
34
34
|
record.destroy
|
35
35
|
|
36
|
-
puts
|
37
|
-
puts
|
36
|
+
puts "Get the Zone Changes..."
|
37
|
+
puts "-----------------------"
|
38
38
|
zone.changes
|
39
39
|
|
40
|
-
puts
|
41
|
-
puts
|
40
|
+
puts "Delete the Zone..."
|
41
|
+
puts "------------------"
|
42
42
|
zone.destroy
|
43
43
|
end
|
data/examples/get_list_images.rb
CHANGED
@@ -1,26 +1,42 @@
|
|
1
|
+
# All examples presume that you have a ~/.fog credentials file set up.
|
2
|
+
# More info on it can be found here: http://fog.io/about/getting_started.html
|
3
|
+
|
4
|
+
require "bundler"
|
5
|
+
Bundler.require(:default, :development)
|
6
|
+
# Uncomment this if you want to make real requests to GCE (you _will_ be billed!)
|
7
|
+
# WebMock.disable!
|
8
|
+
|
1
9
|
def test
|
2
|
-
connection = Fog::Compute.new(
|
10
|
+
connection = Fog::Compute.new(:provider => "Google")
|
3
11
|
|
4
|
-
|
5
|
-
|
12
|
+
puts "Listing images in all projects..."
|
13
|
+
puts "---------------------------------"
|
6
14
|
images = connection.images.all
|
7
|
-
raise
|
8
|
-
|
15
|
+
raise "Could not LIST the images" unless images
|
16
|
+
puts images.inspect
|
9
17
|
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
raise
|
14
|
-
|
18
|
+
puts "Listing current (non-deprecated) images in all projects..."
|
19
|
+
puts "----------------------------------------------------------"
|
20
|
+
images = connection.images.current
|
21
|
+
raise "Could not LIST current images" unless images
|
22
|
+
puts images.inspect
|
23
|
+
|
24
|
+
puts "Fetching a single image from a global project..."
|
25
|
+
puts "------------------------------------------------"
|
26
|
+
img = connection.images.get("debian-7-wheezy-v20151104")
|
27
|
+
raise "Could not GET the image" unless img
|
28
|
+
puts img.inspect
|
15
29
|
|
16
30
|
# First, get the name of an image that is in the users 'project' (not global)
|
17
|
-
custom_img_name = images.
|
31
|
+
custom_img_name = images.detect { |i| i.project.eql? i.service.project }
|
18
32
|
# Run the next test only if there is a custom image available
|
19
33
|
if custom_img_name
|
20
|
-
|
21
|
-
|
34
|
+
puts "Fetching a single image from the custom project"
|
35
|
+
puts "----------------------------------------------"
|
22
36
|
img = connection.images.get(custom_img_name.name)
|
23
|
-
raise
|
24
|
-
|
37
|
+
raise "Could not GET the (custom) image" unless img
|
38
|
+
puts img.inspect
|
25
39
|
end
|
26
40
|
end
|
41
|
+
|
42
|
+
test
|
@@ -1,18 +1,28 @@
|
|
1
|
+
# All examples presume that you have a ~/.fog credentials file set up.
|
2
|
+
# More info on it can be found here: http://fog.io/about/getting_started.html
|
3
|
+
|
4
|
+
require "bundler"
|
5
|
+
Bundler.require(:default, :development)
|
6
|
+
# Uncomment this if you want to make real requests to GCE (you _will_ be billed!)
|
7
|
+
# WebMock.disable!
|
8
|
+
|
1
9
|
def test
|
2
|
-
connection = Fog::Compute.new(
|
10
|
+
connection = Fog::Compute.new(:provider => "Google")
|
3
11
|
|
4
|
-
|
5
|
-
|
12
|
+
puts "Listing snapshots..."
|
13
|
+
puts "---------------------------------"
|
6
14
|
snapshots = connection.snapshots.all
|
7
|
-
raise
|
8
|
-
|
15
|
+
raise "Could not LIST the snapshots" unless snapshots
|
16
|
+
puts snapshots.inspect
|
9
17
|
|
10
|
-
|
11
|
-
|
18
|
+
puts "Fetching a single snapshot..."
|
19
|
+
puts "------------------------------------------------"
|
12
20
|
snap = snapshots.first
|
13
|
-
|
21
|
+
unless snap.nil?
|
14
22
|
snap = connection.snapshots.get(snap)
|
15
|
-
raise
|
16
|
-
|
23
|
+
raise "Could not GET the snapshot" unless snap
|
24
|
+
puts snap.inspect
|
17
25
|
end
|
18
26
|
end
|
27
|
+
|
28
|
+
test
|
data/examples/image_create.rb
CHANGED
@@ -1,17 +1,17 @@
|
|
1
1
|
def test
|
2
|
-
connection = Fog::Compute.new(
|
2
|
+
connection = Fog::Compute.new(:provider => "Google")
|
3
3
|
|
4
4
|
rawdisk = {
|
5
5
|
:source => nil, # Google Cloud Storage URL pointing to the disk image. (e.g. http://storage.googleapis.com/test/test.tar.gz)
|
6
|
-
:container_type =>
|
6
|
+
:container_type => "TAR"
|
7
7
|
}
|
8
8
|
|
9
9
|
# Can't test this unless the 'source' points to a valid URL
|
10
10
|
return if rawdisk[:source].nil?
|
11
11
|
|
12
|
-
img = connection.images.create(:name =>
|
13
|
-
|
14
|
-
|
12
|
+
img = connection.images.create(:name => "test-image",
|
13
|
+
:description => "Test image (via fog)",
|
14
|
+
:raw_disk => rawdisk)
|
15
15
|
|
16
16
|
img.reload # will raise if image was not saved correctly
|
17
17
|
end
|
data/examples/l7_load_balance.rb
CHANGED
@@ -2,72 +2,70 @@
|
|
2
2
|
# They should each have Apache installed and distinct index.html files
|
3
3
|
# in order to observe the results of the l7 load balancer. A firewall
|
4
4
|
# rule should also have been created with a tag shared by the instances.
|
5
|
-
# More info on Google's HTTP load balancing:
|
5
|
+
# More info on Google's HTTP load balancing:
|
6
6
|
# https://developers.google.com/compute/docs/load-balancing/http/
|
7
7
|
|
8
8
|
def test
|
9
|
-
connection = Fog::Compute.new(
|
10
|
-
health = connection.http_health_checks.create(
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
instance2 = connection.servers.get('fog-l7-instance-2')
|
15
|
-
instance3 = connection.servers.get('fog-l7-instance-3')
|
9
|
+
connection = Fog::Compute.new(:provider => "google")
|
10
|
+
health = connection.http_health_checks.create(:name => "test-checks")
|
11
|
+
instance1 = connection.servers.get("fog-l7-instance-1")
|
12
|
+
instance2 = connection.servers.get("fog-l7-instance-2")
|
13
|
+
instance3 = connection.servers.get("fog-l7-instance-3")
|
16
14
|
|
17
|
-
resource_view1 = connection.resource_views.create(
|
18
|
-
:name =>
|
19
|
-
:numMembers => 1,
|
20
|
-
:members => [instance1.self_link],
|
21
|
-
:zone =>
|
22
|
-
})
|
15
|
+
resource_view1 = connection.resource_views.create(
|
16
|
+
:name => "fog-l7-resource-view-1",
|
17
|
+
:numMembers => 1,
|
18
|
+
:members => [instance1.self_link],
|
19
|
+
:zone => "us-central1-a")
|
23
20
|
resource_view1.add_resources(instance1.self_link)
|
24
|
-
resource_view2 = connection.resource_views.create(
|
25
|
-
:name =>
|
26
|
-
:numMembers => 1,
|
27
|
-
:members => [instance2.self_link],
|
28
|
-
:zone =>
|
29
|
-
})
|
21
|
+
resource_view2 = connection.resource_views.create(
|
22
|
+
:name => "fog-l7-resource-view-2",
|
23
|
+
:numMembers => 1,
|
24
|
+
:members => [instance2.self_link],
|
25
|
+
:zone => "us-central1-a")
|
30
26
|
resource_view2.add_resources(instance2.self_link)
|
31
|
-
resource_view3 = connection.resource_views.create(
|
32
|
-
:name =>
|
33
|
-
:members => [instance3.self_link],
|
34
|
-
:zone =>
|
27
|
+
resource_view3 = connection.resource_views.create(
|
28
|
+
:name => "fog-l7-resource-view-3",
|
29
|
+
:members => [instance3.self_link],
|
30
|
+
:zone => "us-central1-b")
|
35
31
|
resource_view3.add_resources(instance3.self_link)
|
36
|
-
backend_service1 = connection.backend_services.create(
|
37
|
-
:name =>
|
32
|
+
backend_service1 = connection.backend_services.create(
|
33
|
+
:name => "fog-l7-backend-service-1",
|
38
34
|
:health_checks => [health.self_link],
|
39
|
-
:backends => [{
|
40
|
-
|
41
|
-
|
42
|
-
:name => 'fog-l7-backend-service-2',
|
35
|
+
:backends => [{ "balancingMode" => "RATE", "maxRate" => 100, "group" => resource_view1.self_link }])
|
36
|
+
backend_service2 = connection.backend_services.create(
|
37
|
+
:name => "fog-l7-backend-service-2",
|
43
38
|
:health_checks => [health.self_link],
|
44
|
-
:backends => [{
|
45
|
-
|
46
|
-
|
47
|
-
:name => 'fog-l7-backend-service-3',
|
39
|
+
:backends => [{ "balancingMode" => "RATE", "maxRate" => 100, "group" => resource_view2.self_link }])
|
40
|
+
backend_service3 = connection.backend_services.create(
|
41
|
+
:name => "fog-l7-backend-service-3",
|
48
42
|
:health_checks => [health.self_link],
|
49
|
-
:backends => [{
|
50
|
-
|
51
|
-
|
52
|
-
:
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
:
|
71
|
-
|
72
|
-
|
43
|
+
:backends => [{ "balancingMode" => "RATE", "maxRate" => 100, "group" => resource_view3.self_link }])
|
44
|
+
url_map = connection.url_maps.create(
|
45
|
+
:name => "fog-l7-url-map",
|
46
|
+
:pathMatchers => [{
|
47
|
+
"name" => "pathmatcher",
|
48
|
+
"defaultService" => backend_service1.self_link,
|
49
|
+
"pathRules" => [
|
50
|
+
{
|
51
|
+
"paths" => ["/one/*"],
|
52
|
+
"service" => backend_service1.self_link
|
53
|
+
},
|
54
|
+
{
|
55
|
+
"paths" => ["/two/*"],
|
56
|
+
"service" => backend_service2.self_link
|
57
|
+
},
|
58
|
+
{
|
59
|
+
"paths" => ["/three/*"],
|
60
|
+
"service" => backend_service3.self_link
|
61
|
+
}
|
62
|
+
]
|
63
|
+
}],
|
64
|
+
:hostRules => [{ "hosts" => ["*"], "pathMatcher" => "pathmatcher" }],
|
65
|
+
:default_service => backend_service1.self_link)
|
66
|
+
proxy = connection.target_http_proxies.create(
|
67
|
+
:name => "fog-l7-proxy",
|
68
|
+
:url_map => url_map.self_link)
|
69
|
+
|
70
|
+
connection.global_forwarding_rules.create(:name => "fog-l7-fwd-rule", :target => proxy.self_link)
|
73
71
|
end
|
data/examples/load-balance.rb
CHANGED
@@ -2,20 +2,20 @@
|
|
2
2
|
def test
|
3
3
|
# Config
|
4
4
|
name = "fog-lb-test-#{Time.now.to_i}"
|
5
|
-
zone =
|
6
|
-
region =
|
5
|
+
zone = "us-central1-b"
|
6
|
+
region = "us-central1"
|
7
7
|
|
8
8
|
# Setup
|
9
|
-
gce = Fog::Compute.new provider
|
9
|
+
gce = Fog::Compute.new :provider => "Google"
|
10
10
|
servers = []
|
11
11
|
|
12
12
|
(1..3).each do |i|
|
13
13
|
begin
|
14
14
|
disk = gce.disks.create(
|
15
|
-
name
|
16
|
-
size_gb
|
17
|
-
|
18
|
-
|
15
|
+
:name => "#{name}-#{i}",
|
16
|
+
:size_gb => 10,
|
17
|
+
:zone_name => zone,
|
18
|
+
:source_image => "debian-7-wheezy-v20131120"
|
19
19
|
)
|
20
20
|
disk.wait_for { disk.ready? }
|
21
21
|
rescue
|
@@ -24,10 +24,10 @@ def test
|
|
24
24
|
|
25
25
|
begin
|
26
26
|
server = gce.servers.create(
|
27
|
-
name
|
28
|
-
disks
|
29
|
-
|
30
|
-
|
27
|
+
:name => "#{name}-#{i}",
|
28
|
+
:disks => [disk.get_as_boot_disk(true, true)],
|
29
|
+
:machine_type => "f1-micro",
|
30
|
+
:zone_name => zone
|
31
31
|
)
|
32
32
|
servers << server
|
33
33
|
rescue
|
@@ -36,7 +36,7 @@ def test
|
|
36
36
|
end
|
37
37
|
|
38
38
|
begin
|
39
|
-
health = gce.http_health_checks.new(name
|
39
|
+
health = gce.http_health_checks.new(:name => name)
|
40
40
|
health.save
|
41
41
|
rescue
|
42
42
|
puts "Failed to create health check #{name}"
|
@@ -44,10 +44,10 @@ def test
|
|
44
44
|
|
45
45
|
begin
|
46
46
|
pool = gce.target_pools.new(
|
47
|
-
name
|
48
|
-
region
|
49
|
-
health_checks
|
50
|
-
instances
|
47
|
+
:name => name,
|
48
|
+
:region => region,
|
49
|
+
:health_checks => health.self_link,
|
50
|
+
:instances => servers.map(&:self_link)
|
51
51
|
)
|
52
52
|
pool.save
|
53
53
|
rescue
|
@@ -56,18 +56,17 @@ def test
|
|
56
56
|
|
57
57
|
begin
|
58
58
|
rule = gce.forwarding_rules.new(
|
59
|
-
name
|
60
|
-
region
|
61
|
-
port_range
|
62
|
-
ip_protocol
|
63
|
-
target
|
59
|
+
:name => name,
|
60
|
+
:region => region,
|
61
|
+
:port_range => "1-65535",
|
62
|
+
:ip_protocol => "TCP",
|
63
|
+
:target => pool.self_link
|
64
64
|
)
|
65
65
|
rule.save
|
66
66
|
rescue
|
67
67
|
puts "Failed to create forwarding rule #{name}"
|
68
68
|
end
|
69
69
|
|
70
|
-
|
71
70
|
# TODO(bensonk): Install apache, create individualized htdocs, and run some
|
72
71
|
# actual requests through the load balancer.
|
73
72
|
|
@@ -91,7 +90,7 @@ def test
|
|
91
90
|
end
|
92
91
|
|
93
92
|
begin
|
94
|
-
servers.each
|
93
|
+
servers.each(&:destroy)
|
95
94
|
rescue
|
96
95
|
puts "Failed to clean up instances."
|
97
96
|
end
|