|
|
0e3136 |
diff --git a/server/core.c b/server/core.c
|
|
|
0e3136 |
index c36ff26..621c82a 100644
|
|
|
0e3136 |
--- a/server/core.c
|
|
|
0e3136 |
+++ b/server/core.c
|
|
|
0e3136 |
@@ -3569,6 +3569,7 @@ enum server_token_type {
|
|
|
0e3136 |
SrvTk_MINIMAL, /* eg: Apache/2.0.41 */
|
|
|
0e3136 |
SrvTk_OS, /* eg: Apache/2.0.41 (UNIX) */
|
|
|
0e3136 |
SrvTk_FULL, /* eg: Apache/2.0.41 (UNIX) PHP/4.2.2 FooBar/1.2b */
|
|
|
0e3136 |
+ SrvTk_FULL_RELEASE, /* eg: Apache/2.0.41 (UNIX) (Release 32.el7) PHP/4.2.2 FooBar/1.2b */
|
|
|
0e3136 |
SrvTk_PRODUCT_ONLY /* eg: Apache */
|
|
|
0e3136 |
};
|
|
|
0e3136 |
static enum server_token_type ap_server_tokens = SrvTk_FULL;
|
|
|
0e3136 |
@@ -3645,7 +3646,10 @@ static void set_banner(apr_pool_t *pconf)
|
|
|
0e3136 |
else if (ap_server_tokens == SrvTk_MAJOR) {
|
|
|
0e3136 |
ap_add_version_component(pconf, AP_SERVER_BASEPRODUCT "/" AP_SERVER_MAJORVERSION);
|
|
|
0e3136 |
}
|
|
|
0e3136 |
- else {
|
|
|
0e3136 |
+ else if (ap_server_tokens == SrvTk_FULL_RELEASE) {
|
|
|
0e3136 |
+ ap_add_version_component(pconf, AP_SERVER_BASEVERSION " (" PLATFORM ") (Release @RELEASE@)");
|
|
|
0e3136 |
+ }
|
|
|
0e3136 |
+ else {
|
|
|
0e3136 |
ap_add_version_component(pconf, AP_SERVER_BASEVERSION " (" PLATFORM ")");
|
|
|
0e3136 |
}
|
|
|
0e3136 |
|
|
|
0e3136 |
@@ -3653,7 +3657,7 @@ static void set_banner(apr_pool_t *pconf)
|
|
|
0e3136 |
* Lock the server_banner string if we're not displaying
|
|
|
0e3136 |
* the full set of tokens
|
|
|
0e3136 |
*/
|
|
|
0e3136 |
- if (ap_server_tokens != SrvTk_FULL) {
|
|
|
0e3136 |
+ if (ap_server_tokens != SrvTk_FULL && ap_server_tokens != SrvTk_FULL_RELEASE) {
|
|
|
0e3136 |
banner_locked++;
|
|
|
0e3136 |
}
|
|
|
0e3136 |
server_description = AP_SERVER_BASEVERSION " (" PLATFORM ")";
|
|
|
0e3136 |
@@ -3686,8 +3690,11 @@ static const char *set_serv_tokens(cmd_parms *cmd, void *dummy,
|
|
|
0e3136 |
else if (!ap_cstr_casecmp(arg, "Full")) {
|
|
|
0e3136 |
ap_server_tokens = SrvTk_FULL;
|
|
|
0e3136 |
}
|
|
|
0e3136 |
+ else if (!strcasecmp(arg, "Full-Release")) {
|
|
|
0e3136 |
+ ap_server_tokens = SrvTk_FULL_RELEASE;
|
|
|
0e3136 |
+ }
|
|
|
0e3136 |
else {
|
|
|
0e3136 |
- return "ServerTokens takes 1 argument: 'Prod(uctOnly)', 'Major', 'Minor', 'Min(imal)', 'OS', or 'Full'";
|
|
|
0e3136 |
+ return "ServerTokens takes 1 argument: 'Prod(uctOnly)', 'Major', 'Minor', 'Min(imal)', 'OS', 'Full' or 'Full-Release'";
|
|
|
0e3136 |
}
|
|
|
0e3136 |
|
|
|
0e3136 |
return NULL;
|