%bcond_without check %global extver 3320300 %global tcl_version 8.6 %global tcl_sitearch %{_libdir}/tcl%{tcl_version} %global year 2020 Name: sqlite Version: 3.32.3 Release: 7 Summary: Embeded SQL database License: Public Domain URL: http://www.sqlite.org/ Source0: https://www.sqlite.org/%{year}/sqlite-src-%{extver}.zip Source1: http://www.sqlite.org/%{year}/sqlite-doc-%{extver}.zip Source2: https://www.sqlite.org/%{year}/sqlite-autoconf-%{extver}.tar.gz Patch1: 0001-sqlite-no-malloc-usable-size.patch Patch2: 0002-remove-fail-testcase-in-no-free-fd-situation.patch Patch3: CVE-2021-20227.patch Patch4: 0004-CVE-2022-35737.patch Patch5: 0005-CVE-2021-20223.patch Patch6: 0006-fix-integer-overflow-on-gigabyte-string.patch Patch7: 0007-CVE-2023-7104.patch BuildRequires: gcc autoconf tcl tcl-devel BuildRequires: ncurses-devel readline-devel glibc-devel Provides: %{name}-libs Obsoletes: %{name}-libs Provides: lemon Obsoletes: lemon Provides: %{name}-analyzer Obsoletes: %{name}-analyzer Provides: %{name}-tcl Obsoletes: %{name}-tcl %description SQLite is a C-language library that implements a small, fast, self-contained, high-reliability, full-featured, SQL database engine. SQLite is the most used database engine in the world. SQLite is built into all mobile phones and most computers and comes bundled inside countless other applications that people use every day.It also include lemon and sqlite3_analyzer and tcl tools. %package devel Summary: Including header files and library for the developing of sqlite Requires: %{name}%{?_isa} = %{version}-%{release} Requires: pkgconfig %description devel This contains dynamic libraries and header files for the developing of sqlite. %package help Summary: Man file and documentation for sqlite BuildArch: noarch Provides: %{name}-doc Obsoletes: %{name}-doc %description help This contains man files and HTML files for the using of sqlite. %prep #autosetup will fail because of 2 zip files %setup -q -a1 -n %{name}-src-%{extver} %patch1 -p1 %patch2 -p1 %patch3 -p1 %patch4 -p1 %patch5 -p1 %patch6 -p1 %patch7 -p1 rm -f %{name}-doc-%{extver}/sqlite.css~ || : autoconf %build export CFLAGS="$RPM_OPT_FLAGS $RPM_LD_FLAGS -DSQLITE_ENABLE_COLUMN_METADATA=1 \ -DSQLITE_DISABLE_DIRSYNC=1 -DSQLITE_ENABLE_FTS3=3 \ -DSQLITE_ENABLE_RTREE=1 -DSQLITE_SECURE_DELETE=1 \ -DSQLITE_ENABLE_UNLOCK_NOTIFY=1 -DSQLITE_ENABLE_DBSTAT_VTAB=1 \ -DSQLITE_ENABLE_FTS3_PARENTHESIS=1 -DSQLITE_ENABLE_JSON1=1 \ -Wall -fno-strict-aliasing" %configure --enable-fts5 \ --enable-threadsafe \ --enable-threads-override-locks \ --enable-load-extension \ TCLLIBDIR=%{tcl_sitearch}/sqlite3 # rpath removal sed -i 's|^hardcode_libdir_flag_spec=.*|hardcode_libdir_flag_spec=""|g' libtool sed -i 's|^runpath_var=LD_RUN_PATH|runpath_var=DIE_RPATH_DIE|g' libtool %make_build %make_build sqlite3_analyzer %install make DESTDIR=${RPM_BUILD_ROOT} install install -D -m 755 lemon %{buildroot}%{_bindir}/lemon install -D -m 644 tool/lempar.c %{buildroot}%{_datadir}/lemon/lempar.c install -D -m 644 sqlite3.1 %{buildroot}%{_mandir}/man1/sqlite3.1 install -D -m 755 sqlite3_analyzer %{buildroot}%{_bindir}/sqlite3_analyzer chmod 755 %{buildroot}/%{tcl_sitearch}/sqlite3/*.so %if %{with check} %check export LD_LIBRARY_PATH=`pwd`/.libs export MALLOC_CHECK_=3 #bypass zipfile.test rm test/zipfile.test %ifarch x86_64 %{ix86} %else rm test/csv01.test %endif make test %endif # with check %ldconfig_scriptlets %files %doc README.md %{_bindir}/{sqlite3,lemon,sqlite3_analyzer} %{_libdir}/*.so.* %{_datadir}/lemon %{tcl_sitearch}/sqlite3 %exclude %{_libdir}/*.{la,a} %files devel %{_includedir}/*.h %{_libdir}/*.so %{_libdir}/pkgconfig/*.pc %files help %doc %{name}-doc-%{extver}/* %{_mandir}/man*/* %changelog * Wed Jan 3 2024 mazhao - 3.32.3-7 - fix the CVE-2023-7104 * Tue Sep 6 2022 zhuwentao - 3.32.3-6 - fix integer overflow on gigabyte string * Wed Aug 31 2022 wbq_sky - 3.32.3-5 - Fix CVE-2021-20223 * Tue Aug 16 2022 liusirui - 3.32.3-4 - Fix CVE-2022-35737 * Mon Apr 26 2021 bzhaoop - 3.32.3-3 - Fix CVE-2021-20227 * Thu Sep 3 2020 lihaotian - 3.32.3-2 - update source0 url * Tue Aug 25 2020 yanglongkang - 3.32.3-1 - update package to 3.32.3 * Tue Aug 4 2020 yanglongkang - 3.31.1-2 - Type:cves - ID:CVE-2020-13871 - SUG: NA - DESC: fix cve * Mon Aug 3 2020 yanglongkang - 3.31.1-1 - Type:cves - ID:CVE-2020-15358 CVE-2020-13631 - SUG: NA - DESC: fix cve * Fri Apr 17 2020 luoshijie - 3.31.1-0 - Type:enhancement - ID:NA - SUG:restart - DESC:update sqlite to 3.31.1. * Tue Mar 10 2020 guiyao - 3.24.0-11 - Type:cves - ID:CVE-2020-9327 - SUG: NA - DESC: fix cve * Fri Feb 28 2020 sunshihao - 3.24.0-10 - Type:enhancement - ID: - SUG: NA - DESC: remove suffix information * Wed Feb 26 2020 guiyao - 3.24.0-9 - Type:cves - ID:CVE-2018-20505 - SUG:NA - DESC:fix cves * Sat Jan 11 2020 openEuler Buildteam - 3.24.0-8 - Type:enhancement - ID:NA - SUG:NA - DESC:CVE-2019-19959 fixed * Sat Jan 11 2020 openEuler Buildteam - 3.24.0-7 - Type:enhancement - ID:NA - SUG:NA - DESC:Fix CVE-2019-19923 CVE-2019-19924 CVE-2019-19925 CVE-2019-19926 CVE-2019-20218 * Fri Jan 3 2020 openEuler Buildteam - 3.24.0-6 - Type:cves - ID:CVE-2019-9936,CVE-2019-9937 - SUG:NA - DESC:fix cve * Sat Dec 21 2019 openEuler Buildteam - 3.24.0-5 - Type:bugfix - ID:NA - SUG:NA - DESC:fix CVE bug * Wed Sep 11 2019 openEuler Buildteam - 3.24.0-4 - Type:enhancemnet - ID:NA - SUG:NA - DESC:remove debuginfo * Wed Aug 28 2019 openEuler Buildteam - 3.24.0-3 - Type:enhancemnet - ID:NA - SUG:restart - DESC:openEuler Debranding * Tue Aug 20 2019 wubo - 3.24.0-2.h4 - Type: - ID: - SUG:NA - DESC:rename patch * Thu Aug 15 2019 wubo - 3.24.0-2.h3 - Type:bugfix - ID:CVE-2019-8457 - SUG:NA - DESC:heap out-of-bound read in function rtreenode() * Sat Mar 23 2019 Xiaoqi Guo - 3.24.0-2.h2 - Type:bugfix - ID:NA - SUG:NA - DESC:backport patch from community * Sat Mar 23 2019 luochunsheng - 3.24.0-2.h1 - Type:cves - ID:CVE-2018-20346 - SUG:NA - DESC:CVE-2018-20346 - Package init