Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kuzzleio/kuzzle
Open-source Back-end, self-hostable & ready to use - Real-time, storage, advanced search - Web, Apps, Mobile, IoT -
https://github.com/kuzzleio/kuzzle
api-server backend elasticsearch hacktoberfest iot kuzzle kuzzle-server mqtt-server node-js persistent-data real-time redis scalable websockets
Last synced: 24 days ago
JSON representation
Open-source Back-end, self-hostable & ready to use - Real-time, storage, advanced search - Web, Apps, Mobile, IoT -
- Host: GitHub
- URL: https://github.com/kuzzleio/kuzzle
- Owner: kuzzleio
- License: apache-2.0
- Created: 2015-08-20T08:26:57.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2024-05-22T11:33:56.000Z (6 months ago)
- Last Synced: 2024-05-22T16:36:52.394Z (6 months ago)
- Topics: api-server, backend, elasticsearch, hacktoberfest, iot, kuzzle, kuzzle-server, mqtt-server, node-js, persistent-data, real-time, redis, scalable, websockets
- Language: JavaScript
- Homepage: https://kuzzle.io
- Size: 32.8 MB
- Stars: 1,379
- Watchers: 44
- Forks: 123
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-elasticsearch - Kuzzle - An open-source backend with advanced real-time features for Web, Mobile and IoT that uses ElasticSearch as a database. ([Website](https://kuzzle.io/)) (Open-source and free products, based on Elasticsearch / Elastic Certified Engineer)
- elasticsearch-collection - Kuzzle - An open-source backend with advanced real-time features for Web, Mobile and IoT that uses ElasticSearch as a database. ([Website](https://kuzzle.io/)) (Open-source and free products, based on Elasticsearch / Elastic Certified Engineer)
- awesome-starred - kuzzleio/kuzzle - Open-source Back-end, self-hostable & ready to use - Real-time, storage, advanced search - Web, Apps, Mobile, IoT - (iot)
README
## Why Kuzzle ?
Kuzzle is a [generic backend](https://docs.kuzzle.io/core/2/guides/introduction/general-purpose-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 :point_right: https://docs.kuzzle.io/core/2/guides/introduction/what-is-kuzzle/
## Kuzzle in production
Kuzzle is production-proof, and can be [deployed anywhere](https://kuzzle.io/products/by-features/on-premises/).
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](https://kuzzle.io/pricing/).
## Run Kuzzle
The easiest way to start a Kuzzle application is to use [Kourou](https://github.com/kuzzleio/kourou):
```bash
kourou app:scaffold playground🚀 Kourou - Scaffolds a new Kuzzle application
generic
✔ Checking destination
✔ Prepare temporary folder
✔ Cloning template repository
✔ Copying template files
✔ Cleaning up[✔] Scaffolding complete!
[✔] Use cd playground && docker compose up -d to start your Kuzzle stack.
```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 docker:dev`
Kuzzle is now listening for requests on the port `7512`!
## Use the framework
Your first Kuzzle application is inside the `app.ts` file.
For example, you can add a new [API Controller](https://docs.kuzzle.io/core/2/guides/develop-on-kuzzle/api-controllers):
```ts
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](https://docs.kuzzle.io/core/2/guides/getting-started/write-application/).
### Useful links
* [Getting Started with Kuzzle](https://docs.kuzzle.io/core/2/guides/getting-started/run-kuzzle/)
* [API](https://docs.kuzzle.io/core/2/guides/main-concepts/api/)
* [Data Storage](https://docs.kuzzle.io/core/2/guides/main-concepts/data-storage/)
* [Querying](https://docs.kuzzle.io/core/2/guides/main-concepts/querying/)
* [Permissions](https://docs.kuzzle.io/core/2/guides/main-concepts/permissions/)
* [Authentication](https://docs.kuzzle.io/core/2/guides/main-concepts/authentication/)
* [Realtime Engine](https://docs.kuzzle.io/core/2/guides/main-concepts/realtime-engine/)
* [Discover our SDKs](https://docs.kuzzle.io/sdk/v2.html)
* [Release Notes](https://github.com/kuzzleio/kuzzle/releases)## Get trained by the creators of Kuzzle :zap:
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.
:point_right: [Get a quote](https://kuzzle.io/pricing/)## Contributing to Kuzzle
You're welcome to contribute to Kuzzle!
Feel free to report issues, ask for features or even make pull requests!Check our [contributing documentation](./CONTRIBUTING.md) to know about our coding and pull requests rules
## Join our community
* Follow us on [𝕏 (Twitter)](https://twitter.com/kuzzleio) to get latest news
* Register to our monthly [newsletter](http://eepurl.com/bxRxpr) to get highlighed news
* Visit our [blog](https://blog.kuzzle.io/) to be informed about what we are doing
* Come chat with us on [Discord](http://join.discord.kuzzle.io)
* Ask technical questions on [stack overflow](https://stackoverflow.com/search?q=kuzzle)## License
Kuzzle is published under [Apache 2 License](./LICENSE.md).