Kuzzle is a generic backend offering the basic building blocks common to every application.
Rather 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.
Kuzzle enables you to build modern web applications and complex IoT networks in no time.
- API First: use a standardised multi-protocol API.
- Persisted Data: store your data and perform advanced searches on it.
- Realtime Notifications: use the pub/sub system or subscribe to database notifications.
- User Management: login, logout and security rules are no more a burden.
- Extensible: develop advanced business feature directly with the integrated framework.
- Client SDKs: use our SDKs to accelerate the frontend development.
Learn how Kuzzle will accelerate your developments 👉 https://docs.kuzzle.io/core/2/guides/introduction/what-is-kuzzle/
Kuzzle is production-proof, and can be deployed anywhere.
With Kuzzle, it is possible to deploy applications that can serve tens of thousands of users with very good performances.
Check out our support plans.
The easiest way to start a Kuzzle application is to use Kourou:
npx kourou app:scaffold playground
🚀 Kourou - Scaffolds a new Kuzzle application
✔ Creating playground/ directory
✔ Creating and rendering application files
✔ Installing latest Kuzzle version via NPM and Docker (this can take some time)
[✔] Scaffolding complete! Use "npm run dev:docker" to run your application
Then you need to run Kuzzle services, Elasticsearch and Redis: kourou app:start-services
Finally you can run your application inside Docker with npm run dev:docker
Kuzzle is now listening for requests on the port 7512
!
Your first Kuzzle application is inside the app.ts
file.
For example, you can add a new API Controller:
import { Backend } from 'kuzzle';
const app = new Backend('playground');
app.controller.register('greeting', {
actions: {
sayHello: {
handler: async request => `Hello, ${request.input.args.name}`
}
}
});
app.start()
.then(() => {
app.log.info('Application started');
})
.catch(console.error);
Now try to call your new API action by:
- opening the generated URL in your browser: http://localhost:7512/_/greeting/say-hello?name=Yagmur
- using Kourou:
npx kourou greeting:sayHello --arg name=Yagmur
Learn how to Write an Application.
- Getting Started with Kuzzle
- API
- Data Storage
- Querying
- Permissions
- Authentication
- Realtime Engine
- Discover our SDKs
- Release Notes
Train yourself and your teams to use Kuzzle to maximize its potential and accelerate the development of your projects.
Our teams will be able to meet your needs in terms of expertise and multi-technology support for IoT, mobile/web, backend/frontend, devops.
👉 Get a quote
You can consult the public roadmap on Trello. Come and vote for the features you need!
👉 Kuzzle Public Roadmap
You're welcome to contribute to Kuzzle! Feel free to report issues, ask for features or even make pull requests!
Check our contributing documentation to know about our coding and pull requests rules
- Follow us on twitter to get latest news
- Register to our monthly newsletter to get highlighed news
- Visit our blog to be informed about what we are doing
- Come chat with us on Discord
- Ask technical questions on stack overflow
- Check out our public roadmap and vote for the upcoming features
Kuzzle is published under Apache 2 License.