{"id":13509011,"url":"https://github.com/frain-dev/convoy","last_synced_at":"2026-02-24T13:06:17.415Z","repository":{"id":37077380,"uuid":"358943289","full_name":"frain-dev/convoy","owner":"frain-dev","description":"The Cloud Native Webhooks Gateway","archived":false,"fork":false,"pushed_at":"2026-02-07T19:01:55.000Z","size":82095,"stargazers_count":2754,"open_issues_count":62,"forks_count":169,"subscribers_count":22,"default_branch":"main","last_synced_at":"2026-02-07T20:15:08.960Z","etag":null,"topics":["angular","api-gateway","automation","cli","cloud","convoy","developer-tools","devtools","gateway","gateways","golang","incoming-webhooks","infrastructure","outgoing-webhooks","webhook-gateway","webhook-service","webhooks","webhooks-server"],"latest_commit_sha":null,"homepage":"https://getconvoy.io","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"other","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/frain-dev.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":"CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":"CLA.md"}},"created_at":"2021-04-17T17:37:17.000Z","updated_at":"2026-02-05T02:45:25.000Z","dependencies_parsed_at":"2025-11-29T14:13:02.505Z","dependency_job_id":"6cec8e62-8576-4c97-91cd-6727fee2eaac","html_url":"https://github.com/frain-dev/convoy","commit_stats":{"total_commits":1267,"total_committers":30,"mean_commits":"42.233333333333334","dds":0.7947908445146015,"last_synced_commit":"46a143d78cea701fd60ed78b006a8fd15298b6e7"},"previous_names":["hookstack/hookstack","hookcamp/hookcamp"],"tags_count":211,"template":false,"template_full_name":null,"purl":"pkg:github/frain-dev/convoy","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/frain-dev%2Fconvoy","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/frain-dev%2Fconvoy/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/frain-dev%2Fconvoy/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/frain-dev%2Fconvoy/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/frain-dev","download_url":"https://codeload.github.com/frain-dev/convoy/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/frain-dev%2Fconvoy/sbom","scorecard":{"id":10443,"data":{"date":"2025-08-04","repo":{"name":"github.com/frain-dev/convoy","commit":"0bbbe7fb0688e198cba2d8f99e5c0fb18e480302"},"scorecard":{"version":"v5.2.1-28-gc1d103a9","commit":"c1d103a9bb9f635ec7260bf9aa0699466fa4be0e"},"score":5,"checks":[{"name":"Code-Review","score":3,"reason":"Found 10/30 approved changesets -- score normalized to 3","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#code-review"}},{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#dangerous-workflow"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#cii-best-practices"}},{"name":"Maintained","score":10,"reason":"18 commit(s) and 2 issue activity found in the last 90 days -- score normalized to 10","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#maintained"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/build-image.yml:1","Warn: no topLevel permission defined: .github/workflows/build-rolling-image.yml:1","Warn: no topLevel permission defined: .github/workflows/docs.yml:1","Warn: no topLevel permission defined: .github/workflows/go.yml:1","Warn: no topLevel permission defined: .github/workflows/linter.yml:1","Warn: no topLevel permission defined: .github/workflows/load-test.yml:1","Warn: no topLevel permission defined: .github/workflows/release.yml:1","Info: no jobLevel write permissions found"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#token-permissions"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#binary-artifacts"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#security-policy"}},{"name":"License","score":9,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Warn: project license file does not contain an FSF or OSI license."],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#license"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#fuzzing"}},{"name":"Signed-Releases","score":0,"reason":"Project has not signed or included provenance with any releases.","details":["Warn: release artifact v25.7.1 not signed: https://api.github.com/repos/frain-dev/convoy/releases/234951062","Warn: release artifact v25.6.8 not signed: https://api.github.com/repos/frain-dev/convoy/releases/231370766","Warn: release artifact v25.6.7 not signed: https://api.github.com/repos/frain-dev/convoy/releases/228593767","Warn: release artifact v25.6.6 not signed: https://api.github.com/repos/frain-dev/convoy/releases/228170964","Warn: release artifact v25.6.5 not signed: https://api.github.com/repos/frain-dev/convoy/releases/228093242","Warn: release artifact v25.7.1 does not have provenance: https://api.github.com/repos/frain-dev/convoy/releases/234951062","Warn: release artifact v25.6.8 does not have provenance: https://api.github.com/repos/frain-dev/convoy/releases/231370766","Warn: release artifact v25.6.7 does not have provenance: https://api.github.com/repos/frain-dev/convoy/releases/228593767","Warn: release artifact v25.6.6 does not have provenance: https://api.github.com/repos/frain-dev/convoy/releases/228170964","Warn: release artifact v25.6.5 does not have provenance: https://api.github.com/repos/frain-dev/convoy/releases/228093242"],"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":6,"reason":"branch protection is not maximal on development and all release branches","details":["Info: 'allow deletion' disabled on branch 'main'","Info: 'force pushes' disabled on branch 'main'","Warn: 'branch protection settings apply to administrators' is disabled on branch 'main'","Warn: required approving review count is 1 on branch 'main'","Warn: codeowners review is not required on branch 'main'","Warn: no status checks found to merge onto branch 'main'","Info: PRs are required in order to make changes on branch 'main'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#branch-protection"}},{"name":"Pinned-Dependencies","score":0,"reason":"dependency not pinned by hash detected -- score normalized to 0","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-image.yml:50: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-image.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-image.yml:55: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-image.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-image.yml:61: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-image.yml:79: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-image.yml:82: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-image.yml:85: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-image.yml:91: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-image.yml:107: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-image.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-image.yml:24: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-image.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-image.yml:29: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-image.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:25: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:46: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:54: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:60: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:78: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:81: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:84: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:91: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:94: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:113: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:119: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:122: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:125: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-rolling-image.yml:132: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/build-rolling-image.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/docs.yml:13: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/docs.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/docs.yml:16: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/docs.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/go.yml:33: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/go.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/go.yml:43: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/go.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/go.yml:48: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/go.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/go.yml:55: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/go.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/linter.yml:11: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/linter.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/linter.yml:13: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/linter.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/load-test.yml:23: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/load-test.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/load-test.yml:26: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/load-test.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:19: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:24: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:36: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:38: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/release.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:44: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:47: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/release.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:58: update your workflow using https://app.stepsecurity.io/secureworkflow/frain-dev/convoy/release.yml/main?enable=pin","Warn: containerImage not pinned by hash: Dockerfile.dev:2","Warn: containerImage not pinned by hash: Dockerfile.dev:9","Warn: containerImage not pinned by hash: Dockerfile.dev:27: pin your Docker image by updating alpine:3.16.2 to alpine:3.16.2@sha256:65a2763f593ae85fab3b5406dc9e80f744ec5b449f269b699b5efd37a07ad32e","Warn: containerImage not pinned by hash: release.Dockerfile:1: pin your Docker image by updating alpine:3.20.2 to alpine:3.20.2@sha256:0a4eaa0eecf5f8c050e5bba433f58c052be7587ee8af3e8b3910ef9ab5fbe9f5","Warn: containerImage not pinned by hash: slim.Dockerfile:1: pin your Docker image by updating gcr.io/distroless/base to gcr.io/distroless/base@sha256:1951bedd9ab20dd71a5ab11b3f5a624863d7af4109f299d62289928b9e311d5d","Warn: npmCommand not pinned by hash: Dockerfile.dev:6","Warn: npmCommand not pinned by hash: scripts/build.sh:23","Warn: npmCommand not pinned by hash: scripts/ui.sh:15","Warn: pipCommand not pinned by hash: .github/workflows/release.yml:55","Info:   0 out of  22 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of  20 third-party GitHubAction dependencies pinned","Info:   0 out of   5 containerImage dependencies pinned","Info:   0 out of   3 npmCommand dependencies pinned","Info:   1 out of   1 goCommand dependencies pinned","Info:   0 out of   1 pipCommand dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#pinned-dependencies"}},{"name":"Packaging","score":10,"reason":"packaging workflow detected","details":["Info: Project packages its releases by way of GitHub Actions.: .github/workflows/build-image.yml:36"],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#packaging"}},{"name":"SAST","score":6,"reason":"SAST tool is not run on all commits -- score normalized to 6","details":["Warn: 15 commits out of 25 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#sast"}},{"name":"Vulnerabilities","score":6,"reason":"4 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GO-2022-0635","Warn: Project is vulnerable to: GO-2022-0646","Warn: Project is vulnerable to: GO-2025-3770 / GHSA-vrw8-fxc6-2r93","Warn: Project is vulnerable to: GO-2025-3787 / GHSA-fv92-fjc5-jj9h"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-14T14:26:23.363Z","repository_id":37077380,"created_at":"2025-08-14T14:26:23.363Z","updated_at":"2025-08-14T14:26:23.363Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":29384992,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-02-12T22:07:52.078Z","status":"ssl_error","status_checked_at":"2026-02-12T22:07:49.026Z","response_time":55,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["angular","api-gateway","automation","cli","cloud","convoy","developer-tools","devtools","gateway","gateways","golang","incoming-webhooks","infrastructure","outgoing-webhooks","webhook-gateway","webhook-service","webhooks","webhooks-server"],"created_at":"2024-08-01T02:01:01.741Z","updated_at":"2026-02-24T13:06:17.403Z","avatar_url":"https://github.com/frain-dev.png","language":"Go","readme":"# ![convoy image](./convoy_logo.png)\n\n[![golangci-lint](https://github.com/frain-dev/convoy/actions/workflows/linter.yml/badge.svg)](https://github.com/frain-dev/convoy/actions/workflows/linter.yml)\n[![Build and run all tests](https://github.com/frain-dev/convoy/actions/workflows/integration-tests.yml/badge.svg)](https://github.com/frain-dev/convoy/actions/workflows/integration-tests.yml)\n\n- Website: https://getconvoy.io\n- Forum: [Convoy Community](https://community.getconvoy.io)\n- Documentation: [docs.getconvoy.io](https://docs.getconvoy.io)\n- Deploy:\n  [Install Convoy](https://docs.getconvoy.io/deployment/install-convoy/docker)\n- Slack:\n  [Join the Community](https://join.slack.com/t/convoy-community/shared_invite/zt-xiuuoj0m-yPp~ylfYMCV9s038QL0IUQ)\n\n[Convoy](https://getconvoy.io) is an open source high-performance webhooks\ngateway used to securely ingest, persist, debug, deliver and manage millions of\nevents reliably with rich features such as retries, rate limiting, static ips,\ncircuit breaking, rolling secrets and more.\n\nConvoy provides several key features:\n\n- **Webhooks Gateway:** As a webhooks gateway, Convoy lives at the edge of your\n  network to stream webhooks from your microservices, and send them out to your\n  users as well as receive webhooks from your providers and route them to the\n  required services. With this your internal systems are never exposed to the\n  public internet.\n\n- **Scalability:** Convoy acts as a dedicated message queue for webhooks, and\n  was designed to be horizontally scalable. It includes several components like\n  the `api server`, `workers`, `scheduler`, and `socket server` which can be\n  scaled independently to fit the need.\n\n- **Security:** Convoy ships with several security features for webhooks, such\n  as payload signing to ensure message integrity, bearer token authentication\n  for authenticated webhook endpoints, and static ips for network environments\n  with strict firewall rules.\n\n- **Fan Out:** Convoy is able to route an event to multiple endpoints based on\n  the event type or payload structure.\n\n- **Rate Limiting:** While Convoy is able to ingest events at a massive rate, it\n  throttles the delivery of these events to the endpoints at a configurable rate\n  per endpoint.\n\n- **Retries \u0026 Batch Retries:** Convoy supports two retry algorithms; constant\n  time and exponential backoff with jitter. Where automatic retries are not\n  sufficient, convoy provides batch retries for endpoints are consecutively\n  failed to process retried events.\n\n- **Customer-Facing Dashboards:** Convoy allows you to generate customer facing\n  webhooks dashboard to embed into your applications using an iframe. On this\n  dashboard, users can debug webhooks, retry events, add endpoints, and\n  configure each endpoint's subscription.\n\n- **Endpoint Failure Notifications:** When endpoints consecutively fails to\n  process events, convoy disables the endpoint and sends out a notification. Two\n  types of notifications are supported: Email and Slack Notifications.\n\n## Installation\n\n- [Docker](https://docs.getconvoy.io/deployment/install-convoy/docker)\n- [Kubernetes with Helm](https://docs.getconvoy.io/deployment/install-convoy/kubernetes)\n\n## Contributing\n\nThank you for your interest in contributing! Please refer to\n[CONTRIBUTING.md](https://github.com/frain-dev/convoy/blob/main/CONTRIBUTING.md)\nfor guidance. For contributions to the Convoy dashboard, please refer to the\n[web/ui](https://github.com/frain-dev/convoy/tree/main/web/ui) directory.\n\n## License\n\n[Elastic License v2.0](https://github.com/frain-dev/convoy/blob/main/LICENSE)\n","funding_links":[],"categories":["Go","\u003ca name=\"Go\"\u003e\u003c/a\u003eGo","cloud"],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ffrain-dev%2Fconvoy","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Ffrain-dev%2Fconvoy","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ffrain-dev%2Fconvoy/lists"}