add example: hello world
This commit is contained in:
parent
0d0f2767b9
commit
ac14349b67
|
@ -9,11 +9,6 @@ if(NOT CMAKE_BUILD_TYPE)
|
||||||
set(CMAKE_BUILD_TYPE Release)
|
set(CMAKE_BUILD_TYPE Release)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
link_directories(
|
|
||||||
dependencies/cryptopp
|
|
||||||
dependencies/libpqxx/src/.libs
|
|
||||||
)
|
|
||||||
|
|
||||||
add_subdirectory(WebApp/bserv)
|
add_subdirectory(WebApp/bserv)
|
||||||
add_subdirectory(WebApp/WebApp)
|
add_subdirectory(WebApp/WebApp)
|
||||||
|
|
||||||
|
|
45
README.md
45
README.md
|
@ -5,14 +5,55 @@
|
||||||
|
|
||||||
## Quick Start
|
## Quick Start
|
||||||
|
|
||||||
> To build the dependencies & the project, refer to [`BUILD-Windows.md`](BUILD-Windows.md) or [`BUILD-ubuntu.md`](BUILD-ubuntu.md)
|
> To build the dependencies & the project, refer to [`BUILD-Windows.md`](BUILD-Windows.md) or [`BUILD-ubuntu.md`](BUILD-ubuntu.md).
|
||||||
|
|
||||||
- `WebApp/bserv` contains the source code for `bserv`.
|
- `WebApp/bserv` contains the source code for `bserv`.
|
||||||
|
|
||||||
|
|
||||||
|
### Hello, World!
|
||||||
|
|
||||||
|
*This [example](examples/hello-world) shows how to use `bserv` to echo a json object `{"msg": "hello, world!"}` when requesting `localhost:8080/hello`.*
|
||||||
|
|
||||||
|
`main.cpp`:
|
||||||
|
```C++
|
||||||
|
#include <bserv/common.hpp>
|
||||||
|
#include <boost/json.hpp>
|
||||||
|
boost::json::object hello()
|
||||||
|
{
|
||||||
|
return {{"msg", "hello, world!"}};
|
||||||
|
}
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
bserv::server_config config;
|
||||||
|
// config.set_port(8080);
|
||||||
|
bserv::server{config, {
|
||||||
|
bserv::make_path("/hello", &hello)
|
||||||
|
}};
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
`CMakeLists.txt`:
|
||||||
|
```
|
||||||
|
cmake_minimum_required(VERSION 3.10)
|
||||||
|
|
||||||
|
project(hello)
|
||||||
|
|
||||||
|
set(CMAKE_CXX_STANDARD 17)
|
||||||
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
|
||||||
|
add_subdirectory(path/to/WebApp/bserv bserv)
|
||||||
|
add_executable(main main.cpp)
|
||||||
|
target_link_libraries(main PUBLIC bserv)
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
### Sample Project: `WebApp`
|
||||||
|
|
||||||
- `WebApp/WebApp` is a sample project.
|
- `WebApp/WebApp` is a sample project.
|
||||||
- [`config-Windows.json`](config-Windows.json) and [`config-ubuntu.json`](config-ubuntu.json) are two sample config file for `WebApp`'s startup parameters. **It should be configured and renamed to `config.json` before you start `WebApp`.**
|
- [`config-Windows.json`](config-Windows.json) and [`config-ubuntu.json`](config-ubuntu.json) are two sample config file for `WebApp`'s startup parameters. **It should be configured and renamed to `config.json` before you start `WebApp`.**
|
||||||
- To use `WebApp`, you should setup the database as well.
|
- To use `WebApp`, you should setup the database as well.
|
||||||
|
|
||||||
### Database
|
#### Database
|
||||||
|
|
||||||
You can import the sample database:
|
You can import the sample database:
|
||||||
|
|
||||||
|
|
|
@ -29,8 +29,8 @@ target_link_libraries(
|
||||||
boost_log
|
boost_log
|
||||||
boost_log_setup
|
boost_log_setup
|
||||||
boost_json
|
boost_json
|
||||||
pqxx
|
"${CMAKE_CURRENT_SOURCE_DIR}/../../dependencies/cryptopp/libcryptopp.a"
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}/../../dependencies/libpqxx/src/.libs/libpqxx.a"
|
||||||
pq
|
pq
|
||||||
cryptopp
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
/build
|
|
@ -0,0 +1,10 @@
|
||||||
|
cmake_minimum_required(VERSION 3.10)
|
||||||
|
|
||||||
|
project(hello)
|
||||||
|
|
||||||
|
set(CMAKE_CXX_STANDARD 17)
|
||||||
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
|
||||||
|
add_subdirectory(../../WebApp/bserv bserv)
|
||||||
|
add_executable(main main.cpp)
|
||||||
|
target_link_libraries(main PUBLIC bserv)
|
|
@ -0,0 +1,14 @@
|
||||||
|
#include <bserv/common.hpp>
|
||||||
|
#include <boost/json.hpp>
|
||||||
|
boost::json::object hello()
|
||||||
|
{
|
||||||
|
return {{"msg", "hello, world!"}};
|
||||||
|
}
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
bserv::server_config config;
|
||||||
|
// config.set_port(8080);
|
||||||
|
bserv::server{config, {
|
||||||
|
bserv::make_path("/hello", &hello)
|
||||||
|
}};
|
||||||
|
}
|
Loading…
Reference in New Issue