diff --git a/.fmf/version b/.fmf/version
new file mode 100644
index 0000000..d00491f
--- /dev/null
+++ b/.fmf/version
@@ -0,0 +1 @@
+1
diff --git a/.gitignore b/.gitignore
index fd61fdd..471c3e4 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,2 +1,4 @@
apache-tomcat-*-src.tar.gz
-
+results_tomcat
+tomcat*.src.rpm
+apache-tomcat-*-src/
diff --git a/.packit.yaml b/.packit.yaml
new file mode 100644
index 0000000..2986867
--- /dev/null
+++ b/.packit.yaml
@@ -0,0 +1,38 @@
+# See the documentation for more information:
+# https://packit.dev/docs/configuration/
+
+create_sync_note: false
+
+upstream_project_url: https://github.com/apache/tomcat.git
+
+issue_repository: https://src.fedoraproject.org/rpms/tomcat
+
+jobs:
+# https://packit.dev/docs/configuration/downstream/pull_from_upstream
+# Make sure there is Fedora mapping for the 'tomcat' project in https://release-monitoring.org/projects/search/?pattern=tomcat
+# Make sure Monitoring status on the left side at https://src.fedoraproject.org/rpms/tomcat is set to Monitoring
+- job: pull_from_upstream
+ trigger: release
+ dist_git_branches:
+ - fedora-branched
+
+# https://packit.dev/docs/configuration/downstream/koji_build
+- job: koji_build
+ trigger: commit
+ dist_git_branches:
+ - fedora-all
+
+- job: koji_build
+ trigger: commit
+ scratch: true
+ allowed_pr_authors: ['all_admins', 'all_committers']
+ allowed_committers: ['all_admins', 'all_committers']
+ dist_git_branches:
+ - fedora-all
+
+# https://packit.dev/docs/configuration/downstream/bodhi_update
+- job: bodhi_update
+ trigger: commit
+ allowed_builders: ['packit', 'all_admins']
+ dist_git_branches:
+ - fedora-branched # rawhide updates are created automatically
diff --git a/add_parent_logger_getter.patch b/add_parent_logger_getter.patch
deleted file mode 100644
index 40b9268..0000000
--- a/add_parent_logger_getter.patch
+++ /dev/null
@@ -1,29 +0,0 @@
---- modules/jdbc-pool/src/main/java/org/apache/tomcat/jdbc/pool/DataSourceProxy.java.sav 2012-01-17 13:55:44.000000000 +0400
-+++ modules/jdbc-pool/src/main/java/org/apache/tomcat/jdbc/pool/DataSourceProxy.java 2012-01-22 00:44:22.299789107 +0400
-@@ -19,9 +19,11 @@ package org.apache.tomcat.jdbc.pool;
- import java.io.PrintWriter;
- import java.sql.Connection;
- import java.sql.SQLException;
-+import java.sql.SQLFeatureNotSupportedException;
- import java.util.Iterator;
- import java.util.Properties;
- import java.util.concurrent.Future;
-+import java.util.logging.Logger;
-
- import javax.sql.XAConnection;
-
-@@ -534,6 +536,14 @@ public class DataSourceProxy implements
- }
-
- /**
-+ * no-op
-+ * {@link javax.sql.DataSource#getParentLogger}
-+ */
-+ public Logger getParentLogger() throws SQLFeatureNotSupportedException {
-+ throw new SQLFeatureNotSupportedException();
-+ }
-+
-+ /**
- * no-op
- * {@link javax.sql.DataSource#getLogWriter}
- */
diff --git a/ci.fmf b/ci.fmf
new file mode 100644
index 0000000..c5aa0e0
--- /dev/null
+++ b/ci.fmf
@@ -0,0 +1 @@
+resultsdb-testcase: separate
diff --git a/el-api-OSGi-MANIFEST.MF b/el-api-OSGi-MANIFEST.MF
deleted file mode 100644
index 69b797f..0000000
--- a/el-api-OSGi-MANIFEST.MF
+++ /dev/null
@@ -1,13 +0,0 @@
-Manifest-Version: 1.0
-Export-Package: javax.el;version="2.2.0"
-Bundle-Vendor: %bundleProvider
-Bundle-ClassPath: .
-Bundle-Version: 2.2.0
-Bundle-Name: %bundleName
-Bundle-Localization: plugin
-Bundle-ManifestVersion: 2
-Bundle-SymbolicName: javax.el
-DynamicImport-Package: org.apache.el
-Bundle-RequiredExecutionEnvironment: J2SE-1.4,CDC-1.0/Foundation-1.0,J
- 2SE-1.3
-
diff --git a/gating.yaml b/gating.yaml
new file mode 100644
index 0000000..0553cb6
--- /dev/null
+++ b/gating.yaml
@@ -0,0 +1,20 @@
+--- !Policy
+product_versions:
+ - fedora-rawhide
+decision_contexts:
+ - bodhi_update_push_stable
+ - bodhi_update_push_testing
+subject_type: koji_build
+rules:
+ - !PassingTestCaseRule {test_case_name: fedora-ci.koji-build.rpmdeplint.functional}
+product_versions:
+ - fedora-*
+decision_contexts:
+ - bodhi_update_push_stable
+ - bodhi_update_push_testing
+subject_type: koji_build
+rules:
+ - !PassingTestCaseRule {test_case_name: fedora-ci.koji-build.rpminspect.static-analysis}
+ - !PassingTestCaseRule {test_case_name: fedora-ci.koji-build.installability.functional}
+ - !PassingTestCaseRule {test_case_name: fedora-ci.koji-build./plans/javapackages.functional}
+ - !PassingTestCaseRule {test_case_name: fedora-ci.koji-build./plans/smoke.functional}
diff --git a/jasper-OSGi-MANIFEST.MF b/jasper-OSGi-MANIFEST.MF
deleted file mode 100644
index 9a3d98a..0000000
--- a/jasper-OSGi-MANIFEST.MF
+++ /dev/null
@@ -1,40 +0,0 @@
-Manifest-Version: 1.0
-Export-Package: org.apache.jasper;version="7.0.21",org.apache.jasper.c
- ompiler;version="7.0.21",org.apache.jasper.compiler.tagplugin;version
- ="7.0.21",org.apache.jasper.resources;version="7.0.21",org.apache.jas
- per.runtime;version="7.0.21",org.apache.jasper.security;version="7.0.
- 19",org.apache.jasper.servlet;version="7.0.21",org.apache.jasper.tagp
- lugins.jstl;version="7.0.21",org.apache.jasper.tagplugins.jstl.core;v
- ersion="7.0.21",org.apache.jasper.util;version="7.0.21",org.apache.ja
- sper.xmlparser;version="7.0.21"
-Bundle-Vendor: %bundleProvider
-Bundle-ClassPath: .
-Bundle-Version: 7.0.21
-Bundle-Localization: plugin
-Bundle-Name: %bundleName
-Bundle-ManifestVersion: 2
-Bundle-SymbolicName: org.apache.jasper
-Import-Package: javax.servlet;version="[2.4.0, 3.0.0]",javax.servlet.h
- ttp;version="[2.4.0, 3.0.0]",javax.servlet.jsp;version="[2.0.0, 2.2.0
- ]",javax.servlet.jsp.el;version="[2.0.0, 2.2.0]",javax.servlet.jsp.re
- sources;version="[2.0.0, 2.2.0]",javax.servlet.jsp.tagext;version="[2
- .0.0, 2.2.0]",javax.servlet.resources;version="[2.4.0, 3.0.0]",javax.
- xml.parsers,org.apache.commons.el;version="[1.0.0,2.0.0)",org.apache.
- commons.logging;version="[1.0.0,2.0.0)",org.apache.tools.ant;resoluti
- on:=optional,org.apache.tools.ant.taskdefs;resolution:=optional,org.a
- pache.tools.ant.types;resolution:=optional,org.apache.tools.ant.util;
- resolution:=optional,org.w3c.dom,org.xml.sax,org.xml.sax.ext,org.xml.
- sax.helpers,org.apache.tomcat;version="7.0.21",org.apache.juli.loggin
- g;version="7.0.21",javax.el;version="2.2.0",org.eclipse.jdt.internal.
- compiler,org.eclipse.jdt.internal.compiler.parser,org.eclipse.jdt.int
- ernal.compiler.parser.diagnose,org.eclipse.jdt.internal.compiler.flow
- ,org.eclipse.jdt.internal.compiler.util,org.eclipse.jdt.internal.comp
- iler.impl,org.eclipse.jdt.internal.compiler.lookup,org.eclipse.jdt.in
- ternal.compiler.codegen,org.eclipse.jdt.internal.compiler.batch,org.e
- clipse.jdt.internal.compiler.classfmt,org.eclipse.jdt.internal.compil
- er.ast,org.eclipse.jdt.internal.compiler.problem,org.eclipse.jdt.inte
- rnal.compiler.env,org.eclipse.jdt.internal.core.util,org.eclipse.jdt.
- core.compiler
-Bundle-RequiredExecutionEnvironment: J2SE-1.4,CDC-1.0/Foundation-1.0,J
- 2SE-1.3
-
diff --git a/jasper-el-OSGi-MANIFEST.MF b/jasper-el-OSGi-MANIFEST.MF
deleted file mode 100644
index fd2879f..0000000
--- a/jasper-el-OSGi-MANIFEST.MF
+++ /dev/null
@@ -1,13 +0,0 @@
-Manifest-Version: 1.0
-Export-Package: org.apache.el;version="7.0.21"
-Bundle-Vendor: %bundleProvider
-Bundle-ClassPath: .
-Bundle-Version: 7.0.21
-Bundle-Name: %bundleName
-Bundle-Localization: plugin
-Bundle-ManifestVersion: 2
-Import-Package: javax.el;version="2.2"
-Bundle-SymbolicName: org.apache.el
-Bundle-RequiredExecutionEnvironment: J2SE-1.4,CDC-1.0/Foundation-1.0,J
- 2SE-1.3
-
diff --git a/jsp-api-OSGi-MANIFEST.MF b/jsp-api-OSGi-MANIFEST.MF
deleted file mode 100644
index 62bc00d..0000000
--- a/jsp-api-OSGi-MANIFEST.MF
+++ /dev/null
@@ -1,13 +0,0 @@
-Manifest-Version: 1.0
-Bundle-Vendor: %bundleProvider
-Bundle-Localization: plugin
-Bundle-RequiredExecutionEnvironment: CDC-1.0/Foundation-1.0,J2SE-1.3
-Bundle-Name: %bundleName
-Bundle-SymbolicName: javax.servlet.jsp
-Export-Package: javax.servlet.jsp; version=2.2,javax.servlet.jsp.el; v
- ersion=2.2,javax.servlet.jsp.resources; version=2.2,javax.servlet.jsp
- .tagext; version=2.2
-Bundle-Version: 2.2.0.v200806031607
-Bundle-ManifestVersion: 2
-Import-Package: javax.servlet; version=3.0,javax.servlet.http; version
- =3.0,javax.servlet.resources; version=3.0,javax.el;version="2.2.0"
diff --git a/module-start-up-parameters.conf b/module-start-up-parameters.conf
new file mode 100644
index 0000000..7f8652a
--- /dev/null
+++ b/module-start-up-parameters.conf
@@ -0,0 +1,8 @@
+# Add the module start-up parameters required by Tomcat
+JAVA_OPTS="$JAVA_OPTS --add-opens=java.base/java.lang=ALL-UNNAMED"
+JAVA_OPTS="$JAVA_OPTS --add-opens=java.base/java.io=ALL-UNNAMED"
+JAVA_OPTS="$JAVA_OPTS --add-opens=java.base/java.util=ALL-UNNAMED"
+JAVA_OPTS="$JAVA_OPTS --add-opens=java.base/java.util.concurrent=ALL-UNNAMED"
+JAVA_OPTS="$JAVA_OPTS --add-opens=java.rmi/sun.rmi.transport=ALL-UNNAMED"
+export JAVA_OPTS
+
diff --git a/plans/javapackages.fmf b/plans/javapackages.fmf
new file mode 100644
index 0000000..86bfcea
--- /dev/null
+++ b/plans/javapackages.fmf
@@ -0,0 +1,7 @@
+summary: Run javapackages-specific tests
+discover:
+ how: fmf
+ url: https://src.fedoraproject.org/tests/javapackages
+ ref: f42
+execute:
+ how: tmt
diff --git a/plans/smoke.fmf b/plans/smoke.fmf
new file mode 100644
index 0000000..039f41a
--- /dev/null
+++ b/plans/smoke.fmf
@@ -0,0 +1,5 @@
+discover:
+ how: fmf
+ url: https://src.fedoraproject.org/tests/tomcat
+execute:
+ how: tmt
diff --git a/rhbz-1857043.patch b/rhbz-1857043.patch
new file mode 100644
index 0000000..4028ee1
--- /dev/null
+++ b/rhbz-1857043.patch
@@ -0,0 +1,215 @@
+--- build.xml.orig 2024-08-02 18:14:43.000000000 +0300
++++ build.xml 2024-08-19 13:56:38.991730088 +0300
+@@ -1121,7 +1121,7 @@
+ filesDir="${tomcat.classes}"
+ filesId="files.annotations-api"
+ manifest="${tomcat.manifests}/annotations-api.jar.manifest"
+- addOSGi="true" />
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
++ addOSGi="false" />
+
+
+
+
+
++
+
+
+
diff --git a/tomcat-7.0-bootstrap-MANIFEST.MF.patch b/tomcat-10.1-bootstrap-MANIFEST.MF.patch
similarity index 100%
rename from tomcat-7.0-bootstrap-MANIFEST.MF.patch
rename to tomcat-10.1-bootstrap-MANIFEST.MF.patch
diff --git a/tomcat-10.1-catalina-policy.patch b/tomcat-10.1-catalina-policy.patch
new file mode 100644
index 0000000..3254968
--- /dev/null
+++ b/tomcat-10.1-catalina-policy.patch
@@ -0,0 +1,16 @@
+--- conf/catalina.policy.orig 2024-05-22 16:12:23.809886452 +0300
++++ conf/catalina.policy 2024-05-22 16:14:38.913939654 +0300
+@@ -55,6 +55,14 @@
+ permission java.security.AllPermission;
+ };
+
++// ========== RHEL SPECIFIC CODE PERMISSIONS =======================================
++
++// Allowing everything in /usr/share/java allows too many unknowns to be permitted
++// Specifying the individual jars that tomcat needs to function with the security manager
++// is the safest way forward.
++grant codeBase "file:/usr/share/java/ecj/ecj.jar" {
++ permission java.security.AllPermission;
++};
+
+ // ========== CATALINA CODE PERMISSIONS =======================================
diff --git a/tomcat-7.0-digest.script b/tomcat-10.1-digest.script
similarity index 88%
rename from tomcat-7.0-digest.script
rename to tomcat-10.1-digest.script
index 2ff7e64..ce4aa0f 100644
--- a/tomcat-7.0-digest.script
+++ b/tomcat-10.1-digest.script
@@ -34,7 +34,7 @@ export CLASSPATH
MAIN_CLASS="org.apache.catalina.startup.Tool"
BASE_FLAGS="-Dcatalina.home=\"$CATALINA_HOME\""
BASE_OPTIONS=""
-BASE_JARS="commons-daemon tomcat/catalina servlet"
+BASE_JARS="commons-daemon tomcat/catalina servlet tomcat/tomcat-util tomcat/tomcat-coyote tomcat/tomcat-api tomcat/tomcat-util-scan"
# Set parameters
set_classpath $BASE_JARS
diff --git a/tomcat-7.0-tomcat-users-webapp.patch b/tomcat-10.1-tomcat-users-webapp.patch
similarity index 59%
rename from tomcat-7.0-tomcat-users-webapp.patch
rename to tomcat-10.1-tomcat-users-webapp.patch
index 9f05e37..85b8b9b 100644
--- a/tomcat-7.0-tomcat-users-webapp.patch
+++ b/tomcat-10.1-tomcat-users-webapp.patch
@@ -1,8 +1,8 @@
--- conf/tomcat-users.xml~ 2008-01-28 17:41:06.000000000 -0500
+++ conf/tomcat-users.xml 2008-03-07 19:40:07.000000000 -0500
-@@ -23,4 +23,14 @@
-
-
+@@ -53,4 +53,14 @@
+
+
-->
+
+
@@ -13,5 +13,5 @@
+
+
+
-+
++
diff --git a/tomcat-7.0-tool-wrapper.script b/tomcat-10.1-tool-wrapper.script
similarity index 88%
rename from tomcat-7.0-tool-wrapper.script
rename to tomcat-10.1-tool-wrapper.script
index 2640ce2..949d46d 100644
--- a/tomcat-7.0-tool-wrapper.script
+++ b/tomcat-10.1-tool-wrapper.script
@@ -34,7 +34,7 @@ export CLASSPATH
MAIN_CLASS="org.apache.catalina.startup.Tool"
BASE_OPTIONS=""
BASE_FLAGS="-Dcatalina.home=\"$CATALINA_HOME\""
-BASE_JARS="commons-daemon tomcat/catalina servlet"
+BASE_JARS="commons-daemon tomcat/catalina servlet tomcat/tomcat-util tomcat/tomcat-coyote tomcat/tomcat-api tomcat/tomcat-util-scan"
# Set parameters
set_classpath $BASE_JARS
diff --git a/tomcat-7.0.conf b/tomcat-10.1.conf
similarity index 78%
rename from tomcat-7.0.conf
rename to tomcat-10.1.conf
index 03119b7..c83305a 100644
--- a/tomcat-7.0.conf
+++ b/tomcat-10.1.conf
@@ -1,6 +1,7 @@
# System-wide configuration file for tomcat services
# This will be loaded by systemd as an environment file,
-# so please keep the syntax.
+# so please keep the syntax. For shell expansion support
+# place your custom files as /etc/tomcat/conf.d/*.conf
#
# There are 2 "classes" of startup behavior in this package.
# The old one, the default service named tomcat.service.
@@ -27,22 +28,15 @@ CATALINA_HOME="@@@TCHOME@@@"
# System-wide tmp
CATALINA_TMPDIR="/var/cache/tomcat/temp"
-# You can pass some parameters to java here if you wish to
-#JAVA_OPTS="-Xminf0.1 -Xmaxf0.3"
-
-# Use JAVA_OPTS to set java.library.path for libtcnative.so
-#JAVA_OPTS="-Djava.library.path=/usr/lib"
-
# You can change your tomcat locale here
#LANG="en_US"
# Run tomcat under the Java Security Manager
SECURITY_MANAGER="false"
-# Time to wait in seconds, before killing process
-# TODO(stingray): does nothing, fix.
-# SHUTDOWN_WAIT="30"
-
# If you wish to further customize your tomcat environment,
# put your own definitions here
# (i.e. LD_LIBRARY_PATH for some jdbc drivers)
+
+# You can also pass parameters to Java here by defining JAVA_OPTS variable
+# (e.g. JAVA_OPTS="-Xminf0.1 -Xmaxf0.3")
diff --git a/tomcat-10.1.logrotate b/tomcat-10.1.logrotate
new file mode 100644
index 0000000..082092a
--- /dev/null
+++ b/tomcat-10.1.logrotate
@@ -0,0 +1,11 @@
+# This is an example config only and is disabled by default
+# If you wish to use it, you'll need to update /etc/tomcat/logging.properties
+# to prevent catalina*.log from being rotated by Tomcat
+@@@TCLOG@@@/catalina*.log {
+ copytruncate
+ weekly
+ rotate 52
+ compress
+ missingok
+ create 0644 tomcat tomcat
+}
diff --git a/tomcat-7.0.service b/tomcat-10.1.service
similarity index 89%
rename from tomcat-7.0.service
rename to tomcat-10.1.service
index 103d464..832e7c6 100644
--- a/tomcat-7.0.service
+++ b/tomcat-10.1.service
@@ -13,11 +13,8 @@ EnvironmentFile=/etc/tomcat/tomcat.conf
Environment="NAME="
EnvironmentFile=-/etc/sysconfig/tomcat
ExecStart=/usr/libexec/tomcat/server start
-ExecStop=/usr/libexec/tomcat/server stop
SuccessExitStatus=143
User=tomcat
-Group=tomcat
-
[Install]
WantedBy=multi-user.target
diff --git a/tomcat-7.0.sysconfig b/tomcat-10.1.sysconfig
similarity index 100%
rename from tomcat-7.0.sysconfig
rename to tomcat-10.1.sysconfig
diff --git a/tomcat-7.0.wrapper b/tomcat-10.1.wrapper
similarity index 100%
rename from tomcat-7.0.wrapper
rename to tomcat-10.1.wrapper
diff --git a/tomcat-7.0-jsvc.service b/tomcat-7.0-jsvc.service
deleted file mode 100644
index 3792cef..0000000
--- a/tomcat-7.0-jsvc.service
+++ /dev/null
@@ -1,19 +0,0 @@
-# Systemd unit file for tomcat
-#
-# To create clones of this service:
-# 1) By default SERVICE_NAME=tomcat. When cloned, the value must be defined
-# before tomcat-sysd is called.
-# 2) Create /etc/sysconfig/${SERVICE_NAME} from /etc/sysconfig/tomcat
-# to override tomcat defaults
-
-[Unit]
-Description=Apache Tomcat Web Application Container JSVC wrapper
-After=syslog.target network.target
-
-[Service]
-Type=forking
-ExecStart=/usr/sbin/tomcat-jsvc-sysd start
-ExecStop=/usr/sbin/tomcat-jsvc-sysd stop
-
-[Install]
-WantedBy=multi-user.target
diff --git a/tomcat-7.0-jsvc.wrapper b/tomcat-7.0-jsvc.wrapper
deleted file mode 100644
index 56fcc09..0000000
--- a/tomcat-7.0-jsvc.wrapper
+++ /dev/null
@@ -1,83 +0,0 @@
-#!/bin/bash
-
-if [ -r /usr/share/java-utils/java-functions ]; then
- . /usr/share/java-utils/java-functions
-else
- echo "Can't read Java functions library, aborting"
- exit 1
-fi
-
-# Get the tomcat config (use this for environment specific settings)
-#if [ -z "${TOMCAT_CFG}" ]; then
-# TOMCAT_CFG="/etc/tomcat/tomcat.conf"
-#fi
-
-#if [ -r "$TOMCAT_CFG" ]; then
-# . $TOMCAT_CFG
-#fi
-
-set_javacmd
-
-# CLASSPATH munging
-if [ -n "$JSSE_HOME" ]; then
- CLASSPATH="${CLASSPATH}:$(build-classpath jcert jnet jsse 2>/dev/null)"
-fi
-CLASSPATH="${CLASSPATH}:${CATALINA_HOME}/bin/bootstrap.jar"
-CLASSPATH="${CLASSPATH}:${CATALINA_HOME}/bin/tomcat-juli.jar"
-CLASSPATH="${CLASSPATH}:$(build-classpath commons-daemon 2>/dev/null)"
-
-# if jsvc installed and USE_JSVC=true
-# then use jsvc instead of calling java directly
-if [ -x /usr/bin/jsvc ]; then
- JAVACMD="/usr/bin/jsvc -nodetach -user ${TOMCAT_USER} -outfile ${CATALINA_BASE}/logs/catalina.out -errfile ${CATALINA_BASE}/logs/catalina.out"
- if [ "$1" = "stop" ]; then
- JAVACMD="${JAVACMD} -stop"
- fi
-fi
-
-if [ "$1" = "start" ]; then
- ${JAVACMD} $JAVA_OPTS $CATALINA_OPTS \
- -classpath "$CLASSPATH" \
- -Dcatalina.base="$CATALINA_BASE" \
- -Dcatalina.home="$CATALINA_HOME" \
- -Djava.endorsed.dirs="$JAVA_ENDORSED_DIRS" \
- -Djava.io.tmpdir="$CATALINA_TMPDIR" \
- -Djava.util.logging.config.file="${CATALINA_BASE}/conf/logging.properties" \
- -Djava.util.logging.manager="org.apache.juli.ClassLoaderLogManager" \
- org.apache.catalina.startup.Bootstrap start \
- >> ${CATALINA_BASE}/logs/catalina.out 2>&1 &
- if [ ! -z "$CATALINA_PID" ]; then
- echo $! > $CATALINA_PID
- fi
-elif [ "$1" = "start-security" ]; then
- ${JAVACMD} $JAVA_OPTS $CATALINA_OPTS \
- -classpath "$CLASSPATH" \
- -Dcatalina.base="$CATALINA_BASE" \
- -Dcatalina.home="$CATALINA_HOME" \
- -Djava.endorsed.dirs="$JAVA_ENDORSED_DIRS" \
- -Djava.io.tmpdir="$CATALINA_TMPDIR" \
- -Djava.security.manager \
- -Djava.security.policy=="${CATALINA_BASE}/conf/catalina.policy" \
- -Djava.util.logging.config.file="${CATALINA_BASE}/conf/logging.properties" \
- -Djava.util.logging.manager="org.apache.juli.ClassLoaderLogManager" \
- org.apache.catalina.startup.Bootstrap start \
- >> ${CATALINA_BASE}/logs/catalina.out 2>&1 &
- if [ ! -z "$CATALINA_PID" ]; then
- echo $! > $CATALINA_PID
- fi
-elif [ "$1" = "stop" ]; then
- ${JAVACMD} $JAVA_OPTS \
- -classpath "$CLASSPATH" \
- -Dcatalina.base="$CATALINA_BASE" \
- -Dcatalina.home="$CATALINA_HOME" \
- -Djava.endorsed.dirs="$JAVA_ENDORSED_DIRS" \
- -Djava.io.tmpdir="$CATALINA_TMPDIR" \
- org.apache.catalina.startup.Bootstrap stop \
- >> ${CATALINA_BASE}/logs/catalina.out 2>&1
-elif [ "$1" = "version" ]; then
- ${JAVACMD} -classpath ${CATALINA_HOME}/lib/catalina.jar \
- org.apache.catalina.util.ServerInfo
-else
- echo "Usage: $0 {start|start-security|stop|version}"
- exit 1
-fi
diff --git a/tomcat-7.0-log4j.properties b/tomcat-7.0-log4j.properties
deleted file mode 100644
index dfc2309..0000000
--- a/tomcat-7.0-log4j.properties
+++ /dev/null
@@ -1,11 +0,0 @@
-log4j.rootLogger=debug, R
-log4j.appender.R=org.apache.log4j.RollingFileAppender
-log4j.appender.R.File=${catalina.base}/logs/tomcat.log
-log4j.appender.R.MaxFileSize=10MB
-log4j.appender.R.MaxBackupIndex=10
-log4j.appender.R.layout=org.apache.log4j.PatternLayout
-log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n
-log4j.logger.org.apache.catalina=DEBUG, R
-log4j.logger.org.apache.catalina.core.ContainerBase.[Catalina].[localhost]=DEBUG, R
-log4j.logger.org.apache.catalina.core=DEBUG, R
-log4j.logger.org.apache.catalina.session=DEBUG, R
diff --git a/tomcat-7.0-tomcat-jsvc-sysd b/tomcat-7.0-tomcat-jsvc-sysd
deleted file mode 100644
index 9134d5b..0000000
--- a/tomcat-7.0-tomcat-jsvc-sysd
+++ /dev/null
@@ -1,113 +0,0 @@
-#!/bin/bash
-#
-# This script provides systemd activation of the tomcat service
-# To create clones of this service:
-# 1) SERVICE_NAME must be defined before calling this script
-# 2) Create /etc/sysconfig/${SERVICE_NAME} from /etc/sysconfig/tomcat
-# to override tomcat defaults
-
-# SERVICE_NAME is a required value only if the service name is
-# different from 'tomcat'
-#
-NAME="${SERVICE_NAME:-tomcat}"
-
-#I'll bet this isn't required.
-# unset ISBOOT
-
-# For SELinux we need to use 'runuser' not 'su'
-if [ -x "/sbin/runuser" ]; then
- SU="/sbin/runuser -s /bin/sh"
-else
- SU="/bin/su -s /bin/sh"
-fi
-
-# Path to the tomcat launch script
-TOMCAT_SCRIPT="/usr/sbin/tomcat-jsvc"
-
-# Define the tomcat username
-TOMCAT_USER="${TOMCAT_USER:-tomcat}"
-
-# TOMCAT_LOG should be different from catalina.out.
-# Usually the below config is all that is necessary
-TOMCAT_LOG=/var/log/${NAME}/${NAME}-sysd.log
-
-# Get the tomcat config (use this for environment specific settings)
-TOMCAT_CFG="/etc/tomcat/tomcat.conf"
-if [ -r "$TOMCAT_CFG" ]; then
- . $TOMCAT_CFG
-fi
-
-# Get instance specific config file
-if [ -r "/etc/sysconfig/${NAME}" ]; then
- . /etc/sysconfig/${NAME}
-fi
-
-function parseOptions() {
- options=""
- options="$options $(
- awk '!/^#/ && !/^$/ { ORS=" "; print "export ", $0, ";" }' \
- $TOMCAT_CFG
- )"
- if [ -r "/etc/sysconfig/${NAME}" ]; then
- options="$options $(
- awk '!/^#/ && !/^$/ { ORS=" ";
- print "export ", $0, ";" }' \
- /etc/sysconfig/${NAME}
- )"
- fi
- TOMCAT_SCRIPT="$options ${TOMCAT_SCRIPT}"
-}
-
-# See how we were called.
-function start() {
- # fix permissions on the log and pid files
- export CATALINA_PID="/var/run/${NAME}.pid"
- touch $CATALINA_PID 2>&1
- if [ "$?" -eq "0" ]; then
- chown ${TOMCAT_USER}:${TOMCAT_USER} $CATALINA_PID
- fi
-
- touch $TOMCAT_LOG 2>&1
- if [ "$?" -eq "0" ]; then
- chown ${TOMCAT_USER}:${TOMCAT_USER} $TOMCAT_LOG
- fi
-
- # if jsvc installed and USE_JSVC=true
- # then start as root and use jsvc to drop privileges
- if [ -x /usr/bin/jsvc ]; then
- TOMCAT_USER="root"
- fi
-
- parseOptions
- if [ "$SECURITY_MANAGER" = "true" ]; then
- $SU - $TOMCAT_USER -c "${TOMCAT_SCRIPT} start-security" >> $TOMCAT_LOG 2>&1
- else
- $SU - $TOMCAT_USER -c "${TOMCAT_SCRIPT} start" >> $TOMCAT_LOG 2>&1
- fi
-}
-
-function stop() {
- # if jsvc installed and USE_JSVC=true
- # then start as root and use jsvc to drop privileges
- if [ -x /usr/bin/jsvc ]; then
- TOMCAT_USER="root"
- fi
-
- parseOptions
- $SU - $TOMCAT_USER -c "${TOMCAT_SCRIPT} stop" >> $TOMCAT_LOG 2>&1
-}
-
-# See how we were called.
-case "$1" in
- start)
- start
- ;;
- stop)
- stop
- ;;
- restart)
- stop
- start
- ;;
-esac
-
diff --git a/tomcat-7.0.logrotate b/tomcat-7.0.logrotate
deleted file mode 100644
index a87b4c0..0000000
--- a/tomcat-7.0.logrotate
+++ /dev/null
@@ -1,8 +0,0 @@
-@@@TCLOG@@@/catalina.out {
- copytruncate
- weekly
- rotate 52
- compress
- missingok
- create 0644 tomcat tomcat
-}
diff --git a/tomcat-api-OSGi-MANIFEST.MF b/tomcat-api-OSGi-MANIFEST.MF
deleted file mode 100644
index 3522c72..0000000
--- a/tomcat-api-OSGi-MANIFEST.MF
+++ /dev/null
@@ -1,12 +0,0 @@
-Manifest-Version: 1.0
-Export-Package: org.apache.tomcat;version="7.0.21"
-Bundle-Vendor: %bundleProvider
-Bundle-ClassPath: .
-Bundle-Version: 7.0.21
-Bundle-Name: %bundleName
-Bundle-Localization: plugin
-Bundle-ManifestVersion: 2
-Bundle-SymbolicName: org.apache.tomcat
-Bundle-RequiredExecutionEnvironment: J2SE-1.4,CDC-1.0/Foundation-1.0,J
- 2SE-1.3
-
diff --git a/tomcat-build.patch b/tomcat-build.patch
new file mode 100644
index 0000000..cdf73ef
--- /dev/null
+++ b/tomcat-build.patch
@@ -0,0 +1,19 @@
+diff -up ./res/bnd/build-defaults.bnd.orig ./res/bnd/build-defaults.bnd
+--- res/bnd/build-defaults.bnd.orig 2023-10-16 11:23:04.752754202 +0800
++++ res/bnd/build-defaults.bnd 2023-10-16 11:23:29.931876910 +0800
+@@ -13,7 +13,7 @@
+ # See the License for the specific language governing permissions and
+ # limitations under the License.
+
+-Bundle-Version: ${version_cleanup;${version}}
++Bundle-Version: ${version}
+ Bundle-License: https://www.apache.org/licenses/LICENSE-2.0.txt
+
+ Specification-Title: Apache Tomcat
+@@ -36,4 +36,4 @@ X-Compile-Target-JDK: ${compile.release}
+
+ -removeheaders: DSTAMP,TODAY,TSTAMP
+
+-module.name: org.apache.${replace;${Bundle-Name};-;.}
+\ No newline at end of file
++module.name: org.apache.${replace;${Bundle-Name};-;.}
diff --git a/tomcat-functions b/tomcat-functions
new file mode 100644
index 0000000..1187653
--- /dev/null
+++ b/tomcat-functions
@@ -0,0 +1,21 @@
+#!/bin/bash
+
+if [ -r /usr/share/java-utils/java-functions ]; then
+ . /usr/share/java-utils/java-functions
+else
+ echo "Can't read Java functions library, aborting"
+ exit 1
+fi
+
+_save_function() {
+ local ORIG_FUNC=$(declare -f $1)
+ local NEWNAME_FUNC="$2${ORIG_FUNC#$1}"
+ eval "$NEWNAME_FUNC"
+}
+
+_save_function run run_java
+
+run() {
+ run_java $@
+}
+
diff --git a/tomcat-juli-OSGi-MANIFEST.MF b/tomcat-juli-OSGi-MANIFEST.MF
deleted file mode 100644
index cbb5674..0000000
--- a/tomcat-juli-OSGi-MANIFEST.MF
+++ /dev/null
@@ -1,13 +0,0 @@
-Manifest-Version: 1.0
-Export-Package: org.apache.juli;version="7.0.21",org.apache.juli.loggi
- ng;version="7.0.21"
-Bundle-Vendor: %bundleProvider
-Bundle-ClassPath: .
-Bundle-Version: 7.0.21
-Bundle-Name: %bundleName
-Bundle-Localization: plugin
-Bundle-ManifestVersion: 2
-Bundle-SymbolicName: org.apache.juli
-Bundle-RequiredExecutionEnvironment: J2SE-1.4,CDC-1.0/Foundation-1.0,J
- 2SE-1.3
-
diff --git a/tomcat-named.service b/tomcat-named.service
index 9bbcb17..b6cd8bd 100644
--- a/tomcat-named.service
+++ b/tomcat-named.service
@@ -13,14 +13,12 @@ After=syslog.target network.target
[Service]
Type=simple
EnvironmentFile=/etc/tomcat/tomcat.conf
-Environment="NAME=%I"
-EnvironmentFile=-/etc/sysconfig/tomcat@%I
+Environment="NAME=%i"
+EnvironmentFile=-/etc/sysconfig/tomcat@%i
ExecStart=/usr/libexec/tomcat/server start
ExecStop=/usr/libexec/tomcat/server stop
SuccessExitStatus=143
User=tomcat
-Group=tomcat
[Install]
WantedBy=multi-user.target
-
diff --git a/tomcat-preamble b/tomcat-preamble
index 9627522..1271dca 100644
--- a/tomcat-preamble
+++ b/tomcat-preamble
@@ -1,11 +1,6 @@
#!/bin/bash
-if [ -r /usr/share/java-utils/java-functions ]; then
- . /usr/share/java-utils/java-functions
-else
- echo "Can't read Java functions library, aborting"
- exit 1
-fi
+. /usr/libexec/tomcat/functions
# Get the tomcat config (use this for environment specific settings)
@@ -16,6 +11,14 @@ if [ -z "${TOMCAT_CFG_LOADED}" ]; then
. $TOMCAT_CFG
fi
+if [ -d "${TOMCAT_CONFD=/etc/tomcat/conf.d}" ]; then
+ for file in ${TOMCAT_CONFD}/*.conf ; do
+ if [ -f "$file" ] ; then
+ . "$file"
+ fi
+ done
+fi
+
if [ -z "$CATALINA_BASE" ]; then
if [ -n "$NAME" ]; then
if [ -z "$TOMCATS_BASE" ]; then
@@ -26,7 +29,6 @@ if [ -z "$CATALINA_BASE" ]; then
CATALINA_BASE="${CATALINA_HOME}"
fi
fi
-
VERBOSE=1
set_javacmd
cd ${CATALINA_HOME}
diff --git a/tomcat-server b/tomcat-server
index bd55999..17ae385 100644
--- a/tomcat-server
+++ b/tomcat-server
@@ -4,7 +4,7 @@
MAIN_CLASS=org.apache.catalina.startup.Bootstrap
-FLAGS="$JAVA_OPTS $CATALINA_OPTS"
+FLAGS="$JAVA_OPTS"
OPTIONS="-Dcatalina.base=$CATALINA_BASE \
-Dcatalina.home=$CATALINA_HOME \
-Djava.endorsed.dirs=$JAVA_ENDORSED_DIRS \
@@ -13,6 +13,7 @@ OPTIONS="-Dcatalina.base=$CATALINA_BASE \
-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager"
if [ "$1" = "start" ] ; then
+ FLAGS="${FLAGS} $CATALINA_OPTS"
if [ "${SECURITY_MANAGER}" = "true" ] ; then
OPTIONS="${OPTIONS} \
-Djava.security.manager \
diff --git a/tomcat.spec b/tomcat.spec
index fb9ef77..77901bc 100644
--- a/tomcat.spec
+++ b/tomcat.spec
@@ -28,16 +28,19 @@
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
-%global jspspec 2.2
-%global major_version 7
-%global minor_version 0
-%global micro_version 47
+%global jspspec 3.1
+%global major_version 10
+%global minor_version 1
+%global micro_version 46
%global packdname apache-tomcat-%{version}-src
-%global servletspec 3.0
-%global elspec 2.2
-%global tcuid 91
+%global servletspec 6.0
+%global elspec 5.0
+%global tcuid 53
+# Recommended version is specified in java/org/apache/catalina/core/AprLifecycleListener.java
+%global native_version 2.0.8
-# FHS 2.3 compliant tree structure - http://www.pathname.com/fhs/2.3/
+
+# FHS 3.0 compliant tree structure - http://refspecs.linuxfoundation.org/FHS_3.0/fhs/index.html
%global basedir %{_var}/lib/%{name}
%global appdir %{basedir}/webapps
%global homedir %{_datadir}/%{name}
@@ -48,76 +51,63 @@
%global cachedir %{_var}/cache/%{name}
%global tempdir %{cachedir}/temp
%global workdir %{cachedir}/work
-%global _initrddir %{_sysconfdir}/init.d
-%global _systemddir /lib/systemd/system
Name: tomcat
-Epoch: 0
+Epoch: 1
Version: %{major_version}.%{minor_version}.%{micro_version}
-Release: 3%{?dist}
+Release: %autorelease
Summary: Apache Servlet/JSP Engine, RI for Servlet %{servletspec}/JSP %{jspspec} API
-Group: System Environment/Daemons
-License: ASL 2.0
+# Automatically converted from old format: ASL 2.0 - review is highly recommended.
+License: Apache-2.0
URL: http://tomcat.apache.org/
Source0: http://www.apache.org/dist/tomcat/tomcat-%{major_version}/v%{version}/src/%{packdname}.tar.gz
Source1: %{name}-%{major_version}.%{minor_version}.conf
-Source3: %{name}-%{major_version}.%{minor_version}.sysconfig
-Source4: %{name}-%{major_version}.%{minor_version}.wrapper
-Source5: %{name}-%{major_version}.%{minor_version}.logrotate
-Source6: %{name}-%{major_version}.%{minor_version}-digest.script
-Source7: %{name}-%{major_version}.%{minor_version}-tool-wrapper.script
-Source8: servlet-api-OSGi-MANIFEST.MF
-Source9: jsp-api-OSGi-MANIFEST.MF
-Source10: %{name}-%{major_version}.%{minor_version}-log4j.properties
-Source11: %{name}-%{major_version}.%{minor_version}.service
-Source12: el-api-OSGi-MANIFEST.MF
-Source13: jasper-el-OSGi-MANIFEST.MF
-Source14: jasper-OSGi-MANIFEST.MF
-Source15: tomcat-api-OSGi-MANIFEST.MF
-Source16: tomcat-juli-OSGi-MANIFEST.MF
-Source18: %{name}-%{major_version}.%{minor_version}-tomcat-jsvc-sysd
-Source19: %{name}-%{major_version}.%{minor_version}-jsvc.wrapper
-Source20: %{name}-%{major_version}.%{minor_version}-jsvc.service
-Source30: tomcat-preamble
-Source31: tomcat-server
-Source32: tomcat-named.service
+Source2: %{name}-%{major_version}.%{minor_version}.sysconfig
+Source3: %{name}-%{major_version}.%{minor_version}.wrapper
+Source4: %{name}-%{major_version}.%{minor_version}.logrotate
+Source5: %{name}-%{major_version}.%{minor_version}-digest.script
+Source6: %{name}-%{major_version}.%{minor_version}-tool-wrapper.script
+Source7: %{name}-%{major_version}.%{minor_version}.service
+Source8: %{name}-functions
+Source9: %{name}-preamble
+Source10: %{name}-server
+Source11: %{name}-named.service
+Source12: module-start-up-parameters.conf
Patch0: %{name}-%{major_version}.%{minor_version}-bootstrap-MANIFEST.MF.patch
Patch1: %{name}-%{major_version}.%{minor_version}-tomcat-users-webapp.patch
+Patch2: %{name}-build.patch
+Patch3: %{name}-%{major_version}.%{minor_version}-catalina-policy.patch
+Patch4: %{name}-%{major_version}.%{minor_version}-bnd-annotation.patch
+Patch5: %{name}-%{major_version}.%{minor_version}-JDTCompiler.patch
+Patch6: rhbz-1857043.patch
BuildArch: noarch
+ExclusiveArch: %{java_arches} noarch
-BuildRequires: ant
-BuildRequires: ecj >= 1:4.2.1
+BuildRequires: ant-openjdk25 >= 1.10.2
+BuildRequires: ecj >= 4.20
BuildRequires: findutils
-BuildRequires: apache-commons-collections
-BuildRequires: apache-commons-daemon
-BuildRequires: apache-commons-dbcp
-BuildRequires: apache-commons-pool
-BuildRequires: jakarta-taglibs-standard
-BuildRequires: java-devel >= 1:1.6.0
-BuildRequires: jpackage-utils >= 0:1.7.0
-BuildRequires: junit
-BuildRequires: log4j
-BuildRequires: geronimo-jaxrpc
-BuildRequires: wsdl4j
-BuildRequires: systemd-units
-Requires: apache-commons-daemon
-Requires: apache-commons-logging
-Requires: apache-commons-collections
-Requires: apache-commons-dbcp
-Requires: apache-commons-pool
-Requires: java >= 1:1.6.0
-Requires: jpackage-utils
-Requires: procps
+BuildRequires: java-25-devel
+BuildRequires: javapackages-local-openjdk25
+BuildRequires: aqute-bnd
+BuildRequires: aqute-bndlib
+BuildRequires: systemd
+BuildRequires: tomcat-jakartaee-migration
+
+Requires: (java-25-headless or java-25)
+Requires: javapackages-tools
Requires: %{name}-lib = %{epoch}:%{version}-%{release}
-Requires(pre): shadow-utils
-Requires(post): chkconfig
-Requires(preun): chkconfig
-Requires(post): systemd-units
-Requires(preun): systemd-units
-Requires(postun): systemd-units
+%if 0%{?fedora} || 0%{?rhel} > 7
+Recommends: tomcat-native >= %{native_version}
+%endif
+Requires(post): systemd
+Requires(preun): systemd
+Requires(postun): systemd
+
+# added after log4j sub-package was removed
+Provides: %{name}-log4j = %{epoch}:%{version}-%{release}
%description
Tomcat is the servlet container that is used in the official Reference
@@ -130,7 +120,6 @@ released under the Apache Software License version 2.0. Tomcat is intended
to be a collaboration of the best-of-breed developers from around the world.
%package admin-webapps
-Group: Applications/System
Summary: The host-manager and manager web applications for Apache Tomcat
Requires: %{name} = %{epoch}:%{version}-%{release}
@@ -138,91 +127,60 @@ Requires: %{name} = %{epoch}:%{version}-%{release}
The host-manager and manager web applications for Apache Tomcat.
%package docs-webapp
-Group: Applications/Text
Summary: The docs web application for Apache Tomcat
Requires: %{name} = %{epoch}:%{version}-%{release}
%description docs-webapp
The docs web application for Apache Tomcat.
-%package javadoc
-Group: Documentation
-Summary: Javadoc generated documentation for Apache Tomcat
-Requires: jpackage-utils
-
-%description javadoc
-Javadoc generated documentation for Apache Tomcat.
-
-%package jsvc
-Group: System Environment/Daemons
-Summary: Apache jsvc wrapper for Apache Tomcat as separate service
-Requires: %{name} = %{epoch}:%{version}-%{release}
-Requires: apache-commons-daemon-jsvc
-
-%description jsvc
-Systemd service and wrapper scripts to start tomcat with jsvc,
-which allows tomcat to perform some privileged operations
-(e.g. bind to a port < 1024) and then switch identity to a non-privileged user.
-
%package jsp-%{jspspec}-api
-Group: Development/Libraries
-Summary: Apache Tomcat JSP API implementation classes
+Summary: Apache Tomcat JavaServer Pages v%{jspspec} API Implementation Classes
Provides: jsp = %{jspspec}
-Provides: jsp22
Requires: %{name}-servlet-%{servletspec}-api = %{epoch}:%{version}-%{release}
-Requires(post): chkconfig
-Requires(postun): chkconfig
+Requires: %{name}-el-%{elspec}-api = %{epoch}:%{version}-%{release}
+Obsoletes: %{name}-jsp-2.3-api < 1:9.1
+Provides: %{name}-jsp-2.3-api = %{?epoch:%{epoch}:}%{version}-%{release}
+
%description jsp-%{jspspec}-api
-Apache Tomcat JSP API implementation classes.
-
+Apache Tomcat JSP API Implementation Classes.
%package lib
-Group: Development/Libraries
Summary: Libraries needed to run the Tomcat Web container
Requires: %{name}-jsp-%{jspspec}-api = %{epoch}:%{version}-%{release}
Requires: %{name}-servlet-%{servletspec}-api = %{epoch}:%{version}-%{release}
Requires: %{name}-el-%{elspec}-api = %{epoch}:%{version}-%{release}
-Requires: ecj >= 1:4.2.1
-Requires: apache-commons-collections
-Requires: apache-commons-dbcp
-Requires: apache-commons-pool
+Requires: ecj >= 4.20
+Recommends: tomcat-jakartaee-migration
Requires(preun): coreutils
%description lib
Libraries needed to run the Tomcat Web container.
%package servlet-%{servletspec}-api
-Group: Development/Libraries
-Summary: Apache Tomcat Servlet API implementation classes
+Summary: Apache Tomcat Java Servlet v%{servletspec} API Implementation Classes
Provides: servlet = %{servletspec}
-Provides: servlet6
-Provides: servlet3
-Requires(post): chkconfig
-Requires(postun): chkconfig
+Obsoletes: %{name}-servlet-4.0-api < 1:9.1
+Provides: %{name}-servlet-4.0-api = %{?epoch:%{epoch}:}%{version}-%{release}
%description servlet-%{servletspec}-api
-Apache Tomcat Servlet API implementation classes.
+Apache Tomcat Servlet API Implementation Classes.
%package el-%{elspec}-api
-Group: Development/Libraries
-Summary: Expression Language v1.0 API
-Provides: el_1_0_api = %{epoch}:%{version}-%{release}
+Summary: Apache Tomcat Expression Language v%{elspec} API Implementation Classes
Provides: el_api = %{elspec}
-Requires(post): chkconfig
-Requires(postun): chkconfig
+Obsoletes: %{name}-el-3.0-api < 1:9.1
+Provides: %{name}-el-3.0-api = %{?epoch:%{epoch}:}%{version}-%{release}
%description el-%{elspec}-api
-Expression Language 1.0.
+Apache Tomcat EL API Implementation Classes.
%package webapps
-Group: Applications/Internet
-Summary: The ROOT and examples web applications for Apache Tomcat
+Summary: The ROOT web application for Apache Tomcat
Requires: %{name} = %{epoch}:%{version}-%{release}
-Requires: jakarta-taglibs-standard >= 0:1.1
%description webapps
-The ROOT and examples web applications for Apache Tomcat.
+The ROOT web application for Apache Tomcat.
%prep
%setup -q -n %{packdname}
@@ -230,99 +188,76 @@ The ROOT and examples web applications for Apache Tomcat.
find . -type f \( -name "*.bat" -o -name "*.class" -o -name Thumbs.db -o -name "*.gz" -o \
-name "*.jar" -o -name "*.war" -o -name "*.zip" \) -delete
-%patch0 -p0
-%patch1 -p0
-%{__ln_s} $(build-classpath jakarta-taglibs-core) webapps/examples/WEB-INF/lib/jstl.jar
-%{__ln_s} $(build-classpath jakarta-taglibs-standard) webapps/examples/WEB-INF/lib/standard.jar
+%patch 0 -p0
+%patch 1 -p0
+%patch 2 -p0
+%patch 3 -p0
+%patch 4 -p0
+%patch 5 -p0
+%patch 6 -p0
+
+# Remove webservices naming resources as it's generally unused
+%{__rm} -rf java/org/apache/naming/factory/webservices
+
+# Configure maven files
+%mvn_package ":tomcat-el-api" tomcat-el-api
+%mvn_alias "org.apache.tomcat:tomcat-el-api" "jakarta.servlet:jakarta.servlet-api"
+%mvn_package ":tomcat-jsp-api" tomcat-jsp-api
+%mvn_alias "org.apache.tomcat:tomcat-jsp-api" "jakarta.servlet:jakarta.servlet.jsp"
+%mvn_package ":tomcat-servlet-api" tomcat-servlet-api
+
+# Create a sysusers.d config file
+cat >tomcat.sysusers.conf < ${RPM_BUILD_ROOT}%{confdir}/conf.d/README
%{__install} -d -m 0755 ${RPM_BUILD_ROOT}%{libdir}
%{__install} -d -m 0775 ${RPM_BUILD_ROOT}%{logdir}
-/bin/touch ${RPM_BUILD_ROOT}%{logdir}/catalina.out
-%{__install} -d -m 0775 ${RPM_BUILD_ROOT}%{_localstatedir}/run
-/bin/touch ${RPM_BUILD_ROOT}%{_localstatedir}/run/%{name}.pid
-/bin/echo "%{name}-%{major_version}.%{minor_version}.%{micro_version} RPM installed" >> ${RPM_BUILD_ROOT}%{logdir}/catalina.out
+%{__install} -d -m 0775 ${RPM_BUILD_ROOT}%{_localstatedir}/lib/tomcats
%{__install} -d -m 0775 ${RPM_BUILD_ROOT}%{homedir}
%{__install} -d -m 0775 ${RPM_BUILD_ROOT}%{tempdir}
%{__install} -d -m 0775 ${RPM_BUILD_ROOT}%{workdir}
@@ -333,13 +268,10 @@ zip -u output/build/bin/tomcat-juli.jar META-INF/MANIFEST.MF
# First copy supporting libs to tomcat lib
pushd output/build
%{__cp} -a bin/*.{jar,xml} ${RPM_BUILD_ROOT}%{bindir}
- %{__cp} %{SOURCE10} conf/log4j.properties
- %{__cp} -a conf/*.{policy,properties,xml} ${RPM_BUILD_ROOT}%{confdir}
+ %{__cp} -a conf/*.{policy,properties,xml,xsd} ${RPM_BUILD_ROOT}%{confdir}
%{__cp} -a lib/*.jar ${RPM_BUILD_ROOT}%{libdir}
%{__cp} -a webapps/* ${RPM_BUILD_ROOT}%{appdir}
popd
-# javadoc
-%{__cp} -a output/dist/webapps/docs/api/* ${RPM_BUILD_ROOT}%{_javadocdir}/%{name}
%{__sed} -e "s|\@\@\@TCHOME\@\@\@|%{homedir}|g" \
-e "s|\@\@\@TCTEMP\@\@\@|%{tempdir}|g" \
@@ -347,36 +279,41 @@ popd
> ${RPM_BUILD_ROOT}%{confdir}/%{name}.conf
%{__sed} -e "s|\@\@\@TCHOME\@\@\@|%{homedir}|g" \
-e "s|\@\@\@TCTEMP\@\@\@|%{tempdir}|g" \
- -e "s|\@\@\@LIBDIR\@\@\@|%{_libdir}|g" %{SOURCE3} \
+ -e "s|\@\@\@LIBDIR\@\@\@|%{_libdir}|g" %{SOURCE2} \
> ${RPM_BUILD_ROOT}%{_sysconfdir}/sysconfig/%{name}
-%{__install} -m 0644 %{SOURCE4} \
+%{__install} -m 0755 %{SOURCE3} \
${RPM_BUILD_ROOT}%{_sbindir}/%{name}
-%{__install} -m 0644 %{SOURCE11} \
+%{__install} -m 0644 %{SOURCE7} \
${RPM_BUILD_ROOT}%{_unitdir}/%{name}.service
-%{__install} -m 0644 %{SOURCE19} \
- ${RPM_BUILD_ROOT}%{_sbindir}/%{name}-jsvc
-%{__install} -m 0644 %{SOURCE20} \
- ${RPM_BUILD_ROOT}%{_unitdir}/%{name}-jsvc.service
-%{__install} -m 0644 %{SOURCE18} \
- ${RPM_BUILD_ROOT}%{_sbindir}/%{name}-jsvc-sysd
-%{__sed} -e "s|\@\@\@TCLOG\@\@\@|%{logdir}|g" %{SOURCE5} \
- > ${RPM_BUILD_ROOT}%{_sysconfdir}/logrotate.d/%{name}
+%{__sed} -e "s|\@\@\@TCLOG\@\@\@|%{logdir}|g" %{SOURCE4} \
+ > ${RPM_BUILD_ROOT}%{_sysconfdir}/logrotate.d/%{name}.disabled
%{__sed} -e "s|\@\@\@TCHOME\@\@\@|%{homedir}|g" \
-e "s|\@\@\@TCTEMP\@\@\@|%{tempdir}|g" \
- -e "s|\@\@\@LIBDIR\@\@\@|%{_libdir}|g" %{SOURCE6} \
+ -e "s|\@\@\@LIBDIR\@\@\@|%{_libdir}|g" %{SOURCE5} \
> ${RPM_BUILD_ROOT}%{_bindir}/%{name}-digest
%{__sed} -e "s|\@\@\@TCHOME\@\@\@|%{homedir}|g" \
-e "s|\@\@\@TCTEMP\@\@\@|%{tempdir}|g" \
- -e "s|\@\@\@LIBDIR\@\@\@|%{_libdir}|g" %{SOURCE7} \
+ -e "s|\@\@\@LIBDIR\@\@\@|%{_libdir}|g" %{SOURCE6} \
> ${RPM_BUILD_ROOT}%{_bindir}/%{name}-tool-wrapper
-%{__install} -m 0755 %{SOURCE30} \
+%{__install} -m 0644 %{SOURCE8} \
+ ${RPM_BUILD_ROOT}%{_libexecdir}/%{name}/functions
+%{__install} -m 0755 %{SOURCE9} \
${RPM_BUILD_ROOT}%{_libexecdir}/%{name}/preamble
-%{__install} -m 0755 %{SOURCE31} \
+%{__install} -m 0755 %{SOURCE10} \
${RPM_BUILD_ROOT}%{_libexecdir}/%{name}/server
-%{__install} -m 0644 %{SOURCE32} \
+%{__install} -m 0644 %{SOURCE11} \
${RPM_BUILD_ROOT}%{_unitdir}/%{name}@.service
+%{__install} -m 0644 %{SOURCE12} ${RPM_BUILD_ROOT}%{confdir}/conf.d/
+
+# Substitute libnames in catalina-tasks.xml
+sed -i \
+ "s,el-api.jar,%{name}-el-%{elspec}-api.jar,;
+ s,servlet-api.jar,%{name}-servlet-%{servletspec}-api.jar,;
+ s,jsp-api.jar,%{name}-jsp-%{jspspec}-api.jar,;" \
+ ${RPM_BUILD_ROOT}%{bindir}/catalina-tasks.xml
+
# create jsp and servlet API symlinks
pushd ${RPM_BUILD_ROOT}%{_javadir}
%{__mv} %{name}/jsp-api.jar %{name}-jsp-%{jspspec}-api.jar
@@ -388,27 +325,19 @@ pushd ${RPM_BUILD_ROOT}%{_javadir}
popd
pushd output/build
- %{_bindir}/build-jar-repository lib apache-commons-collections \
- apache-commons-dbcp apache-commons-pool ecj 2>&1
- # need to use -p here with b-j-r otherwise the examples webapp fails to
- # load with a java.io.IOException
- %{_bindir}/build-jar-repository -p webapps/examples/WEB-INF/lib \
- taglibs-core.jar taglibs-standard.jar 2>&1
+ %{_bindir}/build-jar-repository lib ecj 2>&1
+ %{_bindir}/build-jar-repository lib tomcat-jakartaee-migration 2>&1
popd
pushd ${RPM_BUILD_ROOT}%{libdir}
# symlink JSP and servlet API jars
- %{__ln_s} ../%{name}-jsp-%{jspspec}-api.jar .
- %{__ln_s} ../%{name}-servlet-%{servletspec}-api.jar .
- %{__ln_s} ../%{name}-el-%{elspec}-api.jar .
- %{__ln_s} $(build-classpath apache-commons-collections) commons-collections.jar
- %{__ln_s} $(build-classpath apache-commons-dbcp) commons-dbcp.jar
- %{__ln_s} $(build-classpath apache-commons-pool) commons-pool.jar
- %{__ln_s} $(build-classpath log4j) log4j.jar
- %{__ln_s} $(build-classpath ecj) jasper-jdt.jar
-
- # Temporary copy the juli jar here from /usr/share/java/tomcat (for maven depmap)
- %{__cp} -a ${RPM_BUILD_ROOT}%{bindir}/tomcat-juli.jar ./
+ %{__ln_s} ../../java/%{name}-jsp-%{jspspec}-api.jar .
+ %{__ln_s} ../../java/%{name}-servlet-%{servletspec}-api.jar .
+ %{__ln_s} ../../java/%{name}-el-%{elspec}-api.jar .
+ %{__ln_s} $(build-classpath ecj/ecj) jasper-jdt.jar
+ %{__ln_s} $(build-classpath tomcat-jakartaee-migration/jakartaee-migration) jakartaee-migration.jar
+
+ cp ../../%{name}/bin/tomcat-juli.jar .
popd
# symlink to the FHS locations where we've installed things
@@ -421,133 +350,80 @@ pushd ${RPM_BUILD_ROOT}%{homedir}
%{__ln_s} %{workdir} work
popd
-# install sample webapp
-%{__mkdir_p} ${RPM_BUILD_ROOT}%{appdir}/sample
-pushd ${RPM_BUILD_ROOT}%{appdir}/sample
-%{jar} xf ${RPM_BUILD_ROOT}%{appdir}/docs/appdev/sample/sample.war
-popd
-%{__rm} ${RPM_BUILD_ROOT}%{appdir}/docs/appdev/sample/sample.war
-
-# Allow linking for example webapp
-%{__mkdir_p} ${RPM_BUILD_ROOT}%{appdir}/examples/META-INF
-pushd ${RPM_BUILD_ROOT}%{appdir}/examples/META-INF
-echo ''>context.xml
-echo ''>>context.xml
+# Install the maven metadata for the spec impl artifacts as other projects use them
+#%{__install} -d -m 0755 ${RPM_BUILD_ROOT}%{_mavenpomdir}
+pushd res/maven
+ for pom in *.pom; do
+ # fix-up version in all pom files
+ sed -i 's/@MAVEN.DEPLOY.VERSION@/%{version}/g' $pom
+ done
popd
-pushd ${RPM_BUILD_ROOT}%{appdir}/examples/WEB-INF/lib
-%{__ln_s} -f $(build-classpath jakarta-taglibs-core) jstl.jar
-%{__ln_s} -f $(build-classpath jakarta-taglibs-standard) standard.jar
-popd
+# Configure and install maven artifacts
+%mvn_artifact res/maven/tomcat-el-api.pom output/build/lib/el-api.jar
+%mvn_artifact res/maven/tomcat-jsp-api.pom output/build/lib/jsp-api.jar
+%mvn_artifact res/maven/tomcat-servlet-api.pom output/build/lib/servlet-api.jar
+%mvn_file org.apache.tomcat:tomcat-annotations-api tomcat/annotations-api
+%mvn_artifact res/maven/tomcat-annotations-api.pom ${RPM_BUILD_ROOT}%{libdir}/annotations-api.jar
+%mvn_artifact res/maven/tomcat-api.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-api.jar
+%mvn_file org.apache.tomcat:tomcat-catalina-ant tomcat/catalina-ant
+%mvn_artifact res/maven/tomcat-catalina-ant.pom ${RPM_BUILD_ROOT}%{libdir}/catalina-ant.jar
+%mvn_file org.apache.tomcat:tomcat-catalina-ha tomcat/catalina-ha
+%mvn_artifact res/maven/tomcat-catalina-ha.pom ${RPM_BUILD_ROOT}%{libdir}/catalina-ha.jar
+%mvn_file org.apache.tomcat:tomcat-catalina tomcat/catalina
+%mvn_artifact res/maven/tomcat-catalina.pom ${RPM_BUILD_ROOT}%{libdir}/catalina.jar
+%mvn_artifact res/maven/tomcat-coyote.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-coyote.jar
+%mvn_artifact res/maven/tomcat-dbcp.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-dbcp.jar
+%mvn_artifact res/maven/tomcat-i18n-cs.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-i18n-cs.jar
+%mvn_artifact res/maven/tomcat-i18n-de.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-i18n-de.jar
+%mvn_artifact res/maven/tomcat-i18n-es.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-i18n-es.jar
+%mvn_artifact res/maven/tomcat-i18n-fr.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-i18n-fr.jar
+%mvn_artifact res/maven/tomcat-i18n-ja.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-i18n-ja.jar
+%mvn_artifact res/maven/tomcat-i18n-ko.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-i18n-ko.jar
+%mvn_artifact res/maven/tomcat-i18n-pt-BR.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-i18n-pt-BR.jar
+%mvn_artifact res/maven/tomcat-i18n-ru.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-i18n-ru.jar
+%mvn_artifact res/maven/tomcat-i18n-zh-CN.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-i18n-zh-CN.jar
+%mvn_file org.apache.tomcat:tomcat-jasper-el tomcat/jasper-el
+%mvn_artifact res/maven/tomcat-jasper-el.pom ${RPM_BUILD_ROOT}%{libdir}/jasper-el.jar
+%mvn_file org.apache.tomcat:tomcat-jasper tomcat/jasper
+%mvn_artifact res/maven/tomcat-jasper.pom ${RPM_BUILD_ROOT}%{libdir}/jasper.jar
+%mvn_file org.apache.tomcat:tomcat-jaspic-api tomcat/jaspic-api
+%mvn_artifact res/maven/tomcat-jaspic-api.pom ${RPM_BUILD_ROOT}%{libdir}/jaspic-api.jar
+%mvn_artifact res/maven/tomcat-jdbc.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-jdbc.jar
+%mvn_artifact res/maven/tomcat-jni.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-jni.jar
+%mvn_artifact res/maven/tomcat-juli.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-juli.jar
+%mvn_file org.apache.tomcat:tomcat-ssi tomcat/catalina-ssi
+%mvn_artifact res/maven/tomcat-ssi.pom ${RPM_BUILD_ROOT}%{libdir}/catalina-ssi.jar
+%mvn_file org.apache.tomcat:tomcat-storeconfig tomcat/catalina-storeconfig
+%mvn_artifact res/maven/tomcat-storeconfig.pom ${RPM_BUILD_ROOT}%{libdir}/catalina-storeconfig.jar
+%mvn_file org.apache.tomcat:tomcat-tribes tomcat/catalina-tribes
+%mvn_artifact res/maven/tomcat-tribes.pom ${RPM_BUILD_ROOT}%{libdir}/catalina-tribes.jar
+%mvn_artifact res/maven/tomcat-util-scan.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-util-scan.jar
+%mvn_artifact res/maven/tomcat-util.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-util.jar
+%mvn_file org.apache.tomcat:tomcat-websocket-api tomcat/websocket-api
+%mvn_artifact res/maven/tomcat-websocket-api.pom ${RPM_BUILD_ROOT}%{libdir}/websocket-api.jar
+%mvn_artifact res/maven/tomcat-websocket.pom ${RPM_BUILD_ROOT}%{libdir}/tomcat-websocket.jar
+%mvn_artifact res/maven/tomcat-websocket-client-api.pom ${RPM_BUILD_ROOT}%{libdir}/websocket-client-api.jar
+%mvn_artifact res/maven/tomcat.pom
-# Install the maven metadata
-%{__install} -d -m 0755 ${RPM_BUILD_ROOT}%{_mavenpomdir}
-pushd output/dist/src/res/maven
-for pom in *.pom; do
- # fix-up version in all pom files
- sed -i 's/@MAVEN.DEPLOY.VERSION@/%{version}/g' $pom
-done
+%mvn_install
-# we won't install dbcp, juli-adapters and juli-extras pom files
-for libname in annotations-api catalina jasper-el jasper catalina-ha; do
- %{__cp} -a %{name}-$libname.pom ${RPM_BUILD_ROOT}%{_mavenpomdir}/JPP.%{name}-$libname.pom
- %add_maven_depmap JPP.%{name}-$libname.pom %{name}/$libname.jar
-done
-
-# servlet-api jsp-api and el-api are not in tomcat subdir, since they are widely re-used elsewhere
-%{__cp} -a tomcat-jsp-api.pom ${RPM_BUILD_ROOT}%{_mavenpomdir}/JPP-tomcat-jsp-api.pom
-%add_maven_depmap JPP-tomcat-jsp-api.pom tomcat-jsp-api.jar -f "tomcat-jsp-api" -a "javax.servlet.jsp:javax.servlet.jsp-api,javax.servlet:jsp-api,org.eclipse.jetty.orbit:javax.servlet.jsp"
-
-%{__cp} -a tomcat-el-api.pom ${RPM_BUILD_ROOT}%{_mavenpomdir}/JPP-tomcat-el-api.pom
-%add_maven_depmap JPP-tomcat-el-api.pom tomcat-el-api.jar -f "tomcat-el-api" -a "javax.el:javax.el-api,javax.el:el-api,org.eclipse.jetty.orbit:javax.el"
-
-%{__cp} -a tomcat-servlet-api.pom ${RPM_BUILD_ROOT}%{_mavenpomdir}/JPP-tomcat-servlet-api.pom
-# Generate a depmap fragment javax.servlet:servlet-api pointing to
-# tomcat-servlet-3.0-api for backwards compatibility
-# also provide jetty depmap (originally in jetty package, but it's cleaner to have it here
-%add_maven_depmap JPP-tomcat-servlet-api.pom tomcat-servlet-api.jar -f "tomcat-servlet-api" -a "javax.servlet:servlet-api,javax.servlet:javax.servlet-api,org.mortbay.jetty:servlet-api,org.eclipse.jetty.orbit:javax.servlet"
-
-# replace temporary copy with link
-%{__ln_s} -f $(abs2rel %{bindir}/tomcat-juli.jar %{libdir}) ${RPM_BUILD_ROOT}%{libdir}/
-
-# two special pom where jar files have different names
-%{__cp} -a tomcat-tribes.pom ${RPM_BUILD_ROOT}%{_mavenpomdir}/JPP.%{name}-catalina-tribes.pom
-%add_maven_depmap JPP.%{name}-catalina-tribes.pom %{name}/catalina-tribes.jar
-
-%{__cp} -a tomcat-coyote.pom ${RPM_BUILD_ROOT}%{_mavenpomdir}/JPP.%{name}-tomcat-coyote.pom
-%add_maven_depmap JPP.%{name}-tomcat-coyote.pom %{name}/tomcat-coyote.jar
-
-%{__cp} -a tomcat-juli.pom ${RPM_BUILD_ROOT}%{_mavenpomdir}/JPP.%{name}-tomcat-juli.pom
-%add_maven_depmap JPP.%{name}-tomcat-juli.pom %{name}/tomcat-juli.jar
-
-%{__cp} -a tomcat-api.pom ${RPM_BUILD_ROOT}%{_mavenpomdir}/JPP.%{name}-tomcat-api.pom
-%add_maven_depmap JPP.%{name}-tomcat-api.pom %{name}/tomcat-api.jar
-
-%{__cp} -a tomcat-util.pom ${RPM_BUILD_ROOT}%{_mavenpomdir}/JPP.%{name}-tomcat-util.pom
-%add_maven_depmap JPP.%{name}-tomcat-util.pom %{name}/tomcat-util.jar
-
-mkdir -p ${RPM_BUILD_ROOT}%{_prefix}/lib/tmpfiles.d
-cat > ${RPM_BUILD_ROOT}%{_prefix}/lib/tmpfiles.d/%{name}.conf </dev/null || :
-%{_sbindir}/useradd -c "Apache Tomcat" -u %{tcuid} -g tomcat \
- -s /bin/nologin -r -d %{homedir} tomcat 2>/dev/null || :
+install -m0644 -D tomcat.sysusers.conf %{buildroot}%{_sysusersdir}/tomcat.conf
%post
# install but don't activate
%systemd_post %{name}.service
-%post jsp-%{jspspec}-api
-%{_sbindir}/update-alternatives --install %{_javadir}/jsp.jar jsp \
- %{_javadir}/%{name}-jsp-%{jspspec}-api.jar 20200
-
-%post servlet-%{servletspec}-api
-%{_sbindir}/update-alternatives --install %{_javadir}/servlet.jar servlet \
- %{_javadir}/%{name}-servlet-%{servletspec}-api.jar 30000
-
-%post el-%{elspec}-api
-%{_sbindir}/update-alternatives --install %{_javadir}/elspec.jar elspec \
- %{_javadir}/%{name}-el-%{elspec}-api.jar 20300
-
%preun
# clean tempdir and workdir on removal or upgrade
%{__rm} -rf %{workdir}/* %{tempdir}/*
%systemd_preun %{name}.service
%postun
-%systemd_postun_with_restart %{name}.service
+%systemd_postun_with_restart %{name}.service
-%postun jsp-%{jspspec}-api
-if [ "$1" = "0" ]; then
- %{_sbindir}/update-alternatives --remove jsp \
- %{_javadir}/%{name}-jsp-%{jspspec}-api.jar
-fi
-
-%postun servlet-%{servletspec}-api
-if [ "$1" = "0" ]; then
- %{_sbindir}/update-alternatives --remove servlet \
- %{_javadir}/%{name}-servlet-%{servletspec}-api.jar
-fi
-
-%postun el-%{elspec}-api
-if [ "$1" = "0" ]; then
- %{_sbindir}/update-alternatives --remove elspec \
- %{_javadir}/%{name}-el-%{elspec}-api.jar
-fi
-
-%triggerun -- tomcat < 0:7.0.22-2
-/usr/bin/systemd-sysv-convert -- save tomcat > /dev/null 2>&1 || :
-# Run these becasue the SysV package being removed won't do them
-/sbin/chkconfig --del tomcat > /dev/null 2>&1 || :
-/bin/systemctl try-restart tomcat.service > /dev/null 2>&1 || :
-
-%files
+%files
%defattr(0664,root,tomcat,0755)
%doc {LICENSE,NOTICE,RELEASE*}
%attr(0755,root,root) %{_bindir}/%{name}-digest
@@ -556,33 +432,41 @@ fi
%attr(0644,root,root) %{_unitdir}/%{name}.service
%attr(0644,root,root) %{_unitdir}/%{name}@.service
%attr(0755,root,root) %dir %{_libexecdir}/%{name}
+%attr(0755,root,root) %dir %{_localstatedir}/lib/tomcats
+%attr(0644,root,root) %{_libexecdir}/%{name}/functions
%attr(0755,root,root) %{_libexecdir}/%{name}/preamble
%attr(0755,root,root) %{_libexecdir}/%{name}/server
-%attr(0644,root,root) %config(noreplace) %{_sysconfdir}/logrotate.d/%{name}
-%config(noreplace) %{_sysconfdir}/sysconfig/%{name}
+%attr(0644,root,root) %config(noreplace) %{_sysconfdir}/sysconfig/%{name}
+%attr(0644,root,root) %config(noreplace) %{_sysconfdir}/logrotate.d/%{name}.disabled
%attr(0755,root,tomcat) %dir %{basedir}
%attr(0755,root,tomcat) %dir %{confdir}
+
%defattr(0664,tomcat,root,0770)
%attr(0770,tomcat,root) %dir %{logdir}
+
%defattr(0664,root,tomcat,0770)
-%attr(0660,tomcat,tomcat) %{logdir}/catalina.out
-%attr(0644,tomcat,tomcat) %{_localstatedir}/run/%{name}.pid
%attr(0770,root,tomcat) %dir %{cachedir}
%attr(0770,root,tomcat) %dir %{tempdir}
%attr(0770,root,tomcat) %dir %{workdir}
-%defattr(0664,root,tomcat,0775)
+
+%defattr(0644,root,tomcat,0775)
%attr(0775,root,tomcat) %dir %{appdir}
%attr(0775,root,tomcat) %dir %{confdir}/Catalina
%attr(0775,root,tomcat) %dir %{confdir}/Catalina/localhost
-%attr(0664,tomcat,tomcat) %config(noreplace) %{confdir}/%{name}.conf
-%attr(0664,tomcat,tomcat) %config(noreplace) %{confdir}/*.policy
-%attr(0664,tomcat,tomcat) %config(noreplace) %{confdir}/*.properties
-%attr(0664,tomcat,tomcat) %config(noreplace) %{confdir}/context.xml
-%attr(0664,tomcat,tomcat) %config(noreplace) %{confdir}/server.xml
-%attr(0660,tomcat,tomcat) %config(noreplace) %{confdir}/tomcat-users.xml
-%attr(0664,tomcat,tomcat) %config(noreplace) %{confdir}/web.xml
+%attr(0755,root,tomcat) %dir %{confdir}/conf.d
+%{confdir}/conf.d/README
+%{confdir}/conf.d/module-start-up-parameters.conf
+%config(noreplace) %{confdir}/%{name}.conf
+%config(noreplace) %{confdir}/*.policy
+%config(noreplace) %{confdir}/*.properties
+%config(noreplace) %{confdir}/context.xml
+%config(noreplace) %{confdir}/server.xml
+%attr(0640,root,tomcat) %config(noreplace) %{confdir}/tomcat-users.xml
+%attr(0664,root,tomcat) %{confdir}/tomcat-users.xsd
+%attr(0664,root,tomcat) %config(noreplace) %{confdir}/jaspic-providers.xml
+%attr(0664,root,tomcat) %{confdir}/jaspic-providers.xsd
+%config(noreplace) %{confdir}/web.xml
%dir %{homedir}
-%{_prefix}/lib/tmpfiles.d/%{name}.conf
%{bindir}/bootstrap.jar
%{bindir}/catalina-tasks.xml
%{homedir}/lib
@@ -591,6 +475,7 @@ fi
%{homedir}/work
%{homedir}/logs
%{homedir}/conf
+%{_sysusersdir}/tomcat.conf
%files admin-webapps
%defattr(0664,root,tomcat,0755)
@@ -598,69 +483,501 @@ fi
%{appdir}/manager
%files docs-webapp
-%defattr(-,root,root,-)
%{appdir}/docs
-%files javadoc
-%defattr(-,root,root,-)
-%{_javadocdir}/%{name}
-
-%files jsp-%{jspspec}-api
-%defattr(-,root,root,-)
-%{_javadir}/%{name}-jsp-%{jspspec}*.jar
-%{_javadir}/%{name}-jsp-api.jar
-%{_mavenpomdir}/JPP-%{name}-jsp-api.pom
-%{_mavendepmapfragdir}/%{name}-tomcat-jsp-api
-
-%files lib
-%defattr(-,root,root,-)
-%{libdir}
+%files lib -f .mfiles
+%dir %{libdir}
+%{libdir}/*.jar
+%{_javadir}/*.jar
%{bindir}/tomcat-juli.jar
-%{_mavendepmapfragdir}/%{name}
-%{_mavenpomdir}/JPP.%{name}-annotations-api.pom
-%{_mavenpomdir}/JPP.%{name}-catalina-ha.pom
-%{_mavenpomdir}/JPP.%{name}-catalina-tribes.pom
-%{_mavenpomdir}/JPP.%{name}-catalina.pom
-%{_mavenpomdir}/JPP.%{name}-jasper-el.pom
-%{_mavenpomdir}/JPP.%{name}-jasper.pom
-%{_mavenpomdir}/JPP.%{name}-tomcat-api.pom
-%{_mavenpomdir}/JPP.%{name}-tomcat-juli.pom
-%{_mavenpomdir}/JPP.%{name}-tomcat-coyote.pom
-%{_mavenpomdir}/JPP.%{name}-tomcat-util.pom
-
%exclude %{libdir}/%{name}-el-%{elspec}-api.jar
+%exclude %{libdir}/%{name}-servlet-%{servletspec}*.jar
+%exclude %{libdir}/%{name}-jsp-%{jspspec}*.jar
+%exclude %{_javadir}/%{name}-servlet-%{servletspec}*.jar
+%exclude %{_javadir}/%{name}-el-%{elspec}-api.jar
+%exclude %{_javadir}/%{name}-jsp-%{jspspec}*.jar
+%exclude %{_javadir}/%{name}-servlet-api.jar
+%exclude %{_javadir}/%{name}-el-api.jar
+%exclude %{_javadir}/%{name}-jsp-api.jar
+%exclude %{_jnidir}/*
-%files servlet-%{servletspec}-api
-%defattr(-,root,root,-)
+%files jsp-%{jspspec}-api -f .mfiles-tomcat-jsp-api
+%{_javadir}/%{name}-jsp-%{jspspec}*.jar
+%{libdir}/%{name}-jsp-%{jspspec}*.jar
+%{_javadir}/%{name}-jsp-api.jar
+
+%files servlet-%{servletspec}-api -f .mfiles-tomcat-servlet-api
%doc LICENSE
%{_javadir}/%{name}-servlet-%{servletspec}*.jar
+%{libdir}/%{name}-servlet-%{servletspec}*.jar
%{_javadir}/%{name}-servlet-api.jar
-%{_mavendepmapfragdir}/%{name}-tomcat-servlet-api
-%{_mavenpomdir}/JPP-%{name}-servlet-api.pom
-%files el-%{elspec}-api
-%defattr(-,root,root,-)
+%files el-%{elspec}-api -f .mfiles-tomcat-el-api
%doc LICENSE
%{_javadir}/%{name}-el-%{elspec}-api.jar
-%{_javadir}/%{name}-el-api.jar
%{libdir}/%{name}-el-%{elspec}-api.jar
-%{_mavenpomdir}/JPP-%{name}-el-api.pom
-%{_mavendepmapfragdir}/%{name}-tomcat-el-api
-
+%{_javadir}/%{name}-el-api.jar
%files webapps
%defattr(0644,tomcat,tomcat,0755)
%{appdir}/ROOT
-%{appdir}/examples
-%{appdir}/sample
-
-%files jsvc
-%defattr(755,root,root,0755)
-%{_sbindir}/%{name}-jsvc
-%{_sbindir}/%{name}-jsvc-sysd
-%attr(0644,root,root) %{_unitdir}/%{name}-jsvc.service
%changelog
+* Thu Sep 25 2025 Adam Williamson - 1:10.1.46-2
+- Drop now-unnecessary version bounds in java requirements
+- Specify java-25-headless, not java-headless (#2398212)
+
+* Fri Sep 12 2025 Dimitris Soumis - 1:10.1.46-1
+- Update to version 10.1.46
+
+* Tue Aug 19 2025 Dimitris Soumis - 1:10.1.43-7
+- Add virtual provides to resolve installability issues
+
+* Thu Aug 14 2025 Dimitris Soumis - 1:10.1.43-6
+- Rebuilt for the side tag f43-build-side-116701
+
+* Tue Jul 29 2025 Dimitris Soumis - 1:10.1.43-5
+- Rebuilt for the side tag f43-build-side-114811
+
+* Fri Jan 10 2025 Dimitris Soumis - 1:10.1.34-1
+- Update to version 10.1.34
+
+* Mon Dec 09 2024 Packit - 1:9.0.98-1
+- Update to version 9.0.98
+- Resolves: rhbz#2331168
+
+* Mon Dec 02 2024 Dimitris Soumis - 1:9.0.97-1
+- Update to version 9.0.97
+- Resolves: rhbz#2327090
+
+* Tue Oct 08 2024 Packit - 1:9.0.96-1
+- Update to version 9.0.96
+- Resolves: rhbz#2317237
+
+* Tue Sep 17 2024 Packit - 1:9.0.95-1
+- Update to version 9.0.95
+- Resolves: rhbz#2312858
+
+* Tue Sep 10 2024 Packit - 1:9.0.94-1
+- Update to version 9.0.94
+- Resolves: rhbz#2311320
+
+* Tue Aug 06 2024 Packit - 1:9.0.93-1
+- Update to version 9.0.93
+- Resolves: rhbz#2303026
+
+* Wed Jul 24 2024 Miroslav Suchý - 1:9.0.91-1
+- convert license to SPDX
+
+* Thu Jul 11 2024 Dimitris Soumis - 1:9.0.91-1
+- Update to 9.0.91
+
+* Thu Jun 20 2024 Dimitris Soumis - 1:9.0.90-1
+- Update to 9.0.90
+
+* Fri Jun 7 2024 Dimitris Soumis - 1:9.0.89-1
+- Update to 9.0.89
+
+* Thu Feb 29 2024 Adam Williamson - 1:9.0.83-4
+- Accept java-21-headless as one of the alternatives for java
+
+* Tue Feb 27 2024 Jiri Vanek - 1:9.0.83-3
+- Rebuilt for java-21-openjdk as system jdk
+
+* Sat Jan 27 2024 Fedora Release Engineering - 1:9.0.83-2
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_40_Mass_Rebuild
+
+* Fri Dec 01 2023 Hui Wang - 1:9.0.83-1
+- Update to 9.0.83
+
+* Mon Oct 16 2023 Hui Wang - 1:9.0.82-1
+- Update to 9.0.82
+- Resolves: rhbz#2244333 Wrong dbcp class in tomcat 9
+
+* Wed Sep 13 2023 Hui Wang - 1:9.0.80-1
+- Update to 9.0.80
+- Fix java version
+
+* Fri Aug 04 2023 Hui Wang - 1:9.0.78-4
+- Fix files permission
+
+* Wed Jul 26 2023 Hui Wang - 1:9.0.78-3
+- Exclude jnidir in the lib subpackage
+
+* Tue Jul 25 2023 Hui Wang - 1:9.0.78-2
+- Resolves: rhbz#2224318 There are duplicated jars in the tomcat lib subpackage
+
+* Tue Jul 25 2023 Hui Wang - 1:9.0.78-1
+- Resolves: rhbz#2224318 There are duplicated jars in the tomcat lib-subpackage
+- Update to 9.0.78
+
+* Sat Jul 22 2023 Fedora Release Engineering - 1:9.0.76-3
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_39_Mass_Rebuild
+
+* Tue Jun 20 2023 Hui Wang - 1:9.0.76-2
+- Resolves: rhbz#2189672 Missing Tomcat POM files in Fedora Rawhide
+- Remove JDTCompiler patch because ecj has been update
+- Update to 9.0.76
+- Resolves: rhbz#2188218 Link bin/tomcat-juli.jar to /usr/share/java
+- Move tomcat-jsp-2.3-api.jar,tomcat-servlet-4.0-api.jar and tomcat-el-api.jar to the subpackages
+
+* Thu Jun 08 2023 Hui Wang - 1:9.0.75-1
+- Update to 9.0.75
+
+* Fri Mar 17 2023 Hui Wang - 1:9.0.73-1
+- Update to 9.0.73
+
+* Sun Jan 29 2023 Hui Wang - 1:9.0.71-1
+- Update to 9.0.71
+- Remove osgi-annotations patch
+- Add bnd-annotation dependency which is in bndlib package
+
+* Sat Jan 21 2023 Fedora Release Engineering - 1:9.0.70-2
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_38_Mass_Rebuild
+
+* Fri Jan 13 2023 Hui Wang - 1:9.0.70-1
+- Update to 9.0.70
+
+* Thu Nov 03 2022 Hui Wang - 1:9.0.68-1
+- Update to 9.0.68
+
+* Thu Jul 21 2022 Hui Wang - 1:9.0.65-1
+- Update to 9.0.65
+
+* Fri Jul 08 2022 Jiri Vanek - 1:9.0.64-2
+- Rebuilt for Drop i686 JDKs
+
+* Tue Jun 21 2022 Hui Wang - 1:9.0.64-1
+- Update to 9.0.64
+- Add osgi-annotations dependency back
+
+* Thu Mar 10 2022 Coty Sutherland - 1:9.0.59-3
+- Related: rhbz#2061424 Adjust fix so that it uses the proper env var
+
+* Tue Mar 08 2022 Coty Sutherland - 1:9.0.59-2
+- Resolves: rhbz#2061424 Add Java 9 start-up parameters to allow reflection
+
+* Wed Mar 02 2022 Sonia Xu - 1:9.0.59-1
+- Update to 9.0.59
+- Resolves: rhbz#2047419 - CVE-2022-23181 tomcat: local privilege escalation vulnerability
+
+* Sat Feb 05 2022 Jiri Vanek - 1:9.0.56-3
+- Rebuilt for java-17-openjdk as system jdk
+
+* Sat Jan 22 2022 Fedora Release Engineering - 1:9.0.56-2
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_36_Mass_Rebuild
+
+* Thu Dec 09 2021 Hui Wang - 1:9.0.56-1
+- Update to 9.0.56
+
+* Tue Oct 12 2021 Hui Wang - 1:9.0.55-1
+- Update to 9.0.55
+
+* Tue Oct 12 2021 Hui Wang - 1:9.0.54-1
+- Update to 9.0.54
+
+* Thu Sep 16 2021 Hui Wang - 1:9.0.53-1
+- Update to 9.0.53
+
+* Wed Aug 18 2021 Hui Wang - 1:9.0.52-1
+- Update to 9.0.52
+
+* Fri Jul 23 2021 Fedora Release Engineering - 1:9.0.50-2
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_35_Mass_Rebuild
+
+* Tue Jul 06 2021 Hui Wang - 1:9.0.50-1
+- Update to 9.0.50
+
+* Sat Jun 05 2021 Coty Sutherland - 1:9.0.45-4
+- Add back logrotate config file per devel list request
+- Add mvn virtual provides back for the servlet, el, and jsp spec impls
+
+* Fri Jun 04 2021 Coty Sutherland - 1:9.0.45-3
+- Drop geronimo-jaxrpc, which provided the webservices naming factory resources that are generally unused
+
+* Thu Jun 03 2021 Coty Sutherland - 1:9.0.45-2
+- Remove examples webapps from subpackage
+- Updates to javapackages-local removed %%add_maven_depmap which broke the build,
+ so I removed the maven artifacts as they aren't very useful anyway
+- Drop JSVC support as it's not very useful these days
+- Drop geronimo-saaj as it's no longer required
+
+* Thu Apr 22 2021 Hui Wang - 1:9.0.45-1
+- Update to 9.0.45
+
+* Thu Mar 18 2021 Hui Wang - 1:9.0.44-1
+- Update to 9.0.44
+
+* Tue Mar 02 2021 Zbigniew Jędrzejewski-Szmek - 1:9.0.43-2
+- Rebuilt for updated systemd-rpm-macros
+ See https://pagure.io/fesco/issue/2583.
+
+* Wed Feb 03 2021 Hui Wang - 1:9.0.43-1
+- Update to 9.0.43
+
+* Wed Jan 27 2021 Fedora Release Engineering - 1:9.0.41-2
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild
+
+* Wed Dec 09 2020 Hui Wang - 1:9.0.41-1
+- Update to 9.0.41
+
+* Wed Nov 18 2020 Hui Wang - 1:9.0.40-1
+- Update to 9.0.40
+
+* Mon Oct 12 2020 Hui Wang - 1:9.0.39-1
+- Update to 9.0.39
+
+* Wed Sep 16 2020 Hui Wang - 1:9.0.38-1
+- Update to 9.0.38
+
+* Wed Jul 29 2020 Fedora Release Engineering - 1:9.0.37-4
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild
+
+* Fri Jul 24 2020 Coty Sutherland - 1:9.0.37-3
+- Related: rhbz#1857043 Temporarily remove OSGi metadata from tomcat jars
+
+* Mon Jul 20 2020 Coty Sutherland - 1:9.0.37-2
+- Resolves: rhbz#1857043 Add patch to reinclude o.a.t.util.net.jsse and o.a.t.util.moduler.modules in tomcat-coyote.jar
+
+* Mon Jul 13 2020 Coty Sutherland - 1:9.0.37-1
+- Update to 9.0.37
+
+* Sat Jul 11 2020 Jiri Vanek - 1:9.0.36-2
+- Rebuilt for JDK-11, see https://fedoraproject.org/wiki/Changes/Java11
+
+* Wed Jun 10 2020 Hui Wang - 1:9.0.36-1
+- Upgrade to 9.0.36
+
+* Sun May 31 2020 Hui Wang - 1:9.0.35-2
+- Upgrade to 9.0.35
+
+* Wed Apr 22 2020 Coty Sutherland - 1:9.0.34-2
+- Add updated catalina.policy patch to allow ECJ usage under the Security Manager
+
+* Tue Apr 21 2020 Coty Sutherland - 1:9.0.34-1
+- Update to 9.0.34
+
+* Thu Mar 05 2020 Coty Sutherland - 1:9.0.31-1
+- Update to 9.0.31
+- Resolves: rhbz#1806398 - CVE-2020-1938 tomcat: Apache Tomcat AJP File Read/Inclusion Vulnerability
+
+* Fri Jan 31 2020 Fedora Release Engineering - 1:9.0.30-2
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild
+
+* Fri Dec 20 2019 Coty Sutherland - 1:9.0.30-1
+- Update to 9.0.30
+
+* Thu Sep 26 2019 Coty Sutherland - 1:9.0.26-2
+- Resolves: rhbz#1510522 man page uid and gid mismatch for service accounts
+
+* Thu Sep 26 2019 Coty Sutherland - 1:9.0.26-1
+- Update to 9.0.26
+- Resolves: rhbz#1523112 tomcat systemd does not cope with - in service names
+- Resolves: rhbz#1510896 Problem to start tomcat with a user whose group has a name different to the user
+
+* Sat Jul 27 2019 Fedora Release Engineering - 1:9.0.21-3
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild
+
+* Wed Jul 17 2019 Coty Sutherland - 1:9.0.21-2
+- Update build-classpath calls to ECJ to specify the JAR we want to use
+
+* Tue Jun 18 2019 Coty Sutherland - 1:9.0.21-1
+- Update to 9.0.21
+
+* Tue Apr 02 2019 Coty Sutherland - 1:9.0.13-4
+- Remove javadoc subpackage to drop the jpackage-utils dependency
+
+* Wed Feb 20 2019 Coty Sutherland - 1:9.0.13-3
+- Remove OSGi MANIFEST files, these are now included in the upstream Tomcat distribution (as of 9.0.10)
+- Remove unused dependencies, apache-commons-collections, apache-commons-daemon, apache-commons-pool, junit
+
+* Sun Feb 03 2019 Fedora Release Engineering - 1:9.0.13-2
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild
+
+* Thu Dec 13 2018 Coty Sutherland - 1:9.0.13-1
+- Update to 9.0.13
+- Resolves: rhbz#1636513 - CVE-2018-11784 tomcat: Open redirect in default servlet
+
+* Sun Oct 14 2018 Peter Robinson 1:9.0.10-2
+- Drop legcy sys-v bits
+
+* Tue Jul 31 2018 Coty Sutherland - 1:9.0.10-1
+- Update to 9.0.10
+- Resolves: rhbz#1624929 - CVE-2018-1336 tomcat: A bug in the UTF-8 decoder can lead to DoS
+- Resolves: rhbz#1579612 - CVE-2018-8014 tomcat: Insecure defaults in CORS filter enable 'supportsCredentials' for all origins
+- Resolves: rhbz#1607586 - CVE-2018-8034 tomcat: host name verification missing in WebSocket client
+- Resolves: rhbz#1607584 - CVE-2018-8037 tomcat: Due to a mishandling of close in NIO/NIO2 connectors user sessions can get mixed up
+
+* Sat Jul 14 2018 Fedora Release Engineering - 1:9.0.7-2
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild
+
+* Tue May 01 2018 Coty Sutherland - 1:9.0.7-1
+- Update to 9.0.7
+
+* Thu Mar 15 2018 Coty Sutherland - 1:8.5.29-1
+- Update to 8.5.29
+- Resolves: rhbz#1548290 CVE-2018-1304 tomcat: Incorrect handling of empty string URL in security constraints can lead to unitended exposure of resources
+- Resolves: rhbz#1548284 CVE-2018-1305 tomcat: Late application of security constraints can lead to resource exposure for unauthorised users
+
+* Fri Feb 09 2018 Igor Gnatenko - 1:8.0.49-2
+- Escape macros in %%changelog
+
+* Thu Feb 01 2018 Coty Sutherland - 1:8.0.49-1
+- Update to 8.0.49
+
+* Tue Dec 12 2017 Merlin Mathesius - 1:8.0.47-3
+- Cleanup spec file conditionals
+
+* Tue Oct 24 2017 Troy Dawson - 1:8.0.47-2
+- Change "zip -u" to "zip"
+- Resolves: rhbz#1495241 [tomcat] zip -u in spec file causes race condition
+
+* Wed Oct 04 2017 Coty Sutherland - 1:8.0.47-1
+- Update to 8.0.47
+- Resolves: rhbz#1497682 CVE-2017-12617 tomcat: Remote Code Execution bypass for CVE-2017-12615
+
+* Mon Aug 21 2017 Coty Sutherland - 1:8.0.46-1
+- Update to 8.0.46
+- Resolves: rhbz#1480620 CVE-2017-7674 tomcat: Cache Poisoning
+
+* Thu Jul 27 2017 Fedora Release Engineering - 1:8.0.44-2
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Mass_Rebuild
+
+* Fri Jun 09 2017 Coty Sutherland - 1:8.0.44-1
+- Resolves: rhbz#1459160 CVE-2017-5664 tomcat: Security constrained bypass in error page mechanism
+
+* Tue Apr 11 2017 Coty Sutherland - 1:8.0.43-1
+- Update to 8.0.43
+
+* Fri Mar 31 2017 Coty Sutherland - 1:8.0.42-1
+- Update to 8.0.42
+
+* Thu Feb 16 2017 Coty Sutherland - 1:8.0.41-1
+- Update to 8.0.41
+- Resolves: rhbz#1403825 CVE-2016-8745 tomcat: information disclosure due to incorrect Processor sharing
+
+* Sat Feb 11 2017 Fedora Release Engineering - 1:8.0.39-2
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_26_Mass_Rebuild
+
+* Tue Nov 29 2016 Coty Sutherland - 1:8.0.39-1
+- Update to 8.0.39
+- Resolves: rhbz#1397493 CVE-2016-6816 CVE-2016-6817 CVE-2016-8735 tomcat: various flaws
+
+* Tue Oct 25 2016 Coty Sutherland - 1:8.0.38-1
+- Update to 8.0.38
+
+* Sun Oct 23 2016 Coty Sutherland - 1:8.0.37-3
+- Resolves: rhbz#1383216 CVE-2016-6325 tomcat: tomcat writable config files allow privilege escalation
+- Resolves: rhbz#1382310 CVE-2016-5425 tomcat: Local privilege escalation via systemd-tmpfiles service
+
+* Tue Sep 13 2016 Coty Sutherland - 1:8.0.37-1
+- Rebase to 8.0.37
+- Resolves: rhbz#1375581 CVE-2016-5388 CGI sets environmental variable based on user supplied Proxy request header
+- Resolves: rhbz#1370262 catalina.out is no longer in use in the main package, but still gets rotated
+
+* Thu Aug 11 2016 Coty Sutherland - 1:8.0.36-2
+- Related: rhbz#1349469 Correct typo in changelog entry
+
+* Mon Aug 08 2016 Coty Sutherland - 1:8.0.36-1
+- Resolves: rhbz#1349469 CVE-2016-3092 tomcat: Usage of vulnerable FileUpload package can result in denial of service (updates to 8.0.36)
+- Resolves: rhbz#1364056 The command tomcat-digest doesn't work
+- Resolves: rhbz#1363884 The tomcat-tool-wrapper script is broken
+- Resolves: rhbz#1347864 The systemd service unit does not allow tomcat to shut down gracefully
+- Resolves: rhbz#1347835 The security manager doesn't work correctly (JSPs cannot be compiled)
+- Resolves: rhbz#1341853 rpm -V tomcat fails on /var/log/tomcat/catalina.out
+- Resolves: rhbz#1341850 tomcat-jsvc.service has TOMCAT_USER value hard-coded
+- Resolves: rhbz#1359737 Missing maven depmap for the following artifacts: org.apache.tomcat:tomcat-websocket, org.apache.tomcat:tomcat-websocket-api
+- Resolves: asfbz#59960 Building javadocs with java8 fails
+
+* Wed Mar 2 2016 Ivan Afonichev - 1:8.0.32-4
+- Revert sysconfig migration changes, resolves: rhbz#1311771, rhbz#1311905
+- Add /etc/tomcat/conf.d/ with shell expansion support, resolves rhbz#1293636
+
+* Sat Feb 27 2016 Ivan Afonichev - 1:8.0.32-3
+- Load sysconfig from tomcat.conf, resolves: rhbz#1311771, rhbz#1311905
+- Set default javax.sql.DataSource factory to apache commons one, resolves rhbz#1214381
+
+* Sun Feb 21 2016 Ivan Afonichev - 1:8.0.32-2
+- Fix symlinks from $CATALINA_HOME/lib perspective, resolves: rhbz#1308685
+
+* Thu Feb 11 2016 Ivan Afonichev - 1:8.0.32-1
+- Updated to 8.0.32
+- Remove log4j support. It has never been working actually. See rhbz#1236297
+- Move shipped config to /etc/sysconfig/tomcat. /etc/tomcat/tomcat.conf can now be used to override it with shell expansion, resolves rhbz#1293636
+- Recommend tomcat-native, resolves: rhbz#1243132
+
+* Wed Feb 10 2016 Coty Sutherland 1:8.0.26-4
+- Resolves: rhbz#1286800 Failed to start component due to wrong allowLinking="true" in context.xml
+- Program /bin/nologin does not exist (#1302718)
+
+* Fri Feb 05 2016 Fedora Release Engineering - 1:8.0.26-3
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_24_Mass_Rebuild
+
+* Wed Nov 11 2015 Robert Scheck 1:8.0.26-2
+- CATALINA_OPTS are only read when SECURITY_MANAGER is true (#1147105)
+
+* Thu Aug 27 2015 Alexander Kurtakov 1:8.0.26-1
+- Update to 8.0.26.
+
+* Fri Jul 10 2015 Alexander Kurtakov 1:8.0.24-2
+- Update to 8.0.24.
+
+* Fri Jun 19 2015 Alexander Kurtakov 1:8.0.23-2
+- Drop javax.el:el-api alias.
+
+* Thu Jun 18 2015 Alexander Kurtakov 1:8.0.23-1
+- Update to 8.0.23.
+
+* Thu Jun 18 2015 Alexander Kurtakov 1:8.0.20-3
+- Drop jetty alias for servlet.
+
+* Tue Jun 09 2015 Michal Srb - 1:8.0.20-2
+- Fix metadata for org.apache.tomcat:{tomcat-jni,tomcat-util-scan}
+
+* Thu Mar 5 2015 Alexander Kurtakov 1:8.0.18-5
+- Rebuild against tomcat-taglibs-standard.
+
+* Wed Mar 4 2015 Alexander Kurtakov 1:8.0.18-4
+- Fix epoch bumped el_1_0_api that would override all other glassfish/jboss/etc. due to wrong epoch.
+- Drop old provides.
+
+* Tue Mar 03 2015 Stephen Gallagher 1:8.0.18-3
+- Bump epoch to maintain upgrade path from Fedora 22
+
+* Mon Feb 16 2015 Michal Srb - 0:8.0.18-2
+- Install POM files for org.apache.tomcat:{tomcat-jni,tomcat-util-scan}
+
+* Sun Feb 15 2015 Ivan Afonichev 0:8.0.18-1
+- Updated to 8.0.18
+
+* Sat Sep 20 2014 Ivan Afonichev 0:8.0.12-1
+- Updated to 8.0.12
+- Substitute libnames in catalina-tasks.xml, resolves: rhbz#1126439
+- Use CATALINA_OPTS only on start, resolves: rhbz#1051194
+
+* Mon Jun 16 2014 Michal Srb - 0:7.0.54-3
+- jsp-api requires el-api
+
+* Sun Jun 08 2014 Fedora Release Engineering - 0:7.0.54-2
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_21_Mass_Rebuild
+
+* Thu Jun 5 2014 Alexander Kurtakov 0:7.0.54-1
+- Update to upstream 7.0.54 - fixes compile with Java 8.
+
+* Wed May 21 2014 Alexander Kurtakov 0:7.0.52-3
+- Drop servlet/el api provides to reduce user machines ending with both.
+
+* Sun Mar 30 2014 Ivan Afonichev 0:7.0.52-2
+- Don't provide maven javax.jsp:jsp-api and javax.servlet.jsp:javax.servlet.jsp-api resolves: rhbz#1076949
+- Move log4j support into subpackage, resolves: rhbz#1027716
+
+* Wed Mar 26 2014 Ivan Afonichev 0:7.0.52-1
+- Updated to 7.0.52
+- Rewrite jsvc implementation, resolves: rhbz#1051743
+- Switch to java-headless R, resolves: rhbz#1068566
+- Create and own %%{_localstatedir}/lib/tomcats, resolves: rhbz#1026741
+- Add pom for tomcat-jdbc, resolves: rhbz#1011003
+
* Tue Jan 21 2014 Mikolaj Izdebski - 0:7.0.47-3
- Fix installation of Maven metadata for tomcat-juli.jar
- Resolves: rhbz#1033664
@@ -737,7 +1054,7 @@ fi
- Updated to 7.0.28
- Resolves: rhbz 820119 Remove bundled apache-commons-dbcp
- Resolves: rhbz 814900 Added tomcat-coyote POM
-- Resolves: rhbz 810775 Remove systemv stuff from %post scriptlet
+- Resolves: rhbz 810775 Remove systemv stuff from %%post scriptlet
- Remove redhat-lsb R
* Mon Apr 9 2012 Ivan Afonichev 0:7.0.27-2
@@ -857,7 +1174,7 @@ fi
* Thu Apr 28 2011 Ivan Afonichev 0:7.0.12-2
- Package now named just tomcat instead of tomcat7
-- Removed Provides: %{name}-log4j
+- Removed Provides: %%{name}-log4j
- Switched to apache-commons-* names instead of jakarta-commons-* .
- Remove the old changelog
- BR/R java >= 1:1.6.0 , same for java-devel