Skip to content

aaron-lui/IPC_WEB

 
 

Repository files navigation

ipcweb-backend

A IP Camera Web Backend Reference Implementation


[TOC]

1. Getting Started

1.1 Build Requirements

ipcweb-backend is designed to run on Linux platform, especially the Linux platform of Rockchip's SoCs. It is cross compiled with the following environments:

  • Build Host: Ubuntu

  • Host Web Server: Any web server that supports CGI application, like Lighttpd, Nginx, Apache, AppWeb etc.

  • Build System: CMake >= 3.8

  • Compiler: GCC >= 6 or Clang

  • PostMan

  • Host Libraries(To test APIs on host environments)

    sudo apt install libboost-all-dev
    sudo apt install libcgicc-dev
    sudo apt install nlohmann-json-dev
    • jwt-cpp This library is not provided by system, it is build from souce
  • Target Libraries The target libraries should be provided by the Buildroot SDK, if them are not found, the CMake build system build them from source.

    BR2_PACKAGE_BOOST=y
    BR2_PACKAGE_BOOST_LOG=y
    BR2_PACKAGE_BOOST_STACKTRACE=y
    BR2_PACKAGE_BOOST_SYSTEM=y
    BR2_PACKAGE_BOOST_THREAD=y
    
    BR2_PACKAGE_LIBCGICC
    
    BR2_PACKAGE_JSON_FOR_MODERN_CPP
    

1.2 Build Instructions

mkdir build
cd build
cmake .. -DCMAKE_TOOLCHAIN_FILE=../cmake/toolchains/linux-arm.cmake
make -j8

1.5 Unit Testing

This project use Google Test as test framework. Init the googletest submodule to use it.

git submodule init
git submodule update

Build and test

cmake .. -DIPCWEB_BUILD_TESTS
make
make test

The output is like:

Running tests...
Test project /work/www/ipcweb-backend/build
    Start 1: ObjectsTest.Tcpip.noArgs
1/1 Test #1: ObjectsTest.Tcpip.noArgs .........   Passed    0.00 sec

100% tests passed, 0 tests failed out of 1

Total Test time (real) =   0.00 sec

1.4 CGI Testing

Start the web server to test CGI applications, suggest to use AppWeb.

appweb <path/of/web/root> <host>:<port>

Use tools like Postman to test the RESTful API

GET http://:/api/v1/hello.cgi?name=cody

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 97.8%
  • C++ 2.1%
  • Other 0.1%