This is an automated email from the ASF dual-hosted git repository. young pushed a commit to branch master in repository https://gitbox.apache.org/repos/asf/apisix-website.git
The following commit(s) were added to refs/heads/master by this push: new 902a0521334 feat: add some plugins (#1432) 902a0521334 is described below commit 902a05213340269be0973e033a760b722becd38b Author: uniqie <48682080+uni...@users.noreply.github.com> AuthorDate: Thu Dec 8 21:51:45 2022 +0800 feat: add some plugins (#1432) Co-authored-by: Young <isk...@outlook.com> Fixes https://github.com/apache/apisix-website/issues/1379 --- website/static/data/plugins.json | 323 ++++++++++++++++++++++++++++----------- 1 file changed, 235 insertions(+), 88 deletions(-) diff --git a/website/static/data/plugins.json b/website/static/data/plugins.json index 532e5fd8cb1..a7673b35f9a 100644 --- a/website/static/data/plugins.json +++ b/website/static/data/plugins.json @@ -1,82 +1,180 @@ [ { - "groupName": "authentication", + "groupName": "General", "plugins": [ { - "name": "authz-casbin", - "description": "An authorization plugin based on Lua Casbin supporting various access control models" + "name": "batch-requests", + "description": "The batch-requests plugin accepts multiple requests, sends them from APISIX via HTTP pipelining, and returns an aggregated response to the client" }, { - "name": "authz-keycloak", - "description": "An authorization plugin to be used with the Keycloak Identity Server" + "name": "redirect", + "description": "The redirect Plugin can be used to configure redirects" }, { - "name": "basic-auth", - "description": "An authentication plugin that need to work with consumer to add Basic Authentication to a Service or a Route" + "name": "echo", + "description": "The echo Plugin is to help users understand how they can develop an APISIX Plugin" }, { - "name": "hmac-auth", - "description": "An authentication plugin that need to work with consumer to establish the integrity of incoming requests" + "name": "gzip", + "description": "The gzip Plugin dynamically sets the behavior of gzip in Nginx" }, { - "name": "jwt-auth", - "description": "An authentication plugin that need to work with consumer to securely authenticate a valid user requesting access" + "name": "real-ip", + "description": "The real-ip Plugin is used to dynamically change the client's IP address and port as seen by APISIX" }, { - "name": "key-auth", - "description": "An authentication plugin that need to work with consumer to add key authentication to your Services" + "name": "server-info", + "description": "The server-info Plugin periodically reports basic server information to etcd" }, { - "name": "openid-connect", - "description": "An authentication plugin that provides authentication and introspection capability to APISIX" + "name": "ext-plugin-pre-req", + "description": "The ext-plugin-pre-req Plugin is for running specific external Plugins in the Plugin Runner before executing the built-in Lua Plugins" + }, + { + "name": "ext-plugin-post-req", + "description": "ext-plugin-post-req differs from the ext-plugin-pre-req Plugin in that it runs after executing the built-in Lua Plugins and before proxying to the Upstream" + }, + { + "name": "ext-plugin-post-resp", + "description": "The ext-plugin-post-resp Plugin is for running specific external Plugins in the Plugin Runner before executing the built-in Lua Plugins" } ] }, { - "groupName": "security", + "groupName": "Transformation", "plugins": [ { - "name": "api-breaker", - "description": "The plugin implements API fuse functionality to help us protect our upstream business services" + "name": "response-rewrite", + "description": "The response-rewrite Plugin rewrites the content returned by the Upstream and APISIX" }, { - "name": "consumer-restriction", - "description": "The plugin makes corresponding access restrictions based on different objects selected" + "name": "proxy-rewrite", + "description": "The proxy-rewrite Plugin rewrites Upstream proxy information such as scheme, uri and host" + }, + { + "name": "grpc-transcode", + "description": "The grpc-transcode Plugin converts between HTTP and gRPC requests" + }, + { + "name": "grpc-web", + "description": "The grpc-web Plugin is a proxy Plugin that can process gRPC Web requests from JavaScript clients to a gRPC service" + }, + { + "name": "fault-injection", + "description": "The fault-injection Plugin can be used to test the resiliency of your application. This Plugin will be executed before the other configured Plugins" + }, + { + "name": "mocking", + "description": "The mocking Plugin is used for mocking an API. When executed, it returns random mock data in the format specified and the request is not forwarded to the Upstream" + } + ] + }, + { + "groupName": "Authentication", + "plugins": [ + { + "name": "key-auth", + "description": "An authentication plugin that need to work with consumer to add key authentication to your Services" + }, + { + "name": "jwt-auth", + "description": "An authentication plugin that need to work with consumer to securely authenticate a valid user requesting access" + }, + { + "name": "basic-auth", + "description": "An authentication plugin that need to work with consumer to add Basic Authentication to a Service or a Route" + }, + { + "name": "authz-keycloak", + "description": "An authorization plugin that can be used to add authentication with Keycloak Identity Server" + }, + { + "name": "authz-casdoor", + "description": "An authorization plugin that can be used to add centralized authentication with Casdoor" }, + { + "name": "wolf-rbac", + "description": "An authorization plugin providing a role-based access control system with wolf to a Route or a Service" + }, + { + "name": "openid-connect", + "description": "An authentication plugin that provides authentication and introspection capability to APISIX" + }, + { + "name": "cas-auth", + "description": "An authorization plugin can be used to access CAS (Central Authentication Service 2.0) IdP (Identity Provider) to do authentication, from the SP (service provider) perspective" + }, + { + "name": "hmac-auth", + "description": "An authentication plugin that need to work with consumer to establish the integrity of incoming requests" + }, + { + "name": "authz-casbin", + "description": "An authorization plugin based on Lua Casbin supporting various access control models" + }, + { + "name": "ldap-auth", + "description": "An authorization plugin can be used to add LDAP authentication to a Route or a Service" + }, + { + "name": "opa", + "description": "An authorization plugin can be used to integrate with Open Policy Agente" + }, + { + "name": "forward-auth", + "description": "The forward-auth Plugin implements a classic external authentication model" + } + ] + }, + { + "groupName": "Security", + "plugins": [ { "name": "cors", "description": "The plugin can help you enable CORS easily" }, { - "name": "fault-injection", - "description": "The plugin provides the ability to deliberately cause a service to fail, in order to test failure in a complex distributed solution" + "name": "uri-blocker", + "description": "The plugin intercepts user requests with a set of block_rules" }, { "name": "ip-restriction", - "description": "The ip-restriction can restrict access to a Service or a Route by either whitelisting or blacklisting IP addresses" + "description": "The plugin allows you to restrict access to a Service or a Route by either whitelisting or blacklisting IP addresses" }, { - "name": "referer-restriction", - "description": "The referer-restriction can restrict access to a Service or a Route by whitelisting request header Referrers" + "name": "ip-restriction", + "description": "The plugin allows you to restrict access to a Service or a Route by either whitelisting or blacklisting IP addresses" }, { - "name": "request-validation", - "description": "The request-validation plugin validates the requests before forwarding to an upstream service" + "name": "ua-restriction", + "description": "The plugin allows you to restrict access to a Route or Service based on the User-Agent header with an allowlist and a denylist" }, { - "name": "uri-blocker", - "description": "The plugin helps to intercept user requests" + "name": "referer-restriction", + "description": "The plugin can be used to restrict access to a Service or a Route by whitelisting/blacklisting the Referer request header" + }, + { + "name": "consumer-restriction", + "description": "The plugin makes corresponding access restrictions based on different objects selected" }, { "name": "CSRF", "description": "Based on the Double Submit Cookie way, protect your API from CSRF attacks", "beta": true + }, + { + "name": "public-api", + "description": "The public-api is used for exposing an API endpoint through a general HTTP API router" } ] }, { - "groupName": "Traffic Control", + "groupName": "Traffic", "plugins": [ + { + "name": "limit-req", + "description": "The plugin limits request rate using the eaky bucket method" + }, { "name": "limit-conn", "description": "The plugin Limits request concurrency" @@ -86,25 +184,36 @@ "description": "The plugin Limits request rate by a fixed number of requests in a given time window" }, { - "name": "limit-req", - "description": "The plugin limits request rate using the eaky bucket method" + "name": "proxy-cache", + "description": "The proxy-cache Plugin can be used to cache the response from the Upstream" + }, + { + "name": "request-validation", + "description": "The request-validation Plugin can be used to validate the requests before forwarding them to an Upstream service" + }, + { + "name": "proxy-mirror", + "description": "The proxy-mirror Plugin can be used to mirror client requests" + }, + { + "name": "api-breaker", + "description": "The api-breaker Plugin implements circuit breaker functionality to protect Upstream services" }, { "name": "traffic-split", "description": "The traffic split plugin allows users to incrementally direct percentages of traffic between various upstreams" - } - ] - }, - { - "groupName": "Serverless", - "plugins": [ + }, + { + "name": "request-id", + "description": "The request-id Plugin adds a unique ID to each request proxied through APISIX" + }, { - "name": "serverless-pre-function", - "description": "The serverless-pre-function runs at the beginning of the specified phase" + "name": "proxy-control", + "description": "The proxy-control Plugin dynamically controls the behavior of the NGINX proxy" }, { - "name": "serverless-post-function", - "description": "The serverless-post-function runs at the end of the specified phase" + "name": "client-control", + "description": "The client-control Plugin can be used to dynamically control the behavior of NGINX to handle a client request, by setting the max size of the request body" } ] }, @@ -112,104 +221,142 @@ "groupName": "Observability", "plugins": [ { - "name": "error-log-logger", - "description": "Error-log-logger is a plugin which pushes the log data of APISIX's error.log to TCP servers" + "name": "zipkin", + "description": "Zipkin is a OpenTracing plugin" }, { - "name": "http-logger", - "description": "Http-logger is a plugin which push Log data requests to HTTP/HTTPS servers" + "name": "skywalking", + "description": "Skywalking uses its native Nginx LUA tracer to provide tracing, topology analysis, and metrics from service and URI perspective" }, { - "name": "kafka-logger", - "description": "Kafka-logger is a plugin which works as a Kafka client driver for the ngx_lua nginx module" + "name": "opentelemetry", + "description": "The opentelemetry Plugin can be used to report tracing data according to the OpenTelemetry specification" }, { "name": "prometheus", "description": "The plugin exposes metrics in Prometheus Exposition format" }, { - "name": "request-id", - "description": "The plugin adds a unique ID (UUID) to each request proxied through APISIX" + "name": "node-status", + "description": "The node-status Plugin can be used get the status of requests to APISIX by exposing an API endpoint" }, { - "name": "skywalking", - "description": "Skywalking uses its native Nginx LUA tracer to provide tracing, topology analysis, and metrics from service and URI perspective" + "name": "datadog", + "description": "Datadog is a monitoring plugin built into Apache APISIX to push metrics of different services into DatadogHQ via a locally run Datadog agent." }, { - "name": "sls-logger", - "description": "Sls-logger pushes Log data requests to ali cloud Log Server with RF5424" + "name": "http-logger", + "description": "Http-logger is a plugin which push Log data requests to HTTP/HTTPS servers" }, { - "name": "syslog", - "description": "Sys pushes Log data requests to Syslog" + "name": "skywalking-loggerr", + "description": "The skywalking-logger Plugin can be used to push access log data to SkyWalking OAP server of HTTP" }, { "name": "tcp-logger", "description": "Tcp-logger pushes Log data requests to TCP servers" }, + { + "name": "kafka-logger", + "description": "Kafka-logger is a plugin which works as a Kafka client driver for the ngx_lua nginx module" + }, + { + "name": "rocketmq-logger", + "description": "The rocketmq-logger Plugin provides the ability to push logs as JSON objects to your RocketMQ clusters" + }, { "name": "udp-logger", "description": "Udp-logger pushes Log data requests to UDP servers" }, { - "name": "zipkin", - "description": "Zipkin is a OpenTracing plugin" + "name": "clickhouse-logger", + "description": "The clickhouse-logger Plugin is used to push logs to ClickHouse database" }, { - "name": "datadog", - "description": "Datadog is a monitoring plugin built into Apache APISIX to push metrics of different services into DatadogHQ via a locally run Datadog agent." + "name": "syslog", + "description": "Sys pushes Log data requests to Syslog" + }, + { + "name": "log-rotate", + "description": "The log-rotate Plugin is used to keep rotating access and error log files in the log directory at regular intervals" + }, + { + "name": "error-log-logger", + "description": "Error-log-logger is a plugin which pushes the log data of APISIX's error.log to TCP servers" + }, + { + "name": "sls-logger", + "description": "Sls-logger pushes Log data requests to ali cloud Log Server with RF5424" }, { "name": "google-cloud-logging", - "description": "google-cloud-logging plugin is used to send the access log of Apache APISIX to the Google Cloud Logging Service." + "description": "google-cloud-logging plugin is used to send the access log of Apache APISIX to the Google Cloud Logging Service" + }, + { + "name": "splunk-hec-logging", + "description": "The splunk-hec-logging Plugin is used to forward logs to Splunk HTTP Event Collector (HEC) for analysis and storage" + }, + { + "name": "file-logger", + "description": "The file-logger Plugin is used to push log streams to a specific location" + }, + { + "name": "loggly", + "description": "The loggly Plugin is used to forward logs to SolarWinds Loggly for analysis and storage" + }, + { + "name": "elasticsearch-logger", + "description": "The elasticsearch-logger Plugin is used to forward logs to Elasticsearch for analysis and storage" + }, + { + "name": "tencent-cloud-cls", + "description": "The tencent-cloud-cls Plugin uses TencentCloud CLSAPI to forward APISIX logs to your topic" } ] }, { - "groupName": "other", + "groupName": "Serverless", "plugins": [ { - "name": "batch-requests", - "description": "Batch-requests accepts multiple request and send them from apisix via http pipeline" - }, - { - "name": "grpc-transcode", - "description": "Grpc-transcoding involves mapping HTTP/JSON requests and their parameters to gRPC methods and their parameters and return types" + "name": "serverless", + "description": "There are two serverless Plugins in APISIX: serverless-pre-function and serverless-post-function." }, { - "name": "proxy-cache", - "description": "The proxy-cache plugin provides the ability to cache upstream response data and can be used with other plugins" + "name": "azure-functions", + "description": "The azure-functions Plugin is used to integrate APISIX with Azure Serverless Function as a dynamic upstream to proxy all requests for a particular URI to the Microsoft Azure Cloud" }, { - "name": "proxy-mirror", - "description": "The proxy-mirror plugin provides the ability to mirror client requests" + "name": "openwhisk", + "description": "The openwhisk Plugin is used to integrate APISIX with Apache OpenWhisk serverless platfor" }, { - "name": "proxy-rewrite", - "description": "The proxy-rewrite is an upstream proxy information rewriting plugin" + "name": "aws-lambda", + "description": "The aws-lambda Plugin is used for integrating APISIX with AWS Lambda as a dynamic upstream to proxy all requests for a particular URI to the AWS Cloud" }, { - "name": "response-rewrite", - "description": "Response-rewrite rewrites the content returned by the upstream as well as Apache APISIX itself" + "name": "workflow", + "description": "The workflow plugin is used to introduce lua-resty-expr to provide complex traffic control features" }, { - "name": "wolf-rbac", - "description": "Wolf-rbac is an authentication and authorization (rbac) plugin where the rbac feature is provided by wolf" - }, + "name": "openfunction", + "description": "The openfunction Plugin is used to integrate APISIX with CNCF OpenFunction serverless platform" + } + ] + }, + { + "groupName": "Other protocols", + "plugins": [ { - "name": "client-control", - "description": "The client-control plugin dynamically controls the behavior of Nginx to handle the client request", - "useDefaultIcon": true + "name": "dubbo-proxy", + "description": "The dubbo-proxy Plugin allows you to proxy HTTP requests to Apache Dubbo" }, { - "name": "ext-plugin-pre-req", - "description": "The ext-plugin-pre-req runs specific external plugins in the plugin runner, before executing most of the builtin Lua plugins", - "useDefaultIcon": true + "name": "mqtt-proxye", + "description": "The mqtt-proxy Plugin is used for dynamic load balancing with client_id of MQTT. It only works in stream mode" }, { - "name": "ext-plugin-post-req", - "description": "The ext-plugin-post-req runs after executing builtin Lua plugins and before proxying to the upstream", - "useDefaultIcon": true + "name": "kafka-proxy", + "description": "The kafka-proxy plugin can be used to configure advanced parameters for the kafka upstream of Apache APISIX, such as SASL authentication" } ] }