tufao
0.8.1
An asynchronous web framework for C++ built on top of Qt
|
Tufão is a web framework for C++ that makes use of Qt's object communication system (signals & slots). It features:
It uses Ryan Dahl's HTTP parser to provide good performance.
In this section, I assume that you already have installed Tufão libraries and tools (tufao-routes-editor, QtCreator's plugin, ...).
First of all, you must open QtCreator and go to the new project dialog, you may be able to select Tufão Web Server project from the list of projects in the Tufão category.
Go through the pages of the project wizard, selecting the application template. At the end, you'll get an unconfigured qmake-based application. Under QtCreator's interface, go to the projects mode and choose a configuration. If you don't configure the project, QtCreator won't be able to compile your project.
You may have a main.cpp file with a code like this:
A main file with 46 lines of code. It's a bunch of code, but if you delete the comments and includes, you'll have only 26 lines remaining. It's possible to create Tufão applications with fewer yet lines, but I'll use this code to explain important Tufão features. They'll prove their value.
Tufão provides a web framework and has its own HTTP server (based on Ryan Dahl's HTTP parser). This design give you greater control over the applications and can really boost its performance. But, as uncle Ben may have told you:
With great power comes great responsibility
This may sound scary to you at first, but don't worry, the Tufão team will do their best to make this responsibility easier to assume, with each realease. But you need to promisse that you'll use Tufão facilities and read the documentation.
To use the Tufão HTTP server, we instantiate, as show in the line 16, a Tufao::HttpServer, put it to listen on port 8080, as show in the line 42, and start a event loop, as show in the line 45. This server will expose all we need to this introduction.
The Tufao::HttpServer will emit the Tufao::HttpServer::requestReady signal each time a request comes. We can handle all requests in a single place in the code, but we won't do that, because... em... as some wise person said before, we need:
We could decompose our slot into some functions to do the job. But we won't do that, because Tufão already has a better abstraction for the problem, Tufao::HttpServerRequestRouter.
The idea behind Tufao::HttpServerRequestRouter is have a chain of request handlers and mapped paths to them. If a request comes to a handler unable to handle it, the request is delegated to another handler in the chain.
In the code, we have one router (line 19) and three handlers (lines 24, 26 and 28). In the lines 33 to 35 we bind the router and the handlers and in the line 38 we bind the router and the server. The handlers, in order, are:
If you run this application, you'll see the error Unsupported config file version. This is happening because you didn't prepare a routes.conf file to feed the plugin handler. See Tufão's plugin system to learn how to fix it and add a plugin-based handler to the application. The file routes.conf must be placed in the working dir from where the application will run (or is running).
If you access http://localhost:8080/ you'll see a message telling you that the page wasn't found. Create a folder called public in the working dir of the executable and put a file called index.html there:
<html> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <head><title>Hello World</title></head> <body> <h1>Congratulations,</h1> <p>you are able to start web development in C++ with Tufão</p> </body> </html>
Now access the page http://localhost:8080/index.html and see the result. As an exercise, I left the task to add a favicon to your application using the Tufão's plugin system.
The Tufão has native support to three build systems: qmake, pkgconfig and CMake.
Once Tufão is correctly installed, you can use Tufão in your qmake-based applications appending the following line to your project file, where x is the major version (0 for Tufão 0.x) you want to use:
CONFIG += TUFAOx
If you use CMake, just follow the common steps (require package and handle compile and link flags) in your CMakeLists.txt file:
find_package(Tufao 0.4 REQUIRED) include_directories("${TUFAO_INCLUDE_DIR}") target_link_libraries(foobar ${TUFAO_LIBRARIES})
If you want to use a FindTufao.cmake file embedded in your project dir, add the following line to your CMakeLists.txt:
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "/path/to/FindTufao.cmake")
If you want to use autotools or another build system that has pkgconfig support, you can use the Tufão's pkgconfig module, where x is the major version (0 for Tufão 0.x) you want to use:
$ pkg-config tufaox
If want to use a build system that don't support pkgconfig, you should be ashamed, but you may still be able to use Tufão (probably editing the compiler -I flag and the linker -L and -l flags).