A Web Framework built on top of Qt, using the simple and elegant approach of Catalyst (Perl) framework.
Qt's meta object system is what powers the core of Cutelyst, it allows for introspecting controller's methods signatures and generate matching actions that can be invoked later.
Don't trust us on being fast, check out the most comprehensive web framework benchmarks by TechEmpower http://www.techempower.com/benchmarks/
- Cross-platform
- Stable API/ABI - v3 tagged from master, v2 tags, v1 on v1.x.x branch (unmaintained)
- Pluggable Engines
- Cutelyst::Server - A cross-platform and fast server engine
- HTTP/1.1 - Pipelining and Keep-Alive
- HTTP/2 - Upgrade to H2, ALPN negotiation on HTTPS and direct H2C
- FastCGI - Pipelining and Keep-Alive
- uWSGI - Multiple protocols support (HTTP 1.0, FastCGI, uWSGI)
- Cutelyst::Server - A cross-platform and fast server engine
- WebSockets
- REST with ActionREST
- Plugin based views
- Cutelee (A Qt implementation of Django's template engine)
- Grantlee (A Qt implementation of Django's template engine)
- Clearsilver
- JSON
- Dispatcher
- Chained
- Path
- Plugins
- Session
- Authentication (with PBKDF2)
- Authorization with RoleACL
- StatusMessage
- Validator (to validate user input)
- CSRF protection
- Memcached
- UserAgent
- Asynchronous processing (just don't use local QEventLoops or it will eventually crash)
- Async SQL with ASql
- Upload parser
- JSON body as QJsonDocument when uploaded data is in JSON format
- C++17
- Chunked reponses (via QIODevice write API)
- Request profiling/stats
- Unit tested
- QtCreator integration
Get started with our Tutorial or check the API.
The Cutelyst project IRC channel is #cutelyst on freenode.
Or you can use the Mailing List
- CMake - for the build system (>= 3.9)
- Qt - the core library of this framework (>= 5.6)
- uWSGI - to receive and parse protocols requests (>= 1.9 recommended)
The library is under the LGPLv2+ and public header files, documentation and examples are under MIT license.