Get catalog maintenance configuration
client.R2DataCatalog.MaintenanceConfigs.Get(ctx, bucketName, query) (*MaintenanceConfigGetResponse, error)
GET/accounts/{account_id}/r2-catalog/{bucket_name}/maintenance-configs
Retrieve the maintenance configuration for a specific catalog, including compaction settings and credential status.
Security
API Token
The preferred authorization scheme for interacting with the Cloudflare API. Create a token.
Example:
API Email + API Key
The previous authorization scheme for interacting with the Cloudflare API, used in conjunction with a Global API key.
Example:
The previous authorization scheme for interacting with the Cloudflare API. When possible, use API tokens instead of Global API keys.
Example:
Accepted Permissions (at least one required)
Get catalog maintenance configuration
package main
import (
"context"
"fmt"
"github.com/cloudflare/cloudflare-go"
"github.com/cloudflare/cloudflare-go/option"
"github.com/cloudflare/cloudflare-go/r2_data_catalog"
)
func main() {
client := cloudflare.NewClient(
option.WithAPIToken("Sn3lZJTBX6kkg7OdcBUAxOO963GEIyGQqnFTOFYY"),
)
maintenanceConfig, err := client.R2DataCatalog.MaintenanceConfigs.Get(
context.TODO(),
"my-data-bucket",
r2_data_catalog.MaintenanceConfigGetParams{
AccountID: cloudflare.F("0123456789abcdef0123456789abcdef"),
},
)
if err != nil {
panic(err.Error())
}
fmt.Printf("%+v\n", maintenanceConfig.CredentialStatus)
}
{
"errors": [],
"messages": [],
"result": {
"credential_status": "present",
"maintenance_config": {
"compaction": {
"state": "enabled",
"target_size_mb": "128"
},
"snapshot_expiration": {
"max_snapshot_age": "7d",
"min_snapshots_to_keep": 100,
"state": "enabled"
}
}
},
"success": true
}Returns Examples
{
"errors": [],
"messages": [],
"result": {
"credential_status": "present",
"maintenance_config": {
"compaction": {
"state": "enabled",
"target_size_mb": "128"
},
"snapshot_expiration": {
"max_snapshot_age": "7d",
"min_snapshots_to_keep": 100,
"state": "enabled"
}
}
},
"success": true
}