fastly 15.0.0 → 15.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (93) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +22 -0
  3. data/Gemfile.lock +1 -1
  4. data/README.md +10 -3
  5. data/docs/DdosProtectionEvent.md +2 -0
  6. data/docs/DdosProtectionEventAllOf.md +2 -0
  7. data/docs/DdosProtectionRequestEnableMode.md +10 -0
  8. data/docs/DomainInspectorHistoricalApi.md +1 -1
  9. data/docs/DomainResearchApi.md +103 -0
  10. data/docs/DomainResearchResponseBodyEnable.md +12 -0
  11. data/docs/DomainResearchResponseCustomer.md +10 -0
  12. data/docs/DomainResearchResponseLinks.md +10 -0
  13. data/docs/DomainResearchResponseLinksLinks.md +10 -0
  14. data/docs/DomainResearchResponseProduct.md +10 -0
  15. data/docs/DomainResearchResponseProductProduct.md +11 -0
  16. data/docs/IamV1RoleResponse.md +1 -0
  17. data/docs/InlineResponse20010.md +2 -1
  18. data/docs/InlineResponse20011.md +10 -0
  19. data/docs/InlineResponse2006.md +1 -2
  20. data/docs/InlineResponse2007.md +1 -1
  21. data/docs/InlineResponse2008.md +1 -1
  22. data/docs/InlineResponse2009.md +1 -1
  23. data/docs/KvStoreApi.md +43 -4
  24. data/docs/KvStoreDetails.md +2 -0
  25. data/docs/KvStoreItemApi.md +2 -2
  26. data/docs/{KvStoreRequestCreate.md → KvStoreRequestCreateOrUpdate.md} +1 -1
  27. data/docs/MetricsPlatformApi.md +75 -0
  28. data/docs/NgwafRequestEnable.md +1 -0
  29. data/docs/Offer.md +12 -0
  30. data/docs/OfferAllOf.md +12 -0
  31. data/docs/OriginInspectorHistoricalApi.md +1 -1
  32. data/docs/PlatformMetadata.md +14 -0
  33. data/docs/PlatformMetricsResponse.md +11 -0
  34. data/docs/PlatformValues.md +25 -0
  35. data/docs/ProductDdosProtectionApi.md +3 -1
  36. data/docs/ProductDomainResearchApi.md +115 -0
  37. data/docs/RealtimeEntryAggregated.md +4 -0
  38. data/docs/RealtimeMeasurements.md +4 -0
  39. data/docs/Results.md +4 -0
  40. data/docs/SecretStoreApi.md +2 -2
  41. data/docs/SecretStoreItemApi.md +2 -2
  42. data/docs/ServiceAuthorizationsApi.md +2 -2
  43. data/docs/Status.md +15 -0
  44. data/docs/StatusAllOf.md +15 -0
  45. data/docs/Suggestion.md +13 -0
  46. data/docs/SuggestionAllOf.md +13 -0
  47. data/lib/fastly/api/domain_inspector_historical_api.rb +1 -1
  48. data/lib/fastly/api/domain_research_api.rb +163 -0
  49. data/lib/fastly/api/kv_store_api.rb +74 -6
  50. data/lib/fastly/api/kv_store_item_api.rb +3 -3
  51. data/lib/fastly/api/metrics_platform_api.rb +134 -0
  52. data/lib/fastly/api/origin_inspector_historical_api.rb +1 -1
  53. data/lib/fastly/api/product_ddos_protection_api.rb +10 -3
  54. data/lib/fastly/api/product_domain_research_api.rb +186 -0
  55. data/lib/fastly/api/secret_store_api.rb +3 -3
  56. data/lib/fastly/api/secret_store_item_api.rb +3 -3
  57. data/lib/fastly/api/service_authorizations_api.rb +3 -3
  58. data/lib/fastly/configuration.rb +42 -0
  59. data/lib/fastly/models/ddos_protection_event.rb +21 -1
  60. data/lib/fastly/models/ddos_protection_event_all_of.rb +21 -1
  61. data/lib/fastly/models/ddos_protection_request_enable_mode.rb +251 -0
  62. data/lib/fastly/models/domain_research_response_body_enable.rb +243 -0
  63. data/lib/fastly/models/domain_research_response_customer.rb +216 -0
  64. data/lib/fastly/models/domain_research_response_links.rb +216 -0
  65. data/lib/fastly/models/domain_research_response_links_links.rb +217 -0
  66. data/lib/fastly/models/domain_research_response_product.rb +216 -0
  67. data/lib/fastly/models/domain_research_response_product_product.rb +227 -0
  68. data/lib/fastly/models/iam_v1_role_response.rb +10 -1
  69. data/lib/fastly/models/inline_response20010.rb +13 -4
  70. data/lib/fastly/models/inline_response20011.rb +218 -0
  71. data/lib/fastly/models/inline_response2006.rb +8 -17
  72. data/lib/fastly/models/inline_response2007.rb +1 -1
  73. data/lib/fastly/models/inline_response2008.rb +1 -1
  74. data/lib/fastly/models/inline_response2009.rb +1 -1
  75. data/lib/fastly/models/kv_store_details.rb +24 -4
  76. data/lib/fastly/models/{kv_store_request_create.rb → kv_store_request_create_or_update.rb} +3 -3
  77. data/lib/fastly/models/ngwaf_request_enable.rb +14 -4
  78. data/lib/fastly/models/offer.rb +245 -0
  79. data/lib/fastly/models/offer_all_of.rb +237 -0
  80. data/lib/fastly/models/platform_metadata.rb +258 -0
  81. data/lib/fastly/models/platform_metrics_response.rb +228 -0
  82. data/lib/fastly/models/platform_values.rb +368 -0
  83. data/lib/fastly/models/realtime_entry_aggregated.rb +44 -4
  84. data/lib/fastly/models/realtime_measurements.rb +44 -4
  85. data/lib/fastly/models/results.rb +41 -1
  86. data/lib/fastly/models/status.rb +276 -0
  87. data/lib/fastly/models/status_all_of.rb +268 -0
  88. data/lib/fastly/models/suggestion.rb +255 -0
  89. data/lib/fastly/models/suggestion_all_of.rb +247 -0
  90. data/lib/fastly/version.rb +1 -1
  91. data/lib/fastly.rb +21 -1
  92. data/sig.json +1 -1
  93. metadata +44 -4
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 811f03dabea8e6389703a81b5ae3f196631b6798af56c3273d932b488f860d66
4
- data.tar.gz: 202ad7a54a01df5c22282dd5b7140c2d282955112aae00019f06db85a2f58003
3
+ metadata.gz: d2f1e620609aa85c9bafd6966f16b63d5f8726dd7e3b8c5ca9bf5932dd558a6d
4
+ data.tar.gz: 6345f7520bec68b27c1174b849e205c0262be29db613cd5b8f70ae2cf528244d
5
5
  SHA512:
6
- metadata.gz: d2aea4e009761f11d495110ad76e5060abb255afef6ce5f659fe83c943cca324dec30f34cc7175b6d210a7d17a040052583c11db1a70e2272e27a56b3e1d5563
7
- data.tar.gz: 430a5ad918dccf92a42971dd87b1c357b4188bde959753a0c13bd2b79cd385555b4a09999b7b1dded56327afbd7bbcabb30c9f6b22d7157badcfdde93a17abd9
6
+ metadata.gz: eed553a99cc3a2b850218d3a77eefa5b4a0f4f952407fe41e449170649dfce8810a9b275918be324fd5efcd046583ce4c8b6327c8d418a6515e30a1de5560431
7
+ data.tar.gz: 99db9892974621f481476e5fb1c0402ddb28050b9768f876f1bb1e60ca29265f326b273fb8e0fdcce94bae6c4cce9af4a699f76633a4d2fb3c0cebab4d79956f
data/CHANGELOG.md CHANGED
@@ -1,5 +1,27 @@
1
1
  # Changelog
2
2
 
3
+ ## [v15.1.0](https://github.com/fastly/fastly-ruby/releases/tag/release/v15.1.0) (2025-12-09)
4
+
5
+ **Enhancements:**
6
+
7
+ - feat(realtime, historical): Add new metrics `imgopto_compute_requests`, `dns_billable_responses_count`,
8
+ `dns_nonbillable_responses_count`, and `upgrade`.
9
+ - feat(products[ngwaf]): Add new parameter `traffic_ramp` to `enable-product-ngwaf`.
10
+ - feat(products[ddos_protection]): Add new parameter `mode` to `enable-product-ddos-protection`.
11
+ - feat(kv_store): Add `kv-store-put` operation.
12
+ - feat(iam_roles): Add `DisplayName` field to model.
13
+ - feat(domain_research): Add new Domain Research API.
14
+ - feat(ddos_protection): Add `requests_allowed` and `requests_detected` fields to DDoS Protection event API.
15
+
16
+ - feat(products): Add `domain_research` product to enablement API.
17
+
18
+
19
+
20
+ **Documentation:**
21
+
22
+ - doc(enabled-products): Add support for optional enablement parameters for some products.
23
+
24
+
3
25
  ## [v15.0.0](https://github.com/fastly/fastly-ruby/releases/tag/release/v15.0.0) (2025-10-31)
4
26
 
5
27
  **Bug fixes:**
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- fastly (15.0.0)
4
+ fastly (15.1.0)
5
5
  typhoeus (~> 1.0, >= 1.0.1)
6
6
 
7
7
  GEM
data/README.md CHANGED
@@ -8,7 +8,7 @@ A Ruby client library for interacting with most facets of the [Fastly API](https
8
8
  To install via RubyGems, add the following to your project's `Gemfile`:
9
9
 
10
10
  ```ruby
11
- gem 'fastly', '~> 15.0.0'
11
+ gem 'fastly', '~> 15.1.0'
12
12
  ```
13
13
 
14
14
  Then run `bundle install`.
@@ -191,6 +191,8 @@ Class | Method | Description
191
191
  [*Fastly::DomainInspectorRealtimeApi*](docs/DomainInspectorRealtimeApi.md) | [**get_domain_inspector_last_max_entries**](docs/DomainInspectorRealtimeApi.md#get_domain_inspector_last_max_entries) | Get a limited number of real-time domain data entries
192
192
  [*Fastly::DomainInspectorRealtimeApi*](docs/DomainInspectorRealtimeApi.md) | [**get_domain_inspector_last_second**](docs/DomainInspectorRealtimeApi.md#get_domain_inspector_last_second) | Get real-time domain data from a specified time
193
193
  [*Fastly::DomainOwnershipsApi*](docs/DomainOwnershipsApi.md) | [**list_domain_ownerships**](docs/DomainOwnershipsApi.md#list_domain_ownerships) | List domain-ownerships
194
+ [*Fastly::DomainResearchApi*](docs/DomainResearchApi.md) | [**domain_status**](docs/DomainResearchApi.md#domain_status) | Domain status
195
+ [*Fastly::DomainResearchApi*](docs/DomainResearchApi.md) | [**suggest_domains**](docs/DomainResearchApi.md#suggest_domains) | Suggest domains
194
196
  [*Fastly::EventsApi*](docs/EventsApi.md) | [**get_event**](docs/EventsApi.md#get_event) | Get an event
195
197
  [*Fastly::EventsApi*](docs/EventsApi.md) | [**list_events**](docs/EventsApi.md#list_events) | List events
196
198
  [*Fastly::GzipApi*](docs/GzipApi.md) | [**create_gzip_config**](docs/GzipApi.md#create_gzip_config) | Create a gzip configuration
@@ -255,6 +257,7 @@ Class | Method | Description
255
257
  [*Fastly::KvStoreApi*](docs/KvStoreApi.md) | [**kv_store_delete**](docs/KvStoreApi.md#kv_store_delete) | Delete a KV store.
256
258
  [*Fastly::KvStoreApi*](docs/KvStoreApi.md) | [**kv_store_get**](docs/KvStoreApi.md#kv_store_get) | Describe a KV store.
257
259
  [*Fastly::KvStoreApi*](docs/KvStoreApi.md) | [**kv_store_list**](docs/KvStoreApi.md#kv_store_list) | List all KV stores.
260
+ [*Fastly::KvStoreApi*](docs/KvStoreApi.md) | [**kv_store_put**](docs/KvStoreApi.md#kv_store_put) | Update a KV store.
258
261
  [*Fastly::KvStoreItemApi*](docs/KvStoreItemApi.md) | [**kv_store_delete_item**](docs/KvStoreItemApi.md#kv_store_delete_item) | Delete an item.
259
262
  [*Fastly::KvStoreItemApi*](docs/KvStoreItemApi.md) | [**kv_store_get_item**](docs/KvStoreItemApi.md#kv_store_get_item) | Get an item.
260
263
  [*Fastly::KvStoreItemApi*](docs/KvStoreItemApi.md) | [**kv_store_list_item_keys**](docs/KvStoreItemApi.md#kv_store_list_item_keys) | List item keys.
@@ -400,6 +403,7 @@ Class | Method | Description
400
403
  [*Fastly::LoggingSyslogApi*](docs/LoggingSyslogApi.md) | [**get_log_syslog**](docs/LoggingSyslogApi.md#get_log_syslog) | Get a syslog log endpoint
401
404
  [*Fastly::LoggingSyslogApi*](docs/LoggingSyslogApi.md) | [**list_log_syslog**](docs/LoggingSyslogApi.md#list_log_syslog) | List Syslog log endpoints
402
405
  [*Fastly::LoggingSyslogApi*](docs/LoggingSyslogApi.md) | [**update_log_syslog**](docs/LoggingSyslogApi.md#update_log_syslog) | Update a syslog log endpoint
406
+ [*Fastly::MetricsPlatformApi*](docs/MetricsPlatformApi.md) | [**get_platform_metrics_service_historical**](docs/MetricsPlatformApi.md#get_platform_metrics_service_historical) | Get historical time series metrics for a single service
403
407
  [*Fastly::MutualAuthenticationApi*](docs/MutualAuthenticationApi.md) | [**create_mutual_tls_authentication**](docs/MutualAuthenticationApi.md#create_mutual_tls_authentication) | Create a Mutual Authentication
404
408
  [*Fastly::MutualAuthenticationApi*](docs/MutualAuthenticationApi.md) | [**delete_mutual_tls**](docs/MutualAuthenticationApi.md#delete_mutual_tls) | Delete a Mutual TLS
405
409
  [*Fastly::MutualAuthenticationApi*](docs/MutualAuthenticationApi.md) | [**get_mutual_authentication**](docs/MutualAuthenticationApi.md#get_mutual_authentication) | Get a Mutual Authentication
@@ -455,6 +459,9 @@ Class | Method | Description
455
459
  [*Fastly::ProductDomainInspectorApi*](docs/ProductDomainInspectorApi.md) | [**enable_product_domain_inspector**](docs/ProductDomainInspectorApi.md#enable_product_domain_inspector) | Enable product
456
460
  [*Fastly::ProductDomainInspectorApi*](docs/ProductDomainInspectorApi.md) | [**get_product_domain_inspector**](docs/ProductDomainInspectorApi.md#get_product_domain_inspector) | Get product enablement status
457
461
  [*Fastly::ProductDomainInspectorApi*](docs/ProductDomainInspectorApi.md) | [**get_services_product_domain_inspector**](docs/ProductDomainInspectorApi.md#get_services_product_domain_inspector) | Get services with product enabled
462
+ [*Fastly::ProductDomainResearchApi*](docs/ProductDomainResearchApi.md) | [**disable_product_domain_research**](docs/ProductDomainResearchApi.md#disable_product_domain_research) | Disable product
463
+ [*Fastly::ProductDomainResearchApi*](docs/ProductDomainResearchApi.md) | [**enable_domain_research**](docs/ProductDomainResearchApi.md#enable_domain_research) | Enable product
464
+ [*Fastly::ProductDomainResearchApi*](docs/ProductDomainResearchApi.md) | [**get_domain_research**](docs/ProductDomainResearchApi.md#get_domain_research) | Get product enablement status
458
465
  [*Fastly::ProductFanoutApi*](docs/ProductFanoutApi.md) | [**disable_product_fanout**](docs/ProductFanoutApi.md#disable_product_fanout) | Disable product
459
466
  [*Fastly::ProductFanoutApi*](docs/ProductFanoutApi.md) | [**enable_product_fanout**](docs/ProductFanoutApi.md#enable_product_fanout) | Enable product
460
467
  [*Fastly::ProductFanoutApi*](docs/ProductFanoutApi.md) | [**get_product_fanout**](docs/ProductFanoutApi.md#get_product_fanout) | Get product enablement status
@@ -646,8 +653,6 @@ The fastly-ruby API client currently does not support the following endpoints:
646
653
  - [`/alerts/history`](https://www.fastly.com/documentation/reference/api/observability/alerts/history) (GET)
647
654
  - [`/dns/configurations/{dns_configuration_id}`](https://www.fastly.com/documentation/reference/api/) (DELETE, GET, PATCH)
648
655
  - [`/dns/configurations`](https://www.fastly.com/documentation/reference/api/) (GET, POST)
649
- - [`/domains/v1/tools/status`](https://www.fastly.com/documentation/reference/api/) (GET)
650
- - [`/domains/v1/tools/suggest`](https://www.fastly.com/documentation/reference/api/) (GET)
651
656
  - [`/ngwaf/v1/lists/{listId}`](https://www.fastly.com/documentation/reference/api/ngwaf/v1/lists) (DELETE, GET, PATCH)
652
657
  - [`/ngwaf/v1/lists`](https://www.fastly.com/documentation/reference/api/ngwaf/v1/lists) (GET, POST)
653
658
  - [`/ngwaf/v1/signals/{signal_id}`](https://www.fastly.com/documentation/reference/api/ngwaf/v1/signals) (DELETE, GET, PATCH)
@@ -660,6 +665,8 @@ The fastly-ruby API client currently does not support the following endpoints:
660
665
  - [`/ngwaf/v1/workspaces/{workspace_id}/alerts`](https://www.fastly.com/documentation/reference/api/ngwaf/v1/workspace_alerts) (GET, POST)
661
666
  - [`/ngwaf/v1/workspaces/{workspace_id}/events/{event_id}`](https://www.fastly.com/documentation/reference/api/ngwaf/events) (GET, PATCH)
662
667
  - [`/ngwaf/v1/workspaces/{workspace_id}/events`](https://www.fastly.com/documentation/reference/api/ngwaf/events) (GET)
668
+ - [`/ngwaf/v1/workspaces/{workspace_id}/header-links/{header_link_id}`](https://www.fastly.com/documentation/reference/api/ngwaf/v1/header-links) (DELETE, GET, PUT)
669
+ - [`/ngwaf/v1/workspaces/{workspace_id}/header-links`](https://www.fastly.com/documentation/reference/api/ngwaf/v1/header-links) (GET, POST)
663
670
  - [`/ngwaf/v1/workspaces/{workspace_id}/redactions/{redaction_id}`](https://www.fastly.com/documentation/reference/api/ngwaf/v1/redactions) (DELETE, GET, PATCH)
664
671
  - [`/ngwaf/v1/workspaces/{workspace_id}/redactions`](https://www.fastly.com/documentation/reference/api/ngwaf/v1/redactions) (GET, POST)
665
672
  - [`/ngwaf/v1/workspaces/{workspace_id}/requests/{request_id}/report`](https://www.fastly.com/documentation/reference/api/ngwaf/v1/requests) (POST)
@@ -8,6 +8,8 @@
8
8
  | **updated_at** | **Time** | Date and time in ISO 8601 format. | [optional][readonly] |
9
9
  | **id** | **String** | Unique ID of the event. | [optional] |
10
10
  | **name** | **String** | A human-readable name for the event. | [optional] |
11
+ | **requests_allowed** | **Integer** | Number of requests classified as non-attack traffic for an event. | [optional] |
12
+ | **requests_detected** | **Integer** | Number of requests classified as DDoS attack traffic for an event. | [optional] |
11
13
  | **customer_id** | **String** | Alphanumeric string identifying the customer. | [optional] |
12
14
  | **service_id** | **String** | Alphanumeric string identifying the service. | [optional] |
13
15
  | **started_at** | **Time** | Date and time in ISO 8601 format. | [optional][readonly] |
@@ -6,6 +6,8 @@
6
6
  | ---- | ---- | ----------- | ----- |
7
7
  | **id** | **String** | Unique ID of the event. | [optional] |
8
8
  | **name** | **String** | A human-readable name for the event. | [optional] |
9
+ | **requests_allowed** | **Integer** | Number of requests classified as non-attack traffic for an event. | [optional] |
10
+ | **requests_detected** | **Integer** | Number of requests classified as DDoS attack traffic for an event. | [optional] |
9
11
  | **customer_id** | **String** | Alphanumeric string identifying the customer. | [optional] |
10
12
  | **service_id** | **String** | Alphanumeric string identifying the service. | [optional] |
11
13
  | **started_at** | **Time** | Date and time in ISO 8601 format. | [optional][readonly] |
@@ -0,0 +1,10 @@
1
+ # Fastly::DdosProtectionRequestEnableMode
2
+
3
+ ## Properties
4
+
5
+ | Name | Type | Description | Notes |
6
+ | ---- | ---- | ----------- | ----- |
7
+ | **mode** | **String** | Operation mode | [optional] |
8
+
9
+ [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
10
+
@@ -37,7 +37,7 @@ opts = {
37
37
  group_by: 'domain', # String | Dimensions to return in the query. Multiple dimensions may be separated by commas. For example, `group_by=domain` will return one timeseries for every domain, as a total across all datacenters (POPs).
38
38
  limit: 'limit_example', # String | Number of results per page. The maximum is 200.
39
39
  cursor: 'cursor_example', # String | Cursor value from the `next_cursor` field of a previous response, used to retrieve the next page. To request the first page, this should be empty.
40
- region: 'usa', # String | Limit query to one or more specific geographic regions. Values should be comma-separated.
40
+ region: 'africa_std', # String | Limit query to one or more specific geographic regions. Values should be comma-separated.
41
41
  datacenter: 'SJC,STP', # String | Limit query to one or more specific POPs. Values should be comma-separated.
42
42
  domain: 'domain_1.com,domain_2.com', # String | Limit query to one or more specific domains. Values should be comma-separated.
43
43
  }
@@ -0,0 +1,103 @@
1
+ # Fastly::DomainResearchApi
2
+
3
+
4
+ ```ruby
5
+ require 'fastly'
6
+ api_instance = Fastly::DomainResearchApi.new
7
+ ```
8
+
9
+ ## Methods
10
+
11
+ > [!NOTE]
12
+ > All URIs are relative to `https://api.fastly.com`
13
+
14
+ Method | HTTP request | Description
15
+ ------ | ------------ | -----------
16
+ [**domain_status**](DomainResearchApi.md#domain_status) | **GET** /domain-management/v1/tools/status | Domain status
17
+ [**suggest_domains**](DomainResearchApi.md#suggest_domains) | **GET** /domain-management/v1/tools/suggest | Suggest domains
18
+
19
+
20
+ ## `domain_status()`
21
+
22
+ ```ruby
23
+ domain_status(opts): <Status> # Domain status
24
+ ```
25
+
26
+ The `Status` method checks the availability status of a single domain name.
27
+
28
+ ### Examples
29
+
30
+ ```ruby
31
+ api_instance = Fastly::DomainResearchApi.new
32
+ opts = {
33
+ domain: 'acmecoffee.shop', # String |
34
+ scope: 'estimate', # String |
35
+ }
36
+
37
+ begin
38
+ # Domain status
39
+ result = api_instance.domain_status(opts)
40
+ p result
41
+ rescue Fastly::ApiError => e
42
+ puts "Error when calling DomainResearchApi->domain_status: #{e}"
43
+ end
44
+ ```
45
+
46
+ ### Options
47
+
48
+ | Name | Type | Description | Notes |
49
+ | ---- | ---- | ----------- | ----- |
50
+ | **domain** | **String** | | |
51
+ | **scope** | **String** | | [optional] |
52
+
53
+ ### Return type
54
+
55
+ [**Status**](Status.md)
56
+
57
+ [[Back to top]](#) [[Back to API list]](../../README.md#endpoints)
58
+ [[Back to README]](../../README.md)
59
+ ## `suggest_domains()`
60
+
61
+ ```ruby
62
+ suggest_domains(opts): <InlineResponse2006> # Suggest domains
63
+ ```
64
+
65
+ The `Suggest` method performs a real-time query of the search term(s) against the [known zone database](http://zonedb.org), making recommendations, stemming, and applying Unicode folding, IDN normalization, registrar supported-zone restrictions, and other refinements. **Note:** `Suggest` method responses do not include domain availability status.
66
+
67
+ ### Examples
68
+
69
+ ```ruby
70
+ api_instance = Fastly::DomainResearchApi.new
71
+ opts = {
72
+ query: 'foo%20bar', # String |
73
+ defaults: 'club', # String |
74
+ keywords: 'food,kitchen', # String |
75
+ location: 'de', # String |
76
+ vendor: 'dnsimple.com', # String |
77
+ }
78
+
79
+ begin
80
+ # Suggest domains
81
+ result = api_instance.suggest_domains(opts)
82
+ p result
83
+ rescue Fastly::ApiError => e
84
+ puts "Error when calling DomainResearchApi->suggest_domains: #{e}"
85
+ end
86
+ ```
87
+
88
+ ### Options
89
+
90
+ | Name | Type | Description | Notes |
91
+ | ---- | ---- | ----------- | ----- |
92
+ | **query** | **String** | | |
93
+ | **defaults** | **String** | | [optional] |
94
+ | **keywords** | **String** | | [optional] |
95
+ | **location** | **String** | | [optional] |
96
+ | **vendor** | **String** | | [optional] |
97
+
98
+ ### Return type
99
+
100
+ [**InlineResponse2006**](InlineResponse2006.md)
101
+
102
+ [[Back to top]](#) [[Back to API list]](../../README.md#endpoints)
103
+ [[Back to README]](../../README.md)
@@ -0,0 +1,12 @@
1
+ # Fastly::DomainResearchResponseBodyEnable
2
+
3
+ ## Properties
4
+
5
+ | Name | Type | Description | Notes |
6
+ | ---- | ---- | ----------- | ----- |
7
+ | **product** | [**DomainResearchResponseProductProduct**](DomainResearchResponseProductProduct.md) | | [optional] |
8
+ | **customer** | [**AiAcceleratorResponseCustomerCustomer**](AiAcceleratorResponseCustomerCustomer.md) | | [optional] |
9
+ | **_links** | [**DomainResearchResponseLinksLinks**](DomainResearchResponseLinksLinks.md) | | [optional] |
10
+
11
+ [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
12
+
@@ -0,0 +1,10 @@
1
+ # Fastly::DomainResearchResponseCustomer
2
+
3
+ ## Properties
4
+
5
+ | Name | Type | Description | Notes |
6
+ | ---- | ---- | ----------- | ----- |
7
+ | **customer** | [**AiAcceleratorResponseCustomerCustomer**](AiAcceleratorResponseCustomerCustomer.md) | | [optional] |
8
+
9
+ [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
10
+
@@ -0,0 +1,10 @@
1
+ # Fastly::DomainResearchResponseLinks
2
+
3
+ ## Properties
4
+
5
+ | Name | Type | Description | Notes |
6
+ | ---- | ---- | ----------- | ----- |
7
+ | **_links** | [**DomainResearchResponseLinksLinks**](DomainResearchResponseLinksLinks.md) | | [optional] |
8
+
9
+ [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
10
+
@@ -0,0 +1,10 @@
1
+ # Fastly::DomainResearchResponseLinksLinks
2
+
3
+ ## Properties
4
+
5
+ | Name | Type | Description | Notes |
6
+ | ---- | ---- | ----------- | ----- |
7
+ | **_self** | **String** | Location of resource | [optional] |
8
+
9
+ [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
10
+
@@ -0,0 +1,10 @@
1
+ # Fastly::DomainResearchResponseProduct
2
+
3
+ ## Properties
4
+
5
+ | Name | Type | Description | Notes |
6
+ | ---- | ---- | ----------- | ----- |
7
+ | **product** | [**DomainResearchResponseProductProduct**](DomainResearchResponseProductProduct.md) | | [optional] |
8
+
9
+ [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
10
+
@@ -0,0 +1,11 @@
1
+ # Fastly::DomainResearchResponseProductProduct
2
+
3
+ ## Properties
4
+
5
+ | Name | Type | Description | Notes |
6
+ | ---- | ---- | ----------- | ----- |
7
+ | **id** | **String** | Product identifier | [optional] |
8
+ | **object** | **String** | Name of the object | [optional] |
9
+
10
+ [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
11
+
@@ -6,6 +6,7 @@
6
6
  | ---- | ---- | ----------- | ----- |
7
7
  | **id** | **String** | | [optional] |
8
8
  | **name** | **String** | | [optional] |
9
+ | **display_name** | **String** | | [optional] |
9
10
  | **description** | **String** | | [optional] |
10
11
  | **permissions** | **Array&lt;String&gt;** | The set of permissions granted to this role. | [optional] |
11
12
 
@@ -4,7 +4,8 @@
4
4
 
5
5
  | Name | Type | Description | Notes |
6
6
  | ---- | ---- | ----------- | ----- |
7
- | **data** | [**Array&lt;ServiceAuthorizationResponseData&gt;**](ServiceAuthorizationResponseData.md) | | [optional] |
7
+ | **data** | [**Array&lt;SecretResponse&gt;**](SecretResponse.md) | | [optional] |
8
+ | **meta** | [**PaginationCursorMeta**](PaginationCursorMeta.md) | | [optional] |
8
9
 
9
10
  [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
10
11
 
@@ -0,0 +1,10 @@
1
+ # Fastly::InlineResponse20011
2
+
3
+ ## Properties
4
+
5
+ | Name | Type | Description | Notes |
6
+ | ---- | ---- | ----------- | ----- |
7
+ | **data** | [**Array&lt;ServiceAuthorizationResponseData&gt;**](ServiceAuthorizationResponseData.md) | | [optional] |
8
+
9
+ [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
10
+
@@ -4,8 +4,7 @@
4
4
 
5
5
  | Name | Type | Description | Notes |
6
6
  | ---- | ---- | ----------- | ----- |
7
- | **data** | [**Array&lt;KvStoreDetails&gt;**](KvStoreDetails.md) | | [optional] |
8
- | **meta** | [**PaginationCursorMeta**](PaginationCursorMeta.md) | | [optional] |
7
+ | **results** | [**Array&lt;Suggestion&gt;**](Suggestion.md) | | [optional] |
9
8
 
10
9
  [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
11
10
 
@@ -4,7 +4,7 @@
4
4
 
5
5
  | Name | Type | Description | Notes |
6
6
  | ---- | ---- | ----------- | ----- |
7
- | **data** | **Array&lt;String&gt;** | | [optional] |
7
+ | **data** | [**Array&lt;KvStoreDetails&gt;**](KvStoreDetails.md) | | [optional] |
8
8
  | **meta** | [**PaginationCursorMeta**](PaginationCursorMeta.md) | | [optional] |
9
9
 
10
10
  [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
@@ -4,7 +4,7 @@
4
4
 
5
5
  | Name | Type | Description | Notes |
6
6
  | ---- | ---- | ----------- | ----- |
7
- | **data** | [**Array&lt;SecretStoreResponse&gt;**](SecretStoreResponse.md) | | [optional] |
7
+ | **data** | **Array&lt;String&gt;** | | [optional] |
8
8
  | **meta** | [**PaginationCursorMeta**](PaginationCursorMeta.md) | | [optional] |
9
9
 
10
10
  [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
@@ -4,7 +4,7 @@
4
4
 
5
5
  | Name | Type | Description | Notes |
6
6
  | ---- | ---- | ----------- | ----- |
7
- | **data** | [**Array&lt;SecretResponse&gt;**](SecretResponse.md) | | [optional] |
7
+ | **data** | [**Array&lt;SecretStoreResponse&gt;**](SecretStoreResponse.md) | | [optional] |
8
8
  | **meta** | [**PaginationCursorMeta**](PaginationCursorMeta.md) | | [optional] |
9
9
 
10
10
  [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
data/docs/KvStoreApi.md CHANGED
@@ -17,6 +17,7 @@ Method | HTTP request | Description
17
17
  [**kv_store_delete**](KvStoreApi.md#kv_store_delete) | **DELETE** /resources/stores/kv/{store_id} | Delete a KV store.
18
18
  [**kv_store_get**](KvStoreApi.md#kv_store_get) | **GET** /resources/stores/kv/{store_id} | Describe a KV store.
19
19
  [**kv_store_list**](KvStoreApi.md#kv_store_list) | **GET** /resources/stores/kv | List all KV stores.
20
+ [**kv_store_put**](KvStoreApi.md#kv_store_put) | **PUT** /resources/stores/kv/{store_id} | Update a KV store.
20
21
 
21
22
 
22
23
  ## `kv_store_create()`
@@ -33,7 +34,7 @@ Create a KV store.
33
34
  api_instance = Fastly::KvStoreApi.new
34
35
  opts = {
35
36
  location: 'US', # String |
36
- kv_store_request_create: Fastly::KvStoreRequestCreate.new({name: 'name_example'}), # KvStoreRequestCreate |
37
+ kv_store_request_create_or_update: Fastly::KvStoreRequestCreateOrUpdate.new({name: 'name_example'}), # KvStoreRequestCreateOrUpdate |
37
38
  }
38
39
 
39
40
  begin
@@ -50,7 +51,7 @@ end
50
51
  | Name | Type | Description | Notes |
51
52
  | ---- | ---- | ----------- | ----- |
52
53
  | **location** | **String** | | [optional] |
53
- | **kv_store_request_create** | [**KvStoreRequestCreate**](KvStoreRequestCreate.md) | | [optional] |
54
+ | **kv_store_request_create_or_update** | [**KvStoreRequestCreateOrUpdate**](KvStoreRequestCreateOrUpdate.md) | | [optional] |
54
55
 
55
56
  ### Return type
56
57
 
@@ -134,7 +135,7 @@ end
134
135
  ## `kv_store_list()`
135
136
 
136
137
  ```ruby
137
- kv_store_list(opts): <InlineResponse2006> # List all KV stores.
138
+ kv_store_list(opts): <InlineResponse2007> # List all KV stores.
138
139
  ```
139
140
 
140
141
  List all KV stores.
@@ -168,7 +169,45 @@ end
168
169
 
169
170
  ### Return type
170
171
 
171
- [**InlineResponse2006**](InlineResponse2006.md)
172
+ [**InlineResponse2007**](InlineResponse2007.md)
173
+
174
+ [[Back to top]](#) [[Back to API list]](../../README.md#endpoints)
175
+ [[Back to README]](../../README.md)
176
+ ## `kv_store_put()`
177
+
178
+ ```ruby
179
+ kv_store_put(opts) # Update a KV store.
180
+ ```
181
+
182
+ Update the name of a KV store.
183
+
184
+ ### Examples
185
+
186
+ ```ruby
187
+ api_instance = Fastly::KvStoreApi.new
188
+ opts = {
189
+ store_id: 'store_id_example', # String |
190
+ kv_store_request_create_or_update: Fastly::KvStoreRequestCreateOrUpdate.new({name: 'name_example'}), # KvStoreRequestCreateOrUpdate |
191
+ }
192
+
193
+ begin
194
+ # Update a KV store.
195
+ api_instance.kv_store_put(opts)
196
+ rescue Fastly::ApiError => e
197
+ puts "Error when calling KvStoreApi->kv_store_put: #{e}"
198
+ end
199
+ ```
200
+
201
+ ### Options
202
+
203
+ | Name | Type | Description | Notes |
204
+ | ---- | ---- | ----------- | ----- |
205
+ | **store_id** | **String** | | |
206
+ | **kv_store_request_create_or_update** | [**KvStoreRequestCreateOrUpdate**](KvStoreRequestCreateOrUpdate.md) | | [optional] |
207
+
208
+ ### Return type
209
+
210
+ nil (empty response body)
172
211
 
173
212
  [[Back to top]](#) [[Back to API list]](../../README.md#endpoints)
174
213
  [[Back to README]](../../README.md)
@@ -6,6 +6,8 @@
6
6
  | ---- | ---- | ----------- | ----- |
7
7
  | **id** | **String** | ID of the store. | [optional] |
8
8
  | **name** | **String** | Name of the store. | [optional] |
9
+ | **created_at** | **String** | Timestamp at which the store was created. | [optional] |
10
+ | **updated_at** | **String** | Timestamp at which the store was last updated. | [optional] |
9
11
 
10
12
  [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
11
13
 
@@ -103,7 +103,7 @@ end
103
103
  ## `kv_store_list_item_keys()`
104
104
 
105
105
  ```ruby
106
- kv_store_list_item_keys(opts): <InlineResponse2007> # List item keys.
106
+ kv_store_list_item_keys(opts): <InlineResponse2008> # List item keys.
107
107
  ```
108
108
 
109
109
  Lists the matching item keys (or all item keys, if no prefix is supplied).
@@ -141,7 +141,7 @@ end
141
141
 
142
142
  ### Return type
143
143
 
144
- [**InlineResponse2007**](InlineResponse2007.md)
144
+ [**InlineResponse2008**](InlineResponse2008.md)
145
145
 
146
146
  [[Back to top]](#) [[Back to API list]](../../README.md#endpoints)
147
147
  [[Back to README]](../../README.md)
@@ -1,4 +1,4 @@
1
- # Fastly::KvStoreRequestCreate
1
+ # Fastly::KvStoreRequestCreateOrUpdate
2
2
 
3
3
  ## Properties
4
4
 
@@ -0,0 +1,75 @@
1
+ # Fastly::MetricsPlatformApi
2
+
3
+
4
+ ```ruby
5
+ require 'fastly'
6
+ api_instance = Fastly::MetricsPlatformApi.new
7
+ ```
8
+
9
+ ## Methods
10
+
11
+ > [!NOTE]
12
+ > All URIs are relative to `https://api.fastly.com`
13
+
14
+ Method | HTTP request | Description
15
+ ------ | ------------ | -----------
16
+ [**get_platform_metrics_service_historical**](MetricsPlatformApi.md#get_platform_metrics_service_historical) | **GET** /metrics/platform/services/{service_id}/{granularity} | Get historical time series metrics for a single service
17
+
18
+
19
+ ## `get_platform_metrics_service_historical()`
20
+
21
+ ```ruby
22
+ get_platform_metrics_service_historical(opts): <PlatformMetricsResponse> # Get historical time series metrics for a single service
23
+ ```
24
+
25
+ Fetches historical metrics for a single service for a given granularity.
26
+
27
+ ### Examples
28
+
29
+ ```ruby
30
+ api_instance = Fastly::MetricsPlatformApi.new
31
+ opts = {
32
+ service_id: 'service_id_example', # String | Alphanumeric string identifying the service.
33
+ granularity: 'minutely', # String | Duration of sample windows.
34
+ from: '2025-06-08T00:00:00.000Z', # String | A valid RFC-8339-formatted date and time indicating the inclusive start of the query time range. If not provided, a default is chosen based on the provided `granularity` value.
35
+ to: '2025-08-02T00:00:00.000Z', # String | A valid RFC-8339-formatted date and time indicating the exclusive end of the query time range. If not provided, a default is chosen based on the provided `granularity` value.
36
+ metric: 'ttfb_edge_p95_us,ttfb_edge_p99_us', # String | The metric(s) to retrieve. Multiple values should be comma-separated.
37
+ metric_set: 'ttfb', # String | The metric set(s) to retrieve. Multiple values should be comma-separated.
38
+ group_by: 'datacenter', # String | Field to group_by in the query. For example, `group_by=region` will return entries for grouped by timestamp and region.
39
+ region: 'africa_std', # String | Limit query to one or more specific geographic regions. Values should be comma-separated.
40
+ datacenter: 'SJC,STP', # String | Limit query to one or more specific POPs. Values should be comma-separated.
41
+ cursor: 'cursor_example', # String | Cursor value from the `next_cursor` field of a previous response, used to retrieve the next page. To request the first page, this should be empty.
42
+ limit: 'limit_example', # String | Number of results per page. The maximum is 10000.
43
+ }
44
+
45
+ begin
46
+ # Get historical time series metrics for a single service
47
+ result = api_instance.get_platform_metrics_service_historical(opts)
48
+ p result
49
+ rescue Fastly::ApiError => e
50
+ puts "Error when calling MetricsPlatformApi->get_platform_metrics_service_historical: #{e}"
51
+ end
52
+ ```
53
+
54
+ ### Options
55
+
56
+ | Name | Type | Description | Notes |
57
+ | ---- | ---- | ----------- | ----- |
58
+ | **service_id** | **String** | Alphanumeric string identifying the service. | |
59
+ | **granularity** | **String** | Duration of sample windows. | |
60
+ | **from** | **String** | A valid RFC-8339-formatted date and time indicating the inclusive start of the query time range. If not provided, a default is chosen based on the provided `granularity` value. | [optional] |
61
+ | **to** | **String** | A valid RFC-8339-formatted date and time indicating the exclusive end of the query time range. If not provided, a default is chosen based on the provided `granularity` value. | [optional] |
62
+ | **metric** | **String** | The metric(s) to retrieve. Multiple values should be comma-separated. | [optional] |
63
+ | **metric_set** | **String** | The metric set(s) to retrieve. Multiple values should be comma-separated. | [optional] |
64
+ | **group_by** | **String** | Field to group_by in the query. For example, `group_by&#x3D;region` will return entries for grouped by timestamp and region. | [optional] |
65
+ | **region** | **String** | Limit query to one or more specific geographic regions. Values should be comma-separated. | [optional] |
66
+ | **datacenter** | **String** | Limit query to one or more specific POPs. Values should be comma-separated. | [optional] |
67
+ | **cursor** | **String** | Cursor value from the `next_cursor` field of a previous response, used to retrieve the next page. To request the first page, this should be empty. | [optional] |
68
+ | **limit** | **String** | Number of results per page. The maximum is 10000. | [optional][default to &#39;1000&#39;] |
69
+
70
+ ### Return type
71
+
72
+ [**PlatformMetricsResponse**](PlatformMetricsResponse.md)
73
+
74
+ [[Back to top]](#) [[Back to API list]](../../README.md#endpoints)
75
+ [[Back to README]](../../README.md)
@@ -5,6 +5,7 @@
5
5
  | Name | Type | Description | Notes |
6
6
  | ---- | ---- | ----------- | ----- |
7
7
  | **workspace_id** | **String** | The workspace to link. | |
8
+ | **traffic_ramp** | **String** | The percentage of traffic to inspect. | [optional] |
8
9
 
9
10
  [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
10
11
 
data/docs/Offer.md ADDED
@@ -0,0 +1,12 @@
1
+ # Fastly::Offer
2
+
3
+ ## Properties
4
+
5
+ | Name | Type | Description | Notes |
6
+ | ---- | ---- | ----------- | ----- |
7
+ | **vendor** | **String** | The aftermarket vendor. | [optional] |
8
+ | **price** | **String** | The price for the domain from the aftermarket vendor. | [optional] |
9
+ | **currency** | **String** | The currency for the aftermarket offer. | [optional] |
10
+
11
+ [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
12
+
@@ -0,0 +1,12 @@
1
+ # Fastly::OfferAllOf
2
+
3
+ ## Properties
4
+
5
+ | Name | Type | Description | Notes |
6
+ | ---- | ---- | ----------- | ----- |
7
+ | **vendor** | **String** | The aftermarket vendor. | [optional] |
8
+ | **price** | **String** | The price for the domain from the aftermarket vendor. | [optional] |
9
+ | **currency** | **String** | The currency for the aftermarket offer. | [optional] |
10
+
11
+ [[Back to API list]](../../README.md#endpoints) [[Back to README]](../../README.md)
12
+