mirror of
https://github.com/drogonframework/drogon.git
synced 2025-07-18 00:00:46 -04:00
Compare commits
No commits in common. "366311c19686eb31601d19d74618b8250da33c88" and "58055ae39c036328a65ed756394809938ac08099" have entirely different histories.
366311c196
...
58055ae39c
11
.github/dependabot.yml
vendored
11
.github/dependabot.yml
vendored
@ -1,11 +0,0 @@
|
|||||||
# To get started with Dependabot version updates, you'll need to specify which
|
|
||||||
# package ecosystems to update and where the package manifests are located.
|
|
||||||
# Please see the documentation for all configuration options:
|
|
||||||
# https://help.github.com/github/administering-a-repository/configuration-options-for-dependency-updates
|
|
||||||
|
|
||||||
version: 2
|
|
||||||
updates:
|
|
||||||
- package-ecosystem: "github-actions"
|
|
||||||
directory: "/"
|
|
||||||
schedule:
|
|
||||||
interval: "monthly"
|
|
167
.github/workflows/cmake.yml
vendored
167
.github/workflows/cmake.yml
vendored
@ -1,8 +1,8 @@
|
|||||||
name: Build & Test
|
name: Build Drogon
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: [master]
|
branches: [ master ]
|
||||||
pull_request:
|
pull_request:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
|
||||||
@ -21,10 +21,10 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
link: ["STATIC", "SHARED"]
|
link: [ 'STATIC', 'SHARED' ]
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout Drogon source code
|
- name: Checkout Drogon source code
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v2
|
||||||
with:
|
with:
|
||||||
submodules: true
|
submodules: true
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
@ -64,35 +64,97 @@ jobs:
|
|||||||
shell: bash
|
shell: bash
|
||||||
run: ./test.sh -w
|
run: ./test.sh -w
|
||||||
|
|
||||||
macos:
|
unix:
|
||||||
name: macos/clang
|
name: ${{ matrix.buildname }}
|
||||||
runs-on: macos-latest
|
runs-on: ${{ matrix.os }}
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- os: ubuntu-22.04
|
||||||
|
buildname: 'ubuntu-22.04/gcc'
|
||||||
|
link: SHARED
|
||||||
|
triplet: x64-linux
|
||||||
|
compiler: gcc_64
|
||||||
|
- os: ubuntu-22.04
|
||||||
|
buildname: 'ubuntu-22.04/gcc'
|
||||||
|
link: STATIC
|
||||||
|
triplet: x64-linux
|
||||||
|
compiler: gcc_64
|
||||||
|
- os: ubuntu-22.04
|
||||||
|
buildname: 'ubuntu-22.04/gcc-10'
|
||||||
|
link: STATIC
|
||||||
|
triplet: x64-linux
|
||||||
|
- os: macos-latest
|
||||||
|
buildname: 'macos/clang'
|
||||||
|
link: STATIC
|
||||||
|
triplet: x64-osx
|
||||||
|
compiler: clang_64
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout Drogon source code
|
- name: Checkout Drogon source code
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v2
|
||||||
with:
|
with:
|
||||||
submodules: true
|
submodules: true
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: (macOS) Install dependencies
|
||||||
|
if: runner.os == 'macOS'
|
||||||
# Already installed: brotli, zlib, postgresql@14, lz4, sqlite3
|
# Already installed: brotli, zlib, postgresql@14, lz4, sqlite3
|
||||||
run: brew install ninja jsoncpp mariadb hiredis redis
|
run: brew install jsoncpp mariadb hiredis redis
|
||||||
|
|
||||||
|
- name: (Linux) Install dependencies
|
||||||
|
if: runner.os == 'Linux'
|
||||||
|
run: |
|
||||||
|
# Installing packages might fail as the github image becomes outdated
|
||||||
|
sudo apt update
|
||||||
|
# These aren't available or don't work well in vcpkg
|
||||||
|
sudo apt-get install -y libjsoncpp-dev uuid-dev libssl-dev zlib1g-dev libsqlite3-dev
|
||||||
|
sudo apt-get install -y libbrotli-dev
|
||||||
|
- name: (Linux) Install gcc-10
|
||||||
|
if: matrix.buildname == 'ubuntu-22.04/gcc-10'
|
||||||
|
run: sudo apt-get install -y gcc-10 g++-10
|
||||||
|
|
||||||
|
- name: (Linux) Install postgresql
|
||||||
|
if: matrix.os == 'ubuntu-22.04'
|
||||||
|
run: |
|
||||||
|
sudo apt-get --purge remove postgresql postgresql-doc postgresql-common postgresql-client-common
|
||||||
|
sudo apt-get -y install postgresql-all
|
||||||
|
- name: Export `shared`
|
||||||
|
run: |
|
||||||
|
[[ ${{ matrix.link }} == "SHARED" ]] && shared="ON" || shared="OFF"
|
||||||
|
echo "shared=$shared" >> $GITHUB_ENV
|
||||||
|
|
||||||
- name: Create Build Environment & Configure Cmake
|
- name: Create Build Environment & Configure Cmake
|
||||||
# Some projects don't allow in-source building, so create a separate build directory
|
# Some projects don't allow in-source building, so create a separate build directory
|
||||||
# We'll use this as our working directory for all subsequent commands
|
# We'll use this as our working directory for all subsequent commands
|
||||||
|
if: matrix.buildname != 'ubuntu-22.04/gcc-10'
|
||||||
run: |
|
run: |
|
||||||
cmake -B build -G Ninja \
|
cmake -B build \
|
||||||
-DCMAKE_BUILD_TYPE=$BUILD_TYPE \
|
-DCMAKE_BUILD_TYPE=$BUILD_TYPE \
|
||||||
-DBUILD_TESTING=on \
|
-DBUILD_TESTING=on \
|
||||||
-DBUILD_SHARED_LIBS=OFF
|
-DBUILD_SHARED_LIBS=$shared
|
||||||
|
|
||||||
|
- name: Create Build Environment & Configure Cmake (gcc-10)
|
||||||
|
# Some projects don't allow in-source building, so create a separate build directory
|
||||||
|
# We'll use this as our working directory for all subsequent commands
|
||||||
|
if: matrix.buildname == 'ubuntu-22.04/gcc-10'
|
||||||
|
run: |
|
||||||
|
cmake -B build \
|
||||||
|
-DCMAKE_BUILD_TYPE=$BUILD_TYPE \
|
||||||
|
-DBUILD_TESTING=on \
|
||||||
|
-DCMAKE_CXX_FLAGS="-fcoroutines" \
|
||||||
|
-DBUILD_SHARED_LIBS=$shared
|
||||||
|
env:
|
||||||
|
CC: gcc-10
|
||||||
|
CXX: g++-10
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
working-directory: ./build
|
working-directory: ./build
|
||||||
# Execute the build. You can specify a specific target with "--target <NAME>"
|
# Execute the build. You can specify a specific target with "--target <NAME>"
|
||||||
run: ninja && sudo ninja install
|
run: make -j $(nproc) && sudo make install
|
||||||
|
|
||||||
- name: Prepare for testing
|
- name: (macOS) Prepare for testing
|
||||||
|
if: runner.os == 'macOS'
|
||||||
run: |
|
run: |
|
||||||
brew tap homebrew/services
|
brew tap homebrew/services
|
||||||
brew services restart postgresql@14
|
brew services restart postgresql@14
|
||||||
@ -106,75 +168,8 @@ jobs:
|
|||||||
sleep 4
|
sleep 4
|
||||||
psql -c 'create user postgres superuser;' postgres
|
psql -c 'create user postgres superuser;' postgres
|
||||||
|
|
||||||
- name: Test
|
- name: (Linux) Prepare for testing
|
||||||
# Execute tests defined by the CMake configuration.
|
if: runner.os == 'Linux'
|
||||||
# See https://cmake.org/cmake/help/latest/manual/ctest.1.html for more detail
|
|
||||||
run: ./test.sh -t
|
|
||||||
|
|
||||||
ubuntu:
|
|
||||||
name: ${{ matrix.buildname }}
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
strategy:
|
|
||||||
fail-fast: false
|
|
||||||
matrix:
|
|
||||||
include:
|
|
||||||
- buildname: "ubuntu-22.04/gcc"
|
|
||||||
link: SHARED
|
|
||||||
- buildname: "ubuntu-22.04/gcc"
|
|
||||||
link: STATIC
|
|
||||||
- buildname: "ubuntu-22.04/coroutines"
|
|
||||||
link: STATIC
|
|
||||||
steps:
|
|
||||||
- name: Checkout Drogon source code
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
with:
|
|
||||||
submodules: true
|
|
||||||
fetch-depth: 0
|
|
||||||
|
|
||||||
- name: Install dependencies
|
|
||||||
run: |
|
|
||||||
# Installing packages might fail as the github image becomes outdated
|
|
||||||
sudo apt update
|
|
||||||
# These aren't available or don't work well in vcpkg
|
|
||||||
sudo apt-get install -y libjsoncpp-dev uuid-dev libssl-dev zlib1g-dev libsqlite3-dev
|
|
||||||
sudo apt-get install -y ninja-build libbrotli-dev
|
|
||||||
|
|
||||||
- name: Install postgresql
|
|
||||||
run: |
|
|
||||||
sudo apt-get --purge remove postgresql postgresql-doc postgresql-common postgresql-client-common
|
|
||||||
sudo apt-get -y install postgresql-all
|
|
||||||
|
|
||||||
- name: Export `shared`
|
|
||||||
run: |
|
|
||||||
[[ ${{ matrix.link }} == "SHARED" ]] && shared="ON" || shared="OFF"
|
|
||||||
echo "shared=$shared" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
- name: Create Build Environment & Configure Cmake
|
|
||||||
# Some projects don't allow in-source building, so create a separate build directory
|
|
||||||
# We'll use this as our working directory for all subsequent commands
|
|
||||||
if: matrix.buildname != 'ubuntu-22.04/coroutines'
|
|
||||||
run: |
|
|
||||||
cmake -B build -G Ninja \
|
|
||||||
-DCMAKE_BUILD_TYPE=$BUILD_TYPE \
|
|
||||||
-DBUILD_TESTING=on \
|
|
||||||
-DBUILD_SHARED_LIBS=$shared
|
|
||||||
- name: Create Build Environment & Configure Cmake (coroutines)
|
|
||||||
# Some projects don't allow in-source building, so create a separate build directory
|
|
||||||
# We'll use this as our working directory for all subsequent commands
|
|
||||||
if: matrix.buildname == 'ubuntu-22.04/coroutines'
|
|
||||||
run: |
|
|
||||||
cmake -B build -G Ninja \
|
|
||||||
-DCMAKE_BUILD_TYPE=$BUILD_TYPE \
|
|
||||||
-DBUILD_TESTING=on \
|
|
||||||
-DCMAKE_CXX_FLAGS="-fcoroutines" \
|
|
||||||
-DBUILD_SHARED_LIBS=$shared
|
|
||||||
|
|
||||||
- name: Build
|
|
||||||
working-directory: ./build
|
|
||||||
# Execute the build. You can specify a specific target with "--target <NAME>"
|
|
||||||
run: ninja && sudo ninja install
|
|
||||||
|
|
||||||
- name: Prepare for testing
|
|
||||||
run: |
|
run: |
|
||||||
sudo systemctl start postgresql
|
sudo systemctl start postgresql
|
||||||
sleep 1
|
sleep 1
|
||||||
@ -184,3 +179,9 @@ jobs:
|
|||||||
# Execute tests defined by the CMake configuration.
|
# Execute tests defined by the CMake configuration.
|
||||||
# See https://cmake.org/cmake/help/latest/manual/ctest.1.html for more detail
|
# See https://cmake.org/cmake/help/latest/manual/ctest.1.html for more detail
|
||||||
run: ./test.sh -t
|
run: ./test.sh -t
|
||||||
|
|
||||||
|
- name: Lint
|
||||||
|
if: matrix.os == 'ubuntu-22.04'
|
||||||
|
run: |
|
||||||
|
sudo apt install -y dos2unix
|
||||||
|
./format.sh && git diff --exit-code
|
||||||
|
12
.github/workflows/codeql.yml
vendored
12
.github/workflows/codeql.yml
vendored
@ -9,10 +9,6 @@ on:
|
|||||||
schedule:
|
schedule:
|
||||||
- cron: '46 7 * * 5'
|
- cron: '46 7 * * 5'
|
||||||
|
|
||||||
concurrency:
|
|
||||||
group: ${{ github.workflow }}-${{ github.ref }}
|
|
||||||
cancel-in-progress: ${{ github.event_name == 'pull_request' }}
|
|
||||||
|
|
||||||
env:
|
env:
|
||||||
# Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.)
|
# Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.)
|
||||||
BUILD_TYPE: Release
|
BUILD_TYPE: Release
|
||||||
@ -40,7 +36,7 @@ jobs:
|
|||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout Drogon source code
|
- name: Checkout Drogon source code
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v2
|
||||||
with:
|
with:
|
||||||
submodules: true
|
submodules: true
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
@ -49,11 +45,11 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
sudo apt update
|
sudo apt update
|
||||||
sudo apt-get install -y libjsoncpp-dev uuid-dev libssl-dev zlib1g-dev libsqlite3-dev
|
sudo apt-get install -y libjsoncpp-dev uuid-dev libssl-dev zlib1g-dev libsqlite3-dev
|
||||||
sudo apt-get install -y ninja-build libbrotli-dev
|
sudo apt-get install -y libbrotli-dev
|
||||||
|
|
||||||
- name: Create Build Environment & Configure Cmake
|
- name: Create Build Environment & Configure Cmake
|
||||||
run: |
|
run: |
|
||||||
cmake -B build -G Ninja \
|
cmake -B build \
|
||||||
-DCMAKE_BUILD_TYPE=$BUILD_TYPE \
|
-DCMAKE_BUILD_TYPE=$BUILD_TYPE \
|
||||||
-DBUILD_TESTING=on \
|
-DBUILD_TESTING=on \
|
||||||
-DBUILD_SHARED_LIBS=$SHARED
|
-DBUILD_SHARED_LIBS=$SHARED
|
||||||
@ -72,7 +68,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
working-directory: ./build
|
working-directory: ./build
|
||||||
run: ninja && sudo ninja install
|
run: make -j $(nproc) && sudo make install
|
||||||
|
|
||||||
- name: Perform CodeQL Analysis
|
- name: Perform CodeQL Analysis
|
||||||
uses: github/codeql-action/analyze@v2
|
uses: github/codeql-action/analyze@v2
|
||||||
|
21
.github/workflows/cpp.yml
vendored
21
.github/workflows/cpp.yml
vendored
@ -1,21 +0,0 @@
|
|||||||
name: C++
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches: [master]
|
|
||||||
pull_request:
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
format:
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
|
|
||||||
- name: Install dos2unix
|
|
||||||
run: sudo apt-get install -y dos2unix
|
|
||||||
|
|
||||||
- name: Check formatting
|
|
||||||
run: ./format.sh && git diff --exit-code
|
|
@ -1,7 +1,7 @@
|
|||||||
#include <drogon/drogon.h>
|
#include <drogon/drogon.h>
|
||||||
int main() {
|
int main() {
|
||||||
//Set HTTP listener address and port
|
//Set HTTP listener address and port
|
||||||
drogon::app().addListener("0.0.0.0", 5555);
|
drogon::app().addListener("0.0.0.0",80);
|
||||||
//Load config file
|
//Load config file
|
||||||
//drogon::app().loadConfigFile("../config.json");
|
//drogon::app().loadConfigFile("../config.json");
|
||||||
//drogon::app().loadConfigFile("../config.yaml");
|
//drogon::app().loadConfigFile("../config.yaml");
|
||||||
|
@ -508,7 +508,7 @@ if(@@.get<std::string>("rdbms")=="postgresql")
|
|||||||
if(@@.get<std::string>("rdbms")=="postgresql")
|
if(@@.get<std::string>("rdbms")=="postgresql")
|
||||||
{
|
{
|
||||||
%>
|
%>
|
||||||
n = snprintf(placeholderStr,sizeof(placeholderStr),"$%d,",placeholder++);
|
n = sprintf(placeholderStr,"$%d,",placeholder++);
|
||||||
sql.append(placeholderStr, n);
|
sql.append(placeholderStr, n);
|
||||||
<%c++
|
<%c++
|
||||||
}else
|
}else
|
||||||
|
@ -352,67 +352,43 @@ class Users
|
|||||||
size_t n = 0;
|
size_t n = 0;
|
||||||
if (dirtyFlag_[0])
|
if (dirtyFlag_[0])
|
||||||
{
|
{
|
||||||
n = snprintf(placeholderStr,
|
n = sprintf(placeholderStr, "$%d,", placeholder++);
|
||||||
sizeof(placeholderStr),
|
|
||||||
"$%d,",
|
|
||||||
placeholder++);
|
|
||||||
sql.append(placeholderStr, n);
|
sql.append(placeholderStr, n);
|
||||||
}
|
}
|
||||||
if (dirtyFlag_[1])
|
if (dirtyFlag_[1])
|
||||||
{
|
{
|
||||||
n = snprintf(placeholderStr,
|
n = sprintf(placeholderStr, "$%d,", placeholder++);
|
||||||
sizeof(placeholderStr),
|
|
||||||
"$%d,",
|
|
||||||
placeholder++);
|
|
||||||
sql.append(placeholderStr, n);
|
sql.append(placeholderStr, n);
|
||||||
}
|
}
|
||||||
if (dirtyFlag_[2])
|
if (dirtyFlag_[2])
|
||||||
{
|
{
|
||||||
n = snprintf(placeholderStr,
|
n = sprintf(placeholderStr, "$%d,", placeholder++);
|
||||||
sizeof(placeholderStr),
|
|
||||||
"$%d,",
|
|
||||||
placeholder++);
|
|
||||||
sql.append(placeholderStr, n);
|
sql.append(placeholderStr, n);
|
||||||
}
|
}
|
||||||
if (dirtyFlag_[3])
|
if (dirtyFlag_[3])
|
||||||
{
|
{
|
||||||
n = snprintf(placeholderStr,
|
n = sprintf(placeholderStr, "$%d,", placeholder++);
|
||||||
sizeof(placeholderStr),
|
|
||||||
"$%d,",
|
|
||||||
placeholder++);
|
|
||||||
sql.append(placeholderStr, n);
|
sql.append(placeholderStr, n);
|
||||||
}
|
}
|
||||||
if (dirtyFlag_[4])
|
if (dirtyFlag_[4])
|
||||||
{
|
{
|
||||||
n = snprintf(placeholderStr,
|
n = sprintf(placeholderStr, "$%d,", placeholder++);
|
||||||
sizeof(placeholderStr),
|
|
||||||
"$%d,",
|
|
||||||
placeholder++);
|
|
||||||
sql.append(placeholderStr, n);
|
sql.append(placeholderStr, n);
|
||||||
}
|
}
|
||||||
if (dirtyFlag_[5])
|
if (dirtyFlag_[5])
|
||||||
{
|
{
|
||||||
n = snprintf(placeholderStr,
|
n = sprintf(placeholderStr, "$%d,", placeholder++);
|
||||||
sizeof(placeholderStr),
|
|
||||||
"$%d,",
|
|
||||||
placeholder++);
|
|
||||||
sql.append(placeholderStr, n);
|
sql.append(placeholderStr, n);
|
||||||
}
|
}
|
||||||
sql += "default,";
|
sql += "default,";
|
||||||
if (dirtyFlag_[7])
|
if (dirtyFlag_[7])
|
||||||
{
|
{
|
||||||
n = snprintf(placeholderStr,
|
n = sprintf(placeholderStr, "$%d,", placeholder++);
|
||||||
sizeof(placeholderStr),
|
|
||||||
"$%d,",
|
|
||||||
placeholder++);
|
|
||||||
sql.append(placeholderStr, n);
|
sql.append(placeholderStr, n);
|
||||||
}
|
}
|
||||||
if (dirtyFlag_[8])
|
if (dirtyFlag_[8])
|
||||||
{
|
{
|
||||||
n = snprintf(placeholderStr,
|
n = sprintf(placeholderStr, "$%d,", placeholder++);
|
||||||
sizeof(placeholderStr),
|
|
||||||
"$%d,",
|
|
||||||
placeholder++);
|
|
||||||
sql.append(placeholderStr, n);
|
sql.append(placeholderStr, n);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
Loading…
x
Reference in New Issue
Block a user