ProvisioningRequest
Name of the bucket to be provisioned
Name of the organization where the bucket should be provisioned
org_quota object
The number of bytes that the organization is allowed to store across all of its buckets. Zero means no limit.
ID of the user who is requesting the bucket
bucket_options object
If set to true, the bucket will be publicly accessible. Default is false.
If set to true, anonymous users can list objects in public buckets. Default is false for new buckets. Only applicable to public buckets.
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 (global distribution).
Accepted values:
- Specific region(s): "iad", "sjc", "iad,sjc,lhr" (comma-separated)
- No restrictions (global distribution): "global"
If you want to remove existing region restrictions, you can set the value to "global".
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.
Enable snapshots on the bucket at creation. Snapshots can also be enabled or disabled on an existing bucket from the Storage Settings page in the Tigris Dashboard. See https://www.tigrisdata.com/docs/snapshots/.
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 > 1000000auth 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]
filter object
Optional scope for a lifecycle rule. When unset, the rule applies to every object in the bucket.
Only apply this rule to objects whose keys start with the given prefix.
For example, logs/ scopes the rule to objects under that prefix.
Role of the user in the organization. Controls what the user can do through the Partner API management endpoints.
Admin: Full org access. Can list and manage all access keys in the org, update org settings, and manage users. ListAccessKeys returns all keys in the org.Member: Standard access. Can only manage their own access keys. ListAccessKeys returns only keys owned by this user.
If omitted, defaults to Member behavior.
Possible values: [Admin, Member]
Create this bucket as a fork of the named source bucket. The source
must belong to the same organization, and the acting user must
either have user_role=Admin or own the source bucket. See
https://www.tigrisdata.com/docs/forks/.
Fork from a specific snapshot of the source bucket. Accepts a snapshot
version string or any UNIX nanosecond-precision timestamp (e.g.
1765889000501544464). Requires fork_of. See
https://www.tigrisdata.com/docs/forks/.
{
"bucket_name": "string",
"org_name": "string",
"org_quota": {
"limit_bytes": 0
},
"user_id": "string",
"bucket_options": {
"public": true,
"enable_public_list_objects": true,
"storage_class": "STANDARD",
"regions": "string",
"enable_object_acl": true,
"enable_snapshots": true,
"object_notifications": {
"enabled": true,
"webhook": "https://webhook.example.com/tigris-events",
"filter": "size > 1000000",
"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"
}
],
"filter": {
"prefix": "string"
}
}
]
}
},
"user_role": "Admin",
"fork_of": "string",
"source_snapshot": "string"
}