Cloud CDN API, gRPC: ResourceRulesService.Create
- gRPC request
- CreateResourceRuleRequest
- ResourceOptions
- BoolOption
- EdgeCacheSettings
- CachingTimes
- Int64Option
- StringsListOption
- QueryParamsOptions
- CompressionOptions
- RedirectOptions
- HostOptions
- StringOption
- StringsMapOption
- RewriteOption
- SecureKeyOption
- IPAddressACLOption
- operation.Operation
- CreateResourceRuleMetadata
- Rule
- ResourceOptions
- BoolOption
- EdgeCacheSettings
- CachingTimes
- Int64Option
- StringsListOption
- QueryParamsOptions
- CompressionOptions
- RedirectOptions
- HostOptions
- StringOption
- StringsMapOption
- RewriteOption
- SecureKeyOption
- IPAddressACLOption
Create new resource rule with specified unique name and rule patter.
gRPC request
rpc Create (CreateResourceRuleRequest) returns (operation.Operation)
CreateResourceRuleRequest
{
"resourceId": "string",
"name": "string",
"rulePattern": "string",
"options": {
"disableCache": {
"enabled": "bool",
"value": "bool"
},
"edgeCacheSettings": {
"enabled": "bool",
// Includes only one of the fields `value`, `defaultValue`
"value": {
"simpleValue": "int64",
"customValues": "int64"
},
"defaultValue": "int64"
// end of the list of possible fields
},
"browserCacheSettings": {
"enabled": "bool",
"value": "int64"
},
"cacheHttpHeaders": {
"enabled": "bool",
"value": [
"string"
]
},
"queryParamsOptions": {
// Includes only one of the fields `ignoreQueryString`, `queryParamsWhitelist`, `queryParamsBlacklist`
"ignoreQueryString": {
"enabled": "bool",
"value": "bool"
},
"queryParamsWhitelist": {
"enabled": "bool",
"value": [
"string"
]
},
"queryParamsBlacklist": {
"enabled": "bool",
"value": [
"string"
]
}
// end of the list of possible fields
},
"slice": {
"enabled": "bool",
"value": "bool"
},
"compressionOptions": {
// Includes only one of the fields `fetchCompressed`, `gzipOn`, `brotliCompression`
"fetchCompressed": {
"enabled": "bool",
"value": "bool"
},
"gzipOn": {
"enabled": "bool",
"value": "bool"
},
"brotliCompression": {
"enabled": "bool",
"value": [
"string"
]
}
// end of the list of possible fields
},
"redirectOptions": {
// Includes only one of the fields `redirectHttpToHttps`, `redirectHttpsToHttp`
"redirectHttpToHttps": {
"enabled": "bool",
"value": "bool"
},
"redirectHttpsToHttp": {
"enabled": "bool",
"value": "bool"
}
// end of the list of possible fields
},
"hostOptions": {
// Includes only one of the fields `host`, `forwardHostHeader`
"host": {
"enabled": "bool",
"value": "string"
},
"forwardHostHeader": {
"enabled": "bool",
"value": "bool"
}
// end of the list of possible fields
},
"staticHeaders": {
"enabled": "bool",
"value": "string"
},
"cors": {
"enabled": "bool",
"value": [
"string"
]
},
"stale": {
"enabled": "bool",
"value": [
"string"
]
},
"allowedHttpMethods": {
"enabled": "bool",
"value": [
"string"
]
},
"proxyCacheMethodsSet": {
"enabled": "bool",
"value": "bool"
},
"disableProxyForceRanges": {
"enabled": "bool",
"value": "bool"
},
"staticRequestHeaders": {
"enabled": "bool",
"value": "string"
},
"customServerName": {
"enabled": "bool",
"value": "string"
},
"ignoreCookie": {
"enabled": "bool",
"value": "bool"
},
"rewrite": {
"enabled": "bool",
"body": "string",
"flag": "RewriteFlag"
},
"secureKey": {
"enabled": "bool",
"key": "string",
"type": "SecureKeyURLType"
},
"ipAddressAcl": {
"enabled": "bool",
"policyType": "PolicyType",
"exceptedValues": [
"string"
]
}
}
}
Field |
Description |
resourceId |
string Required field. ID of resource. |
name |
string Required field. Name of created resource rule. |
rulePattern |
string Required field. Resource rule pattern. |
options |
ResourceOptions
A major set of various resource options.
Field |
Description |
disableCache |
Set up a cache status. |
edgeCacheSettings |
Set up EdgeCacheSettings. |
browserCacheSettings |
Using Int64Option. Set up a cache period for the end-users browser. |
cacheHttpHeaders |
List HTTP headers that must be included in responses to clients. |
queryParamsOptions |
Set up QueryParamsOptions. |
slice |
Files larger than 10 MB will be requested and cached in parts (no larger than 10 MB each part). It reduces time to first byte. The origin must support HTTP Range requests. By default the option is disabled. |
compressionOptions |
Set up compression variant. |
redirectOptions |
Set up redirects. |
hostOptions |
Set up host parameters. |
staticHeaders |
Set up static headers that CDN servers send in responses to clients. |
cors |
Parameter that lets browsers get access to selected resources from a domain |
stale |
List of errors which instruct CDN servers to serve stale content to clients. Possible values: |
allowedHttpMethods |
HTTP methods for your CDN content. By default the following methods |
proxyCacheMethodsSet |
Allows caching for GET, HEAD and POST requests. |
disableProxyForceRanges |
Disabling proxy force ranges. |
staticRequestHeaders |
Set up custom headers that CDN servers send in requests to origins. |
customServerName |
Wildcard additional CNAME. |
ignoreCookie |
Using BoolOption for ignoring cookie. |
rewrite |
Changing or redirecting query paths. |
secureKey |
Secure token to protect contect and limit access by IP addresses and time limits. |
ipAddressAcl |
Manage the state of the IP access policy option. |
BoolOption
Set up bool values.
Field |
Description |
enabled |
bool True - the option is enabled and its |
value |
bool Value of the option. |
EdgeCacheSettings
A set of the edge cache parameters.
Field |
Description |
enabled |
bool True - the option is enabled and its |
value |
Value of the option. Includes only one of the fields |
defaultValue |
int64 Content will be cached according to origin cache settings. Includes only one of the fields |
CachingTimes
A set of the caching response time parameters.
Field |
Description |
simpleValue |
int64 Caching time for a response with codes 200, 206, 301, 302. |
customValues |
int64 Caching time for a response with specific codes. These settings have a higher priority than the value field. |
Int64Option
A set of the numeric parameters.
Field |
Description |
enabled |
bool True - the option is enabled and its |
value |
int64 Value of the option. |
StringsListOption
A set of the string list parameters.
Field |
Description |
enabled |
bool True - the option is enabled and its |
value[] |
string Value of the option. |
QueryParamsOptions
A set of the query parameters.
Field |
Description |
ignoreQueryString |
Using BoolOption. Selected by default. Files with different query parameters are cached as objects with the same key regardless of the parameter value. Includes only one of the fields |
queryParamsWhitelist |
Ignore All Except. Includes only one of the fields |
queryParamsBlacklist |
Ignore only. Files with the specified query parameters are cached as objects with the same key, Includes only one of the fields |
CompressionOptions
A set of the compression variant parameters.
Field |
Description |
fetchCompressed |
The Fetch compressed option helps you to reduce Includes only one of the fields |
gzipOn |
Using BoolOption. GZip compression at CDN servers reduces file size by 70% and can be as high as 90%. Includes only one of the fields |
brotliCompression |
The option allows to compress content with brotli on the CDN's end. Compression is performed on the Origin Shielding. If a pre-cache server doesn't active for a resource, compression does not occur even if the option is enabled. Specify the content-type for each type of content you wish to have compressed. CDN servers will request only uncompressed content from the origin. Includes only one of the fields |
RedirectOptions
A set of the redirect parameters.
Field |
Description |
redirectHttpToHttps |
Using BoolOption. Set up a redirect from HTTPS to HTTP. Includes only one of the fields |
redirectHttpsToHttp |
Using BoolOption. Set up a redirect from HTTP to HTTPS. Includes only one of the fields |
HostOptions
A set of the host parameters.
Field |
Description |
host |
Custom value for the Host header. Your server must be able to process requests with the chosen header. Default value (if StringOption.enabled is Includes only one of the fields |
forwardHostHeader |
Using BoolOption. Choose the Forward Host header option if is important to send in the request to the Origin Includes only one of the fields |
StringOption
A set of the string parameters.
Field |
Description |
enabled |
bool True - the option is enabled and its |
value |
string Value of the option. |
StringsMapOption
A set of the strings map parameters.
Field |
Description |
enabled |
bool True - the option is enabled and its |
value |
string Value of the option. |
RewriteOption
An option for changing or redirecting query paths.
Field |
Description |
enabled |
bool True - the option is enabled and its |
body |
string Pattern for rewrite. The value must have the following format: |
flag |
enum RewriteFlag Break flag is applied to the option by default.
|
SecureKeyOption
Field |
Description |
enabled |
bool True - the option is enabled and its flag is applied to the resource. |
key |
string The key for the URL signing. |
type |
enum SecureKeyURLType The type of the URL signing. The URL could be available for all IP addresses or for the only one IP.
|
IPAddressACLOption
Field |
Description |
enabled |
bool True - the option is enabled and its flag is applied to the resource. |
policyType |
enum PolicyType The policy type. One of allow or deny value.
|
exceptedValues[] |
string The list of IP addresses to be allowed or denied. |
operation.Operation
{
"id": "string",
"description": "string",
"createdAt": "google.protobuf.Timestamp",
"createdBy": "string",
"modifiedAt": "google.protobuf.Timestamp",
"done": "bool",
"metadata": {
"resourceId": "string",
"ruleId": "int64"
},
// Includes only one of the fields `error`, `response`
"error": "google.rpc.Status",
"response": {
"id": "int64",
"name": "string",
"rulePattern": "string",
"options": {
"disableCache": {
"enabled": "bool",
"value": "bool"
},
"edgeCacheSettings": {
"enabled": "bool",
// Includes only one of the fields `value`, `defaultValue`
"value": {
"simpleValue": "int64",
"customValues": "int64"
},
"defaultValue": "int64"
// end of the list of possible fields
},
"browserCacheSettings": {
"enabled": "bool",
"value": "int64"
},
"cacheHttpHeaders": {
"enabled": "bool",
"value": [
"string"
]
},
"queryParamsOptions": {
// Includes only one of the fields `ignoreQueryString`, `queryParamsWhitelist`, `queryParamsBlacklist`
"ignoreQueryString": {
"enabled": "bool",
"value": "bool"
},
"queryParamsWhitelist": {
"enabled": "bool",
"value": [
"string"
]
},
"queryParamsBlacklist": {
"enabled": "bool",
"value": [
"string"
]
}
// end of the list of possible fields
},
"slice": {
"enabled": "bool",
"value": "bool"
},
"compressionOptions": {
// Includes only one of the fields `fetchCompressed`, `gzipOn`, `brotliCompression`
"fetchCompressed": {
"enabled": "bool",
"value": "bool"
},
"gzipOn": {
"enabled": "bool",
"value": "bool"
},
"brotliCompression": {
"enabled": "bool",
"value": [
"string"
]
}
// end of the list of possible fields
},
"redirectOptions": {
// Includes only one of the fields `redirectHttpToHttps`, `redirectHttpsToHttp`
"redirectHttpToHttps": {
"enabled": "bool",
"value": "bool"
},
"redirectHttpsToHttp": {
"enabled": "bool",
"value": "bool"
}
// end of the list of possible fields
},
"hostOptions": {
// Includes only one of the fields `host`, `forwardHostHeader`
"host": {
"enabled": "bool",
"value": "string"
},
"forwardHostHeader": {
"enabled": "bool",
"value": "bool"
}
// end of the list of possible fields
},
"staticHeaders": {
"enabled": "bool",
"value": "string"
},
"cors": {
"enabled": "bool",
"value": [
"string"
]
},
"stale": {
"enabled": "bool",
"value": [
"string"
]
},
"allowedHttpMethods": {
"enabled": "bool",
"value": [
"string"
]
},
"proxyCacheMethodsSet": {
"enabled": "bool",
"value": "bool"
},
"disableProxyForceRanges": {
"enabled": "bool",
"value": "bool"
},
"staticRequestHeaders": {
"enabled": "bool",
"value": "string"
},
"customServerName": {
"enabled": "bool",
"value": "string"
},
"ignoreCookie": {
"enabled": "bool",
"value": "bool"
},
"rewrite": {
"enabled": "bool",
"body": "string",
"flag": "RewriteFlag"
},
"secureKey": {
"enabled": "bool",
"key": "string",
"type": "SecureKeyURLType"
},
"ipAddressAcl": {
"enabled": "bool",
"policyType": "PolicyType",
"exceptedValues": [
"string"
]
}
}
}
// end of the list of possible fields
}
An Operation resource. For more information, see Operation.
Field |
Description |
id |
string ID of the operation. |
description |
string Description of the operation. 0-256 characters long. |
createdAt |
Creation timestamp. |
createdBy |
string ID of the user or service account who initiated the operation. |
modifiedAt |
The time when the Operation resource was last modified. |
done |
bool If the value is |
metadata |
Service-specific metadata associated with the operation. |
error |
The error result of the operation in case of failure or cancellation. Includes only one of the fields The operation result. |
response |
The normal response of the operation in case of success. Includes only one of the fields The operation result. |
CreateResourceRuleMetadata
Field |
Description |
resourceId |
string Required field. ID of resource. |
ruleId |
int64 ID of created resource rule. |
Rule
Resource rule.
Field |
Description |
id |
int64 Rule ID. |
name |
string Required field. Rule name. |
rulePattern |
string Required field. Rule pattern. |
options |
ResourceOptions
A major set of various resource options.
Field |
Description |
disableCache |
Set up a cache status. |
edgeCacheSettings |
Set up EdgeCacheSettings. |
browserCacheSettings |
Using Int64Option. Set up a cache period for the end-users browser. |
cacheHttpHeaders |
List HTTP headers that must be included in responses to clients. |
queryParamsOptions |
Set up QueryParamsOptions. |
slice |
Files larger than 10 MB will be requested and cached in parts (no larger than 10 MB each part). It reduces time to first byte. The origin must support HTTP Range requests. By default the option is disabled. |
compressionOptions |
Set up compression variant. |
redirectOptions |
Set up redirects. |
hostOptions |
Set up host parameters. |
staticHeaders |
Set up static headers that CDN servers send in responses to clients. |
cors |
Parameter that lets browsers get access to selected resources from a domain |
stale |
List of errors which instruct CDN servers to serve stale content to clients. Possible values: |
allowedHttpMethods |
HTTP methods for your CDN content. By default the following methods |
proxyCacheMethodsSet |
Allows caching for GET, HEAD and POST requests. |
disableProxyForceRanges |
Disabling proxy force ranges. |
staticRequestHeaders |
Set up custom headers that CDN servers send in requests to origins. |
customServerName |
Wildcard additional CNAME. |
ignoreCookie |
Using BoolOption for ignoring cookie. |
rewrite |
Changing or redirecting query paths. |
secureKey |
Secure token to protect contect and limit access by IP addresses and time limits. |
ipAddressAcl |
Manage the state of the IP access policy option. |
BoolOption
Set up bool values.
Field |
Description |
enabled |
bool True - the option is enabled and its |
value |
bool Value of the option. |
EdgeCacheSettings
A set of the edge cache parameters.
Field |
Description |
enabled |
bool True - the option is enabled and its |
value |
Value of the option. Includes only one of the fields |
defaultValue |
int64 Content will be cached according to origin cache settings. Includes only one of the fields |
CachingTimes
A set of the caching response time parameters.
Field |
Description |
simpleValue |
int64 Caching time for a response with codes 200, 206, 301, 302. |
customValues |
int64 Caching time for a response with specific codes. These settings have a higher priority than the value field. |
Int64Option
A set of the numeric parameters.
Field |
Description |
enabled |
bool True - the option is enabled and its |
value |
int64 Value of the option. |
StringsListOption
A set of the string list parameters.
Field |
Description |
enabled |
bool True - the option is enabled and its |
value[] |
string Value of the option. |
QueryParamsOptions
A set of the query parameters.
Field |
Description |
ignoreQueryString |
Using BoolOption. Selected by default. Files with different query parameters are cached as objects with the same key regardless of the parameter value. Includes only one of the fields |
queryParamsWhitelist |
Ignore All Except. Includes only one of the fields |
queryParamsBlacklist |
Ignore only. Files with the specified query parameters are cached as objects with the same key, Includes only one of the fields |
CompressionOptions
A set of the compression variant parameters.
Field |
Description |
fetchCompressed |
The Fetch compressed option helps you to reduce Includes only one of the fields |
gzipOn |
Using BoolOption. GZip compression at CDN servers reduces file size by 70% and can be as high as 90%. Includes only one of the fields |
brotliCompression |
The option allows to compress content with brotli on the CDN's end. Compression is performed on the Origin Shielding. If a pre-cache server doesn't active for a resource, compression does not occur even if the option is enabled. Specify the content-type for each type of content you wish to have compressed. CDN servers will request only uncompressed content from the origin. Includes only one of the fields |
RedirectOptions
A set of the redirect parameters.
Field |
Description |
redirectHttpToHttps |
Using BoolOption. Set up a redirect from HTTPS to HTTP. Includes only one of the fields |
redirectHttpsToHttp |
Using BoolOption. Set up a redirect from HTTP to HTTPS. Includes only one of the fields |
HostOptions
A set of the host parameters.
Field |
Description |
host |
Custom value for the Host header. Your server must be able to process requests with the chosen header. Default value (if StringOption.enabled is Includes only one of the fields |
forwardHostHeader |
Using BoolOption. Choose the Forward Host header option if is important to send in the request to the Origin Includes only one of the fields |
StringOption
A set of the string parameters.
Field |
Description |
enabled |
bool True - the option is enabled and its |
value |
string Value of the option. |
StringsMapOption
A set of the strings map parameters.
Field |
Description |
enabled |
bool True - the option is enabled and its |
value |
string Value of the option. |
RewriteOption
An option for changing or redirecting query paths.
Field |
Description |
enabled |
bool True - the option is enabled and its |
body |
string Pattern for rewrite. The value must have the following format: |
flag |
enum RewriteFlag Break flag is applied to the option by default.
|
SecureKeyOption
Field |
Description |
enabled |
bool True - the option is enabled and its flag is applied to the resource. |
key |
string The key for the URL signing. |
type |
enum SecureKeyURLType The type of the URL signing. The URL could be available for all IP addresses or for the only one IP.
|
IPAddressACLOption
Field |
Description |
enabled |
bool True - the option is enabled and its flag is applied to the resource. |
policyType |
enum PolicyType The policy type. One of allow or deny value.
|
exceptedValues[] |
string The list of IP addresses to be allowed or denied. |