[gnupg] Gnupg integration (#1310)

* Integrating GnuPG with oss-fuzz

* Building and running fuzz_verify for gnupg

* Add fuzz_import for gnupg

* Adding seed corpus for fuzz import

and fuzz target decrypt

* Automatically generated corpuses
This commit is contained in:
Catena cyber 2018-05-24 17:58:52 +02:00 committed by Max Moroz
parent 1194bc1464
commit 13aca53072
3 changed files with 110 additions and 0 deletions

32
projects/gnupg/Dockerfile Normal file
View File

@ -0,0 +1,32 @@
# Copyright 2018 Google Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
################################################################################
FROM gcr.io/oss-fuzz-base/base-builder
MAINTAINER info@g10code.com
RUN apt-get update && apt-get install -y make autoconf automake libtool gettext bzip2 gnupg
#wait for zesty, or backport ?
RUN curl -O https://www.gnupg.org/ftp/gcrypt/libgpg-error/libgpg-error-1.28.tar.bz2
RUN curl -O https://www.gnupg.org/ftp/gcrypt/libgcrypt/libgcrypt-1.8.2.tar.bz2
RUN curl -O https://www.gnupg.org/ftp/gcrypt/libassuan/libassuan-2.5.1.tar.bz2
RUN curl -O https://www.gnupg.org/ftp/gcrypt/libksba/libksba-1.3.5.tar.bz2
RUN curl -O https://www.gnupg.org/ftp/gcrypt/npth/npth-1.5.tar.bz2
#TODO change when merged into master branch of official repo
RUN git clone --depth 1 --branch fuzz https://github.com/catenacyber/gnupg.git gnupg
WORKDIR gnupg
COPY build.sh $SRC/

75
projects/gnupg/build.sh Executable file
View File

@ -0,0 +1,75 @@
#!/bin/bash -eu
# Copyright 2018 Google Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
################################################################################
#compile and link statically dependencies
cd ..
tar -xvf libgpg-error-1.28.tar.bz2
cd libgpg-error-1.28
./configure --enable-static --disable-shared
make
make install
cd ..
tar -xvf libgcrypt-1.8.2.tar.bz2
cd libgcrypt-1.8.2
./configure --enable-static --disable-shared
make
make install
cd ..
tar -xvf libassuan-2.5.1.tar.bz2
cd libassuan-2.5.1
./configure --enable-static --disable-shared
make
make install
cd ..
tar -xvf libksba-1.3.5.tar.bz2
cd libksba-1.3.5
./configure --enable-static --disable-shared
make
make install
cd ..
tar -xvf npth-1.5.tar.bz2
cd npth-1.5
./configure --enable-static --disable-shared
make
make install
cd ..
# build project
cd gnupg
./autogen.sh
./configure --disable-doc --enable-maintainer-mode
make -j$(nproc) all
# build fuzzers
cd tests/fuzz
#export other associated stuff
cp *.options $OUT/
cp fuzz_*_seed_corpus.zip $OUT/
$CC $CFLAGS -DHAVE_CONFIG_H -I. -I../.. -I../../common -I../../g10 -c fuzz_verify.c -o fuzz_verify.o
$CXX $CXXFLAGS -std=c++11 -DHAVE_CONFIG_H fuzz_verify.o -o $OUT/fuzz_verify ../../g10/libgpg.a ../../kbx/libkeybox.a ../../common/libcommon.a ../../common/libgpgrl.a -lFuzzingEngine -lgcrypt -lgpg-error -lassuan
$CC $CFLAGS -DHAVE_CONFIG_H -I. -I../.. -I../../common -I../../g10 -c fuzz_import.c -o fuzz_import.o
$CXX $CXXFLAGS -std=c++11 -DHAVE_CONFIG_H fuzz_import.o -o $OUT/fuzz_import ../../g10/libgpg.a ../../kbx/libkeybox.a ../../common/libcommon.a ../../common/libgpgrl.a -lFuzzingEngine -lgcrypt -lgpg-error -lassuan
$CC $CFLAGS -DHAVE_CONFIG_H -I. -I../.. -I../../common -I../../g10 -c fuzz_decrypt.c -o fuzz_decrypt.o
$CXX $CXXFLAGS -std=c++11 -DHAVE_CONFIG_H fuzz_decrypt.o -o $OUT/fuzz_decrypt ../../g10/libgpg.a ../../kbx/libkeybox.a ../../common/libcommon.a ../../common/libgpgrl.a -lFuzzingEngine -lgcrypt -lgpg-error -lassuan

View File

@ -0,0 +1,3 @@
homepage: "https://www.gnupg.org"
primary_contact: "info@g10code.com"
auto_ccs : "p.antoine@catenacyber.fr"