{"id":13526322,"url":"https://github.com/kuzzleio/kuzzle","last_synced_at":"2026-01-12T09:24:11.470Z","repository":{"id":36777615,"uuid":"41084349","full_name":"kuzzleio/kuzzle","owner":"kuzzleio","description":"Open-source Back-end, self-hostable \u0026 ready to use - Real-time, storage, advanced search - Web, Apps, Mobile, IoT -","archived":false,"fork":false,"pushed_at":"2026-01-02T15:30:05.000Z","size":35481,"stargazers_count":1626,"open_issues_count":0,"forks_count":136,"subscribers_count":40,"default_branch":"master","last_synced_at":"2026-01-08T08:53:43.391Z","etag":null,"topics":["api-server","backend","elasticsearch","hacktoberfest","iot","kuzzle","kuzzle-server","mqtt-server","node-js","persistent-data","real-time","redis","scalable","websockets"],"latest_commit_sha":null,"homepage":"https://kuzzle.io","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/kuzzleio.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":"CONTRIBUTING.md","funding":null,"license":"LICENSE.md","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":null}},"created_at":"2015-08-20T08:26:57.000Z","updated_at":"2026-01-07T05:16:22.000Z","dependencies_parsed_at":"2023-01-17T04:45:49.563Z","dependency_job_id":"b366d18f-2df9-46ec-a7bf-adb2cbb70eaa","html_url":"https://github.com/kuzzleio/kuzzle","commit_stats":{"total_commits":5499,"total_committers":72,"mean_commits":76.375,"dds":0.9074377159483542,"last_synced_commit":"4c56549681f1645d7d929258cc3a458b9e19eda0"},"previous_names":[],"tags_count":373,"template":false,"template_full_name":null,"purl":"pkg:github/kuzzleio/kuzzle","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuzzleio%2Fkuzzle","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuzzleio%2Fkuzzle/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuzzleio%2Fkuzzle/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuzzleio%2Fkuzzle/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/kuzzleio","download_url":"https://codeload.github.com/kuzzleio/kuzzle/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuzzleio%2Fkuzzle/sbom","scorecard":{"id":518546,"data":{"date":"2025-08-11","repo":{"name":"github.com/kuzzleio/kuzzle","commit":"2446edf6c2a1afff2a962b8d60fb5e8560b5467f"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":5.5,"checks":[{"name":"Maintained","score":10,"reason":"27 commit(s) and 1 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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Code-Review","score":2,"reason":"Found 2/10 approved changesets -- score normalized to 2","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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Info: jobLevel 'actions' permission set to 'read': .github/workflows/codeql.yml:16","Info: jobLevel 'contents' permission set to 'read': .github/workflows/codeql.yml:17","Warn: no topLevel permission defined: .github/workflows/codeql.yml:1","Warn: no topLevel permission defined: .github/workflows/release.workflow.yaml:1","Warn: no topLevel permission defined: .github/workflows/workflow-deployments.yml:1","Warn: no topLevel permission defined: .github/workflows/workflow.yaml: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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE.md:0","Info: FSF or OSI recognized license: Apache License 2.0: LICENSE.md:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Pinned-Dependencies","score":2,"reason":"dependency not pinned by hash detected -- score normalized to 2","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/codeql.yml:27: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/codeql.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/codeql.yml:30: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/codeql.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/codeql.yml:36: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/codeql.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/codeql.yml:39: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/codeql.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:22: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:28: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:31: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:34: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:40: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:54: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:60: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:63: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:66: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:79: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:92: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:98: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:102: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:105: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.workflow.yaml:111: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/release.workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow-deployments.yml:63: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow-deployments.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/workflow-deployments.yml:76: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow-deployments.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow-deployments.yml:95: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow-deployments.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow-deployments.yml:101: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow-deployments.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow.yaml:143: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow.yaml:149: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow.yaml:171: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow.yaml:177: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow.yaml:183: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow.yaml:41: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow.yaml:47: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow.yaml:67: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow.yaml:73: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow.yaml:95: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow.yaml:101: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow.yaml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/workflow.yaml:121: update your workflow using https://app.stepsecurity.io/secureworkflow/kuzzleio/kuzzle/workflow.yaml/master?enable=pin","Warn: containerImage not pinned by hash: docker/images/elasticsearch/Dockerfile:2","Warn: containerImage not pinned by hash: docker/images/kuzzle-runner/Dockerfile:2","Warn: containerImage not pinned by hash: docker/images/kuzzle/Dockerfile:3","Warn: containerImage not pinned by hash: docker/images/kuzzle/Dockerfile:22","Warn: containerImage not pinned by hash: docker/images/kuzzle/Dockerfile:34","Warn: downloadThenRun not pinned by hash: vagrant/setup.sh:5","Info:   0 out of  22 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of  13 third-party GitHubAction dependencies pinned","Info:   0 out of   1 downloadThenRun dependencies pinned","Info:   0 out of   5 containerImage dependencies pinned","Info:   7 out of   7 npmCommand 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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":-1,"reason":"internal error: error during branchesHandler.setup: internal error: githubv4.Query: Resource not accessible by integration","details":null,"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"Packaging","score":10,"reason":"packaging workflow detected","details":["Info: Project packages its releases by way of GitHub Actions.: .github/workflows/release.workflow.yaml:15"],"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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"SAST","score":10,"reason":"SAST tool is run on all commits","details":["Info: SAST configuration detected: CodeQL","Info: all commits (28) are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Vulnerabilities","score":4,"reason":"6 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-pxg6-pf52-xh8x","Warn: Project is vulnerable to: GHSA-fjxv-7rqg-78g4","Warn: Project is vulnerable to: GHSA-952p-6rrq-rcjv","Warn: Project is vulnerable to: GHSA-p8p7-x288-28g6","Warn: Project is vulnerable to: GHSA-52f5-9888-hmc6","Warn: Project is vulnerable to: GHSA-72xf-g2v4-qvf3"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-20T02:23:21.581Z","repository_id":36777615,"created_at":"2025-08-20T02:23:21.581Z","updated_at":"2025-08-20T02:23:21.581Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28337709,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-12T06:09:07.588Z","status":"ssl_error","status_checked_at":"2026-01-12T06:05:18.301Z","response_time":98,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5: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":["api-server","backend","elasticsearch","hacktoberfest","iot","kuzzle","kuzzle-server","mqtt-server","node-js","persistent-data","real-time","redis","scalable","websockets"],"created_at":"2024-08-01T06:01:27.998Z","updated_at":"2026-01-12T09:24:11.454Z","avatar_url":"https://github.com/kuzzleio.png","language":"JavaScript","readme":"\u003cp align=\"center\"\u003e\n  \u003cimg src=\"https://user-images.githubusercontent.com/7868838/103797784-32337580-5049-11eb-8917-3fcf4487644c.png\"/\u003e\n\u003c/p\u003e\n\u003cp align=\"center\"\u003e\n  \u003cimg alt=\"GitHub branch checks state\" src=\"https://img.shields.io/github/checks-status/kuzzleio/kuzzle/master\"\u003e\n  \u003cimg alt=\"Sonarcloud\" src=\"https://sonarcloud.io/api/project_badges/measure?project=kuzzleio_kuzzle\u0026metric=alert_status\u0026branch=master\"\u003e\n  \u003ca href=\"https://lgtm.com/projects/g/kuzzleio/kuzzle/context:javascript\"\u003e\n    \u003cimg src=\"https://img.shields.io/lgtm/grade/javascript/g/kuzzleio/kuzzle.svg?logo=lgtm\u0026logoWidth=18\" /\u003e\n  \u003c/a\u003e\n  \u003ca href=\"https://lgtm.com/projects/g/kuzzleio/kuzzle/alerts\"\u003e\n    \u003cimg src=\"https://img.shields.io/lgtm/alerts/g/kuzzleio/kuzzle.svg?logo=lgtm\u0026logoWidth=18\" /\u003e\n  \u003c/a\u003e\n  \u003ca href=\"https://github.com/kuzzleio/kuzzle/blob/master/LICENSE\"\u003e\n    \u003cimg alt=\"undefined\" src=\"https://img.shields.io/github/license/kuzzleio/kuzzle.svg?style=flat\"\u003e\n  \u003c/a\u003e\n\u003c/p\u003e\n\n## Why Kuzzle ?\n\nKuzzle is a [generic backend](https://docs.kuzzle.io/core/2/guides/introduction/general-purpose-backend/) offering **the basic building blocks common to every application**.\n\nRather than developing the same standard features over and over again each time you create a new application, Kuzzle proposes them off the shelf, allowing you to focus on building **high-level, high-value business functionalities**.\n\nKuzzle enables you to build modern web applications and complex IoT networks in no time.\n\n* **API First**: use a standardised multi-protocol API.\n* **Persisted Data**: store your data and perform advanced searches on it.\n* **Realtime Notifications**: use the pub/sub system or subscribe to database notifications.\n* **User Management**: login, logout and security rules are no more a burden.\n* **Extensible**: develop advanced business feature directly with the integrated framework.\n* **Client SDKs**: use our SDKs to accelerate the frontend development.\n\nLearn how Kuzzle will accelerate your developments :point_right: https://docs.kuzzle.io/core/2/guides/introduction/what-is-kuzzle/\n\n## Kuzzle in production\n\nKuzzle is production-proof, and can be [deployed anywhere](https://kuzzle.io/products/by-features/on-premises/).\n\nWith Kuzzle, it is possible to deploy applications that can serve tens of thousands of users with very good performances.\n\nCheck out our [support plans](https://kuzzle.io/pricing/).\n\n## Run Kuzzle\n\nThe easiest way to start a Kuzzle application is to use [Kourou](https://github.com/kuzzleio/kourou):\n\n```bash\nkourou app:scaffold playground\n\n 🚀 Kourou - Scaffolds a new Kuzzle application\n\ngeneric\n  ✔ Checking destination\n  ✔ Prepare temporary folder\n  ✔ Cloning template repository\n  ✔ Copying template files\n  ✔ Cleaning up\n\n [✔] Scaffolding complete!\n [✔] Use cd playground \u0026\u0026 docker compose up -d to start your Kuzzle stack.\n```\n\nThen you need to run Kuzzle services, Elasticsearch and Redis: `kourou app:start-services`\n\nFinally you can run your application inside Docker with `npm run docker:dev`\n\nKuzzle is now listening for requests on the port `7512`!\n\n## Use the framework\n\nYour first Kuzzle application is inside the `app.ts` file.\n\nFor example, you can add a new [API Controller](https://docs.kuzzle.io/core/2/guides/develop-on-kuzzle/api-controllers):\n\n```ts\nimport { Backend } from 'kuzzle';\n\nconst app = new Backend('playground');\n\napp.controller.register('greeting', {\n  actions: {\n    sayHello: {\n      handler: async request =\u003e `Hello, ${request.input.args.name}`\n    }\n  }\n});\n\napp.start()\n  .then(() =\u003e {\n    app.log.info('Application started');\n  })\n  .catch(console.error);\n```\n\nNow try to call your new API action by:\n - opening the generated URL in your browser: http://localhost:7512/_/greeting/say-hello?name=Yagmur\n - using Kourou: `npx kourou greeting:sayHello --arg name=Yagmur`\n\nLearn how to [Write an Application](https://docs.kuzzle.io/core/2/guides/getting-started/write-application/).\n\n### Useful links\n\n* [Getting Started with Kuzzle](https://docs.kuzzle.io/core/2/guides/getting-started/run-kuzzle/)\n* [API](https://docs.kuzzle.io/core/2/guides/main-concepts/api/)\n* [Data Storage](https://docs.kuzzle.io/core/2/guides/main-concepts/data-storage/)\n* [Querying](https://docs.kuzzle.io/core/2/guides/main-concepts/querying/)\n* [Permissions](https://docs.kuzzle.io/core/2/guides/main-concepts/permissions/)\n* [Authentication](https://docs.kuzzle.io/core/2/guides/main-concepts/authentication/)\n* [Realtime Engine](https://docs.kuzzle.io/core/2/guides/main-concepts/realtime-engine/)\n* [Discover our SDKs](https://docs.kuzzle.io/sdk/v2.html)\n* [Release Notes](https://github.com/kuzzleio/kuzzle/releases)\n\n## Get trained by the creators of Kuzzle :zap:\n\nTrain yourself and your teams to use Kuzzle to maximize its potential and accelerate the development of your projects.\nOur teams will be able to meet your needs in terms of expertise and multi-technology support for IoT, mobile/web, backend/frontend, devops.\n:point_right: [Get a quote](https://kuzzle.io/pricing/)\n\n\n## Contributing to Kuzzle\n\nYou're welcome to contribute to Kuzzle!\nFeel free to report issues, ask for features or even make pull requests!\n\nCheck our [contributing documentation](./CONTRIBUTING.md) to know about our coding and pull requests rules\n\n## Join our community\n\n* Follow us on [𝕏 (Twitter)](https://twitter.com/kuzzleio) to get latest news\n* Register to our monthly [newsletter](http://eepurl.com/bxRxpr) to get highlighed news\n* Visit our [blog](https://blog.kuzzle.io/) to be informed about what we are doing\n* Come chat with us on [Discord](http://join.discord.kuzzle.io)\n* Ask technical questions on [stack overflow](https://stackoverflow.com/search?q=kuzzle)\n\n## License\n\nKuzzle is published under [Apache 2 License](./LICENSE.md).\n","funding_links":[],"categories":["JavaScript","Api Server","Open-source and free products, based on Elasticsearch","Table of Contents","backend","Middleware","十、中间件"],"sub_categories":["Elastic Certified Engineer","Software","Android Things","3. 底层开发库"],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkuzzleio%2Fkuzzle","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fkuzzleio%2Fkuzzle","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkuzzleio%2Fkuzzle/lists"}