Files
tibi-types/schemas/api-config/permissions.json
Sebastian Frank 025a7ccca4
All checks were successful
continuous-integration/drone/push Build is passing
feat(schema): enhance API configuration schemas with new properties and validations
- Updated collection.json to include upload defaults, audit logging, query limits, and more.
- Enhanced collectionNavigation.json with viewHint configurations.
- Added project-wide upload defaults and hook configurations in config.json.
- Expanded field.json to support new field types, validations, and properties.
- Improved fieldMeta.json with additional widget configurations and properties.
- Updated hooks.json to include new bulk operation hooks and audit logging.
- Enhanced imageFilter.json with additional image processing options.
- Added timeout properties to job.json for better execution control.
- Refined permissions.json to allow more granular control over HTTP method permissions and added filter and field visibility options.
2026-03-30 12:28:50 +00:00

129 lines
5.3 KiB
JSON

{
"$schema": "http://json-schema.org/draft-07/schema#",
"title": "JSON Schema tibi-server permissions configuration",
"description": "tibi-server permissions linter",
"type": "object",
"additionalProperties": false,
"properties": {
"public": {
"description": "permissions for unauthorized public access",
"$ref": "#/definitions/permissionSet"
},
"user": {
"description": "permissions for authorized users (nativ tibi-server auth)",
"$ref": "#/definitions/permissionSet"
}
},
"patternProperties": {
"^x\\-": {
"description": "template property"
},
"^token:": {
"description": "permissions for header or query token",
"$ref": "#/definitions/permissionSet"
},
"^[a-zA-Z0-9_]+$": {
"description": "custom permissions",
"$ref": "#/definitions/permissionSet"
}
},
"required": ["public", "user"],
"definitions": {
"permissionSet": {
"type": "object",
"additionalProperties": false,
"properties": {
"methods": {
"type": "object",
"description": "permissions for http methods",
"additionalProperties": false,
"properties": {
"get": {
"oneOf": [
{ "type": "boolean" },
{
"type": "object",
"properties": {
"allow": { "type": "boolean", "description": "Allow GET." }
},
"required": ["allow"],
"additionalProperties": false
}
]
},
"post": {
"oneOf": [
{ "type": "boolean" },
{
"type": "object",
"properties": {
"allow": { "type": "boolean", "description": "Allow single-document POST." },
"bulk": { "type": "boolean", "description": "Allow bulk POST (JSON array body)." }
},
"required": ["allow"],
"additionalProperties": false
}
]
},
"put": {
"oneOf": [
{ "type": "boolean" },
{
"type": "object",
"properties": {
"allow": { "type": "boolean", "description": "Allow single-document PUT." },
"bulk": { "type": "boolean", "description": "Allow bulk PUT (without ID)." }
},
"required": ["allow"],
"additionalProperties": false
}
]
},
"delete": {
"oneOf": [
{ "type": "boolean" },
{
"type": "object",
"properties": {
"allow": { "type": "boolean", "description": "Allow single-document DELETE." },
"bulk": { "type": "boolean", "description": "Allow bulk DELETE (without ID)." }
},
"required": ["allow"],
"additionalProperties": false
}
]
}
}
},
"validProjections": {
"type": "array",
"description": "list of projection names this permission set is allowed to use",
"items": {
"type": "string"
}
},
"filter": {
"type": "object",
"description": "MongoDB filter applied to all queries for this permission set",
"additionalProperties": true
},
"readonlyFields": {
"type": "array",
"description": "fields that are read-only for this permission set",
"items": {
"type": "string"
}
},
"hiddenFields": {
"type": "array",
"description": "fields that are hidden for this permission set",
"items": {
"type": "string"
}
}
},
"required": ["methods"]
}
}
}