diff options
-rw-r--r-- | .rr.yaml | 99 | ||||
-rw-r--r-- | schemas/config/2.0.schema.json | 359 |
2 files changed, 441 insertions, 17 deletions
@@ -543,22 +543,87 @@ http: # Error if empty. NEW_RELIC_LICENSE_KEY env variable should be set if the license_key key is empty. If both empty - error. license_key: "key" - # RFC 7234 (partially) RR Cache middleware + # RFC 7234 RR Cache middleware + # + # Link: https://github.com/darkweak/souin cache: - # Cache driver - # - # Default: memory. Available drivers: memory - driver: memory - - # Methods to cache - # - # According to the RFC, we can cache only GET, HEAD or POST requests. Currently, only GET method supported. - cache_methods: [ "GET", "HEAD", "POST" ] - - # Configuration for the driver - # - # Empty for the memory - config: { } + api: + basepath: /souin-api + prometheus: + basepath: /anything-for-prometheus-metrics + souin: + basepath: /anything-for-souin + cache_keys: + '.*\.css': + disable_body: true + disable_host: true + disable_method: true + cdn: + api_key: XXXX + provider: fastly + strategy: soft + dynamic: true + default_cache: + allowed_http_verbs: + - GET + - POST + - HEAD + cache_name: Souin + distributed: true + headers: + - Authorization + key: + disable_body: true + disable_host: true + disable_method: true + etcd: + configuration: + endpoints: + - etcd-1:2379 + - etcd-2:2379 + - etcd-3:2379 + olric: + url: 'olric:3320' + regex: + exclude: 'ARegexHere' + stale: 1000s + timeout: + backend: 10s + cache: 20ms + ttl: 1000s + default_cache_control: no-store + log_level: INFO + ssl_providers: + - traefik + urls: + 'https:\/\/domain.com\/first-.+': + ttl: 1000s + 'https:\/\/domain.com\/second-route': + ttl: 10s + headers: + - Authorization + 'https?:\/\/mysubdomain\.domain\.com': + ttl: 50s + headers: + - Authorization + - 'Content-Type' + default_cache_control: public, max-age=86400 + ykeys: + The_First_Test: + headers: + Content-Type: '.+' + The_Second_Test: + url: 'the/second/.+' + The_Third_Test: + The_Fourth_Test: + surrogate_keys: + The_First_Test: + headers: + Content-Type: '.+' + The_Second_Test: + url: 'the/second/.+' + The_Third_Test: + The_Fourth_Test: # File uploading settings. uploads: @@ -1413,7 +1478,9 @@ jobs: - 1: 0 - 2: 0 - # not supported in beta.3 + # Kafka group id + # + # Optional, default - empty group_id: "foo" # Max number of outstanding requests a connection is allowed to have before sending on it blocks diff --git a/schemas/config/2.0.schema.json b/schemas/config/2.0.schema.json index 22c59ba1..d3a794cf 100644 --- a/schemas/config/2.0.schema.json +++ b/schemas/config/2.0.schema.json @@ -406,8 +406,210 @@ "description": "Default route basepath for every additional APIs to avoid conflicts with existing routes", "type": "string", "default": null + }, + "prometheus": { + "type": "object", + "description": "Prometheus exposed metrics", + "properties": { + "basepath": { + "type": "string", + "default": null + } + } + }, + "souin": { + "type": "object", + "description": "Souin listing keys and cache management", + "properties": { + "basepath": { + "type": "string", + "default": null + } + } + } + } + }, + "cache_keys": { + "type": "object", + "patternProperties": { + "^[a-zA-Z0-9._-]+$": { + "description": "cache keys configuration", + "type": "object", + "properties": { + "disable_body": { + "type": "boolean", + "default": false + }, + "disable_host": { + "type": "boolean", + "default": false + }, + "disable_method": { + "type": "boolean", + "default": false + } + } + } + } + }, + "cdn": { + "description": "If Souin is set after a CDN fill these information", + "type": "object", + "properties": { + "api_key": { + "type": "string", + "description": "Your provider API key if mandatory" + }, + "provider": { + "description": "The provider placed before Souin (e.g. fastly, cloudflare, akamai, varnish)", + "type": "string", + "enum": [ + "fastly", + "cloudflare", + "akamai", + "varnish" + ] + }, + "strategy": { + "description": "The strategy to purge the CDN cache based on tags (e.g. soft, hard)", + "type": "string", + "enum": [ + "soft", + "hard" + ] + }, + "dynamic": { + "description": "If true, you'll be able to add custom keys than the ones defined under the surrogate_keys key", + "type": "boolean", + "default": false + } + } + }, + "default_cache": { + "type": "object", + "properties": { + "allowed_http_verbs": { + "type": "array", + "default": [ + "GET", + "POST" + ] + }, + "cache_name": { + "description": "Override the cache name to use in the Cache-Status header", + "type": "string", + "default": "roadrunner" + }, + "distributed": { + "type": "boolean", + "default": false, + "description": "Use Olric or Etcd distributed storage" + }, + "headers": { + "description": "Default headers concatenated in stored keys", + "type": "array", + "default": null + }, + "key": { + "type": "object", + "properties": { + "disable_body": { + "type": "boolean", + "default": false + }, + "disable_host": { + "type": "boolean", + "default": false + }, + "disable_method": { + "type": "boolean", + "default": false + } + } + }, + "etcd": { + "description": "If distributed is set to true, you'll have to define either the etcd or olric section", + "type": "object", + "properties": { + "configuration": { + "type": "object", + "description": "Configure directly the Etcd client", + "properties": { + "endpoints": { + "description": "Define multiple endpoints", + "type": "array", + "default": null + } + } + } + } + }, + "olric": { + "type": "object", + "description": "If distributed is set to true, you'll have to define either the etcd or olric section", + "properties": { + "url": { + "description": "Olric server", + "type": "string", + "default": "http://127.0.0.1:3320" + } + } + }, + "regex": { + "type": "object", + "description": "Regex to exclude from cache", + "properties": { + "exclude": { + "type": "string", + "default": null + } + } + }, + "stale": { + "type": "string", + "description": "Stale duration", + "default": "1000s" + }, + "timeout": { + "description": "Timeout configuration", + "type": "object", + "properties": { + "backend": { + "description": "Backend timeout before returning an HTTP unavailable response", + "type": "string", + "default": "10s" + }, + "cache": { + "description": "Cache provider (badger, etcd, nutsdb, olric, depending the configuration you set) timeout before returning a miss", + "type": "string", + "default": "20ms" + } + } + }, + "ttl": { + "description": "Default TTL", + "type": "string", + "default": "1000s" + }, + "default_cache_control": { + "description": "Set default value for Cache-Control response header if not set by upstream", + "type": "string", + "default": "no-store" } } + }, + "log_level": { + "type": "string", + "description": "Logs verbosity", + "default": "INFO", + "enum": [ + "DEBUG", + "INFO", + "WARN", + "DPANIC", + "PANIC", + "FATAL" + ] } } }, @@ -1032,6 +1234,9 @@ "boltdb": { "$ref": "#/definitions/BoltDB_J" }, + "kafka": { + "$ref": "#/definitions/KAFKA_J" + }, "amqp": { "description": "AMQP jobs driver", "type": "object", @@ -1135,7 +1340,8 @@ "beanstalk", "boltdb", "memory", - "nats" + "nats", + "kafka" ] } }, @@ -1208,6 +1414,141 @@ "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 + } + } + }, + "producer_options": { + "description": "Kafka producer options", + "type": "object", + "properties": { + "max_message_bytes": { + "type": "integer", + "default": 1000000 + }, + "required_acks": { + "description": "The level of acknowledgement reliability needed from the broker.", + "type": "integer", + "default": -1 + }, + "timeout": { + "description": "The maximum duration in seconds the broker will wait the receipt of the number of required_acks.", + "default": 10, + "type": "integer" + }, + "compression_codec": { + "type": "string", + "default": "none", + "enum": [ + "none", + "gzip", + "snappy", + "lz4", + "zstd" + ] + }, + "compression_level": { + "description": "The level of compression to use on messages.", + "type": "integer", + "default": null + }, + "idempotent": { + "description": "If enabled, the producer will ensure that exactly one copy of each message is written.", + "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 + }, + "max_fetch_message_size": { + "type": "integer", + "description": "The default number of message bytes to fetch from the broker in each request", + "default": 1000000 + }, + "session_timeout": { + "type": "integer", + "description": "The timeout in seconds used to detect consumer failures when using Kafka's group management facility.", + "default": 10 + }, + "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 + } + } + } + } + }, + { + "properties": { + "priority": { + "description": "Pipeline priority. If the job pushed to the pipeline has priority set to 0, it will inherit the pipeline's priority", + "type": "integer", + "default": 10 + }, "prefetch": { "description": "Number of job to prefetch from the driver", "type": "integer", @@ -1915,6 +2256,12 @@ }, "additionalProperties": false }, + "HashMapInt": { + "type": "object", + "additionalProperties": { + "type": "integer" + } + }, "NATS_J": { "description": "NATS jobs driver", "type": "object", @@ -1926,6 +2273,16 @@ } } }, + "KAFKA_J": { + "description": "Kafka jobs driver", + "type": "object", + "properties": { + "addr": { + "description": "Kafka server addresses", + "type": "array" + } + } + }, "BoltDB_J": { "description": "Boltdb jobs driver", "type": "object", |