BucketOptions
If set to true, the bucket will be publicly accessible. Default is false.
Storage class for the bucket. Default is STANDARD.
Possible values: [STANDARD, STANDARD_IA, GLACIER, GLACIER_IR]
Restricts the regions where bucket data is stored. Default is empty, which means no restrictions. See https://www.tigrisdata.com/docs/objects/object_regions/ for more details.
If set to true, per object ACL will be enabled. Default is false.
object_notifications object
Configuration for object event notifications via webhook. Receive HTTP callbacks when objects are created, updated, or deleted in your bucket.
Update behavior (partial updates supported):
- Omit field entirely: Keeps existing settings unchanged
- Include only
enabled: Toggles notifications on/off while preserving all other config - Include any field: Updates specified fields, preserves others (auth not re-required)
- Remove completely: Send
{"enabled": false}with no other fields
Common operations:
// Enable notifications (preserves webhook, filter, auth)
{"enabled": true}
// Disable temporarily (keeps all config for later)
{"enabled": false, "webhook": "https://..."}
// Update webhook only (preserves auth, filter)
{"webhook": "https://new-endpoint.com"}
// Change auth type (replaces entire auth object)
{"auth": {"token": "new-token"}}
// Remove all notifications
{"enabled": false}
Note: Auth credentials are masked in responses. You don't need to re-send them when updating other fields.
Enable or disable notifications (webhook required when true)
HTTPS endpoint to receive notification events
https://webhook.example.com/tigris-eventsSQL WHERE clause to filter which objects trigger notifications (e.g., size comparisons)
size > 1000000Region to process notifications from (defaults to server region)
iadauth object
Authentication credentials for webhook endpoint
Basic auth username
Basic auth password
Bearer token for authorization
lifecycle_rules object
Lifecycle rules to automatically transition objects to different storage classes or permanently delete (expire) them.
- Transitions: Automatically move objects to a cheaper storage class after a specified time or on a specific date. Use this for data that is accessed less frequently over time (e.g., logs, backups, archives).
- Expiration: Automatically and permanently delete objects after a specified time or on a specific date. Use this for temporary data, logs with retention policies, or any data that should be cleaned up automatically.
Example: Archive old logs and delete after 1 year
{
"rules": [
{
"id": "archive-and-cleanup-logs",
"enabled": true,
"transitions": [
{ "days": 90, "storage_class": "GLACIER" }
],
"expiration": { "days": 365 }
}
]
}
This rule transitions objects to GLACIER after 90 days, and permanently deletes them after 365 days.
Update Behavior (Partial Updates Supported)
- Omit field entirely: Keeps existing lifecycle rules unchanged
- Include empty rules array
[]: Removes all lifecycle rules - Include rules: Replaces all lifecycle rules with the provided set
Note: When updating rules, you must provide the complete rule configuration. To preserve existing rules while making changes, first retrieve the current bucket configuration, modify the desired fields, and submit the complete updated rules.
rules object[]
Unique identifier for the rule (max 255 chars). Use a descriptive name like archive-old-logs or expire-temp-uploads.
Possible values: <= 255 characters
Whether the rule is currently active. Set to false to temporarily disable a rule without deleting it.
When disabled, objects will not be transitioned or expired by this rule.
expiration object
Configuration for automatic object deletion (expiration).
When the expiration condition is met, objects matching this rule are permanently deleted.
Specify ONE Condition (Not Both)
days: Delete objects N days after their creation datedate: Delete all matching objects on a specific date
Number of days after object creation when the object will be deleted. The deletion happens at midnight UTC on the calculated expiration date.
Example: If days: 30 and an object was created on Dec 1, it expires on Dec 31.
Specific date (at midnight UTC) when all matching objects will be deleted, regardless of when they were created. Use this for one-time cleanup operations or compliance deadlines.
Must be a future date in RFC3339 format with midnight UTC time.
2025-01-01T00:00:00Ztransitions object[]
List of storage class transitions. Objects will transition through each defined step. Transitions must be in chronological order (earlier days/dates first).
Number of days after object creation when the transition occurs. The transition happens at midnight UTC on the calculated date.
Example: If days: 60 and an object was created on Jan 1, it transitions on Mar 2.
Specific date (at midnight UTC) when all matching objects will be transitioned, regardless of when they were created. Use this for planned migrations or cost optimization deadlines.
Must be a future date in RFC3339 format with midnight UTC time.
2025-06-01T00:00:00ZStorage class for the bucket. Default is STANDARD.
Possible values: [STANDARD, STANDARD_IA, GLACIER, GLACIER_IR]
{
"public": true,
"storage_class": "STANDARD",
"regions": "string",
"enable_object_acl": true,
"object_notifications": {
"enabled": true,
"webhook": "https://webhook.example.com/tigris-events",
"filter": "size > 1000000",
"region": "iad",
"auth": {
"basic_user": "string",
"basic_pass": "string",
"token": "string"
}
},
"lifecycle_rules": {
"rules": [
{
"id": "string",
"enabled": true,
"expiration": {
"days": 0,
"date": "2025-01-01T00:00:00Z"
},
"transitions": [
{
"days": 0,
"date": "2025-06-01T00:00:00Z",
"storage_class": "STANDARD"
}
]
}
]
}
}