summaryrefslogtreecommitdiff
path: root/schemas
diff options
context:
space:
mode:
Diffstat (limited to 'schemas')
-rw-r--r--schemas/config/3.0.schema.json331
1 files changed, 249 insertions, 82 deletions
diff --git a/schemas/config/3.0.schema.json b/schemas/config/3.0.schema.json
index 5134dba0..bba1e50a 100644
--- a/schemas/config/3.0.schema.json
+++ b/schemas/config/3.0.schema.json
@@ -88,6 +88,39 @@
"server": {
"type": "object",
"properties": {
+ "after_init": {
+ "description": "Execute command or script after RR allocated a pool of workers. Command executed on the every pool allocation. For example, if you have 2 plugins: `http` and `grpc`, the `after_init` command would be fired twice.",
+ "type": "object",
+ "properties": {
+ "command": {
+ "description": "Command to execute. It can be script or binary",
+ "type": "string",
+ "examples": [
+ "php not-worker.php",
+ "sh script.sh",
+ "start script.bat"
+ ]
+ },
+ "exec_timeout": {
+ "description": "Script execute timeout",
+ "$ref": "#/definitions/Duration",
+ "default": "60s"
+ },
+ "env": {
+ "description": "Environment variables for the worker processes",
+ "type": "array",
+ "items": {
+ "type": "object",
+ "patternProperties": {
+ "^[a-zA-Z0-9._-]+$": {
+ "type": "string"
+ }
+ },
+ "additionalProperties": false
+ }
+ }
+ }
+ },
"on_init": {
"description": "Execute command or script before RR starts allocating workers",
"type": "object",
@@ -1299,6 +1332,34 @@
"description": "AMQP Uri to connect to the rabbitmq server https://www.rabbitmq.com/uri-spec.html",
"type": "string",
"default": "amqp://guest:[email protected]:5672"
+ },
+ "tls": {
+ "description": "",
+ "properties": {
+ "key": {
+ "description": "Path to the key file",
+ "type": "string"
+ },
+ "cert": {
+ "description": "Path to the cert file",
+ "type": "string"
+ },
+ "root_ca": {
+ "description": "Path to the CA certificate, defines the set of root certificate authorities that servers use if required to verify a client certificate. Used with the `client_auth_type` option.",
+ "type": "string"
+ },
+ "client_auth_type": {
+ "type": "string",
+ "default": "no_client_certs",
+ "enum": [
+ "request_client_cert",
+ "require_any_client_cert",
+ "verify_client_cert_if_given",
+ "no_client_certs",
+ "require_and_verify_client_cert"
+ ]
+ }
+ }
}
}
},
@@ -1522,79 +1583,35 @@
"type": "integer",
"default": 10
},
- "topic": {
- "description": "Topic name: https://kafka.apache.org/intro#intro_concepts_and_terms",
- "type": "string",
- "default": null
- },
- "partitions_offsets": {
- "description": "Offsets for the partitions",
- "type": "object",
- "properties": {
- "itemType": {
- "$ref": "#/definitions/HashMapInt"
- },
- "itemCount": {
- "$ref": "#/definitions/Hashmap"
- }
- },
- "default": null
- },
- "group_id": {
- "type": "string",
- "description": "Kafka group id",
- "default": "default"
- },
- "max_open_requests": {
- "description": "Max number of outstanding requests a connection is allowed to have before sending on it blocks",
- "type": "integer",
- "default": 5
- },
- "client_id": {
- "description": "A user provided string sent with every request to the brokers for logging, debugging, and auditing purposes.",
- "type": "string",
- "default": "roadrunner"
- },
- "kafka_version": {
- "description": "Kafka version.",
- "type": "string",
- "default": "1.0.0.0"
- },
- "create_topics": {
- "description": "Create topics configuration. If topic doesn't exist, RR may create a topic with provided configuration",
- "type": "object",
- "properties": {
- "replication_factor": {
- "description": "Replication factor for the data stored across several Kafka brokers.",
- "type": "integer",
- "default": 1
- },
- "replica_assignment": {
- "type": "object",
- "description": "Partition replica assigment.",
- "default": null
- },
- "config_entries": {
- "type": "object",
- "description": "Topic creation options. Note: 'compression:type' will be replaced with 'compression.type', so ':' -> '.'. All options should use ':' as the delimiter.",
- "default": null
- }
- }
+ "auto_create_topics_enable": {
+ "description": "Auto create topic for the consumer/producer",
+ "type": "boolean",
+ "default": false
},
"producer_options": {
"description": "Kafka producer options",
"type": "object",
"properties": {
- "max_message_bytes": {
- "type": "integer",
- "default": 1000000
+ "disable_idempotent": {
+ "description": "Disable_idempotent disables idempotent produce requests, opting out of Kafka server-side deduplication in the face of reissued requests due to transient network problems. Idempotent production is strictly a win, but does require the IDEMPOTENT_WRITE permission on CLUSTER (pre Kafka 3.0), and not all clients can have that permission.",
+ "type": "boolean",
+ "default": false
},
"required_acks": {
- "description": "The level of acknowledgement reliability needed from the broker.",
+ "description": "Sets the required acks for produced records",
+ "type": "string",
+ "default": "AllISRAcks",
+ "enum": [
+ "NoAck",
+ "LeaderAck",
+ "AllISRAck"
+ ]
+ },
+ "max_message_bytes": {
"type": "integer",
- "default": -1
+ "default": 1000012
},
- "timeout": {
+ "request_timeout": {
"description": "The maximum duration in seconds the broker will wait the receipt of the number of required_acks.",
"default": 10,
"type": "integer"
@@ -1610,41 +1627,114 @@
"zstd"
]
},
- "compression_level": {
+ "delivery_timeout": {
"description": "The level of compression to use on messages.",
"type": "integer",
"default": null
},
- "idempotent": {
+ "transaction_timeout": {
"description": "If enabled, the producer will ensure that exactly one copy of each message is written.",
"type": "boolean",
"default": false
}
}
},
+ "group_options": {
+ "description": "group_options sets the consumer group for the client to join and consume in. This option is required if using any other group options.",
+ "properties": {
+ "group_id":{
+ "description": "Kafka group ID",
+ "type": "string",
+ "default": null
+ },
+ "block_rebalance_on_poll":{
+ "description": "Switches the client to block rebalances whenever you poll",
+ "type": "boolean",
+ "default": false
+ }
+ }
+ },
"consumer_options": {
"description": "Kafka consumer options",
"type": "object",
"properties": {
- "min_fetch_message_size": {
- "description": "The minimum number of message bytes to fetch in a request",
- "type": "integer",
- "default": 1
+ "topics": {
+ "description": "List of the topics to consume. Regex also supported",
+ "type": "array",
+ "default": null
+ },
+ "consume_regexp": {
+ "description": "consume_regexp sets the client to parse all topics passed to `topics` as regular expressions. When consuming via regex, every metadata request loads *all* topics, so that all topics can be passed to any regular expressions. Every topic is evaluated only once ever across all regular expressions; either it permanently is known to match, or is permanently known to not match.",
+ "type": "boolean",
+ "default": false
},
"max_fetch_message_size": {
"type": "integer",
- "description": "The default number of message bytes to fetch from the broker in each request",
- "default": 1000000
+ "default": 50000
},
- "session_timeout": {
+ "min_fetch_message_size": {
"type": "integer",
- "description": "The timeout in seconds used to detect consumer failures when using Kafka's group management facility.",
- "default": 10
+ "default": 1
},
- "heartbeat_interval": {
- "type": "integer",
- "description": "The expected time in seconds between heartbeats to the consumer coordinator when using Kafka's group management facilities",
- "default": 3
+ "consume_offset": {
+ "description": "consumer_offset sets the offset to start consuming from, or if OffsetOutOfRange is seen while fetching, to restart consuming from.",
+ "type": "object",
+ "properties": {
+ "type":{
+ "description": "Partition offset type",
+ "type": "string",
+ "default": null,
+ "enum": [
+ "AtEnd",
+ "At",
+ "AfterMilli",
+ "AtStart",
+ "Relative",
+ "WithEpoch"
+ ]
+ },
+ "value": {
+ "description": "Value for the: At, AfterMilli, Relative and WithEpoch offsets",
+ "type": "integer",
+ "default": 0
+ }
+ }
+ },
+ "consume_partitions": {
+ "patternProperties": {
+ "^[a-zA-Z0-9._-]+$": {
+ "description": "Topic to consume",
+ "type":"string",
+ "default": null,
+ "patternProperties": {
+ "^[0-9]+$":{
+ "description": "Partition number",
+ "type": "integer",
+ "default": null,
+ "properties": {
+ "type":{
+ "description": "Partition offset type",
+ "type": "string",
+ "default": null,
+ "enum": [
+ "AtEnd",
+ "At",
+ "AfterMilli",
+ "AtStart",
+ "Relative",
+ "WithEpoch"
+ ]
+ },
+ "value": {
+ "description": "Value for the: At, AfterMilli, Relative and WithEpoch offsets",
+ "type": "integer",
+ "default": 0
+ }
+ }
+ }
+ }
+ }
+ }
}
}
}
@@ -2135,6 +2225,11 @@
"type": "object",
"$ref": "#/definitions/Hashmap"
},
+ "timeout_stop_sec": {
+ "description": "Timeout for the process stop operation",
+ "type":"integer",
+ "default": 5
+ },
"process_num": {
"description": "Number of copies (processes) to start per command",
"type": "integer",
@@ -2373,9 +2468,81 @@
"description": "Kafka jobs driver",
"type": "object",
"properties": {
- "addr": {
- "description": "Kafka server addresses",
- "type": "array"
+ "brokers": {
+ "description": "Kafka broker addresses",
+ "type": "array",
+ "items": {
+ "type": "string",
+ "enum": [
+ "127.0.0.1:9092",
+ "127.0.0.1:9002"
+ ]
+ }
+ },
+ "sasl": {
+ "description": "Mechanism used for the authentication",
+ "properties": {
+ "mechanism":{
+ "description": "Kafka brokers",
+ "type": "string",
+ "items": {
+ "type": "string",
+ "enum": [
+ "aws_msk_iam",
+ "plain",
+ "SCRAM-SHA-256",
+ "SCRAM-SHA-512"
+ ]
+ }
+ },
+ "username":{
+ "description": "Username for authentication",
+ "type": "string",
+ "default": null
+ },
+ "password":{
+ "description": "Password for authentication",
+ "type": "string",
+ "default": null
+ },
+ "nonce":{
+ "description": "Optional for the SHA auth types. Empty by default",
+ "type": "string",
+ "default": null
+ },
+ "is_token":{
+ "description": "If true, suffixes the tokenauth=true extra attribute to the initial authentication message. Set this to true if the user and pass are from a delegation token. Optional for the SHA auth types. Empty by default",
+ "type": "boolean",
+ "default": false
+ },
+ "zid":{
+ "description": "Zid is an optional authorization ID to use in authenticating",
+ "type": "string",
+ "default": null
+ },
+
+
+ "access_key":{
+ "description": "AWS Access key ID",
+ "type": "string",
+ "default": null
+ },
+ "secret_key":{
+ "description": "AWS Secret Access key ID",
+ "type": "string",
+ "default": null
+ },
+ "session_token":{
+ "description": "SessionToken, if non-empty, is a session / security token to use for authentication. See the following link for more details: https://docs.aws.amazon.com/STS/latest/APIReference/welcome.html",
+ "type": "string",
+ "default": null
+ },
+ "user_agent":{
+ "description": "UserAgent is the user agent to for the client to use when connecting to Kafka, overriding the default franz-go/<runtime.Version()>/<hostname>. Setting a UserAgent allows authorizing based on the aws:UserAgent condition key; see the following link for more details: https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-useragent",
+ "type": "string",
+ "default": null
+ }
+ }
}
}
},