This question about Installation of Foswiki: More info required
I used TWiki for years, but as incremental operating system updates kept breaking little things, I moved up to Foswiki 1.0.9.
Now, it too has started failing with Fedora 19 (won't save changed pages), so I am trying to address that by moving on to the current release. Unfortunately, it fails right away when I try to save from the configure script. The problem seems to be that RCS version 5.9.2 does not like the -V option that Foswiki is using to check the environment.
[root@shadow httpd]# rcs -V
rcs: warning: -V is obsolete; instead, use --version
rcs (GNU RCS) 5.9.2
Copyright (C) 2010-2013 Thien-Thi Nguyen
Copyright (C) 1990-1995 Paul Eggert
Copyright (C) 1982,1988,1989 Walter F. Tichy, Purdue CS
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.
[root@shadow httpd]#
I was grepping through Foswiki, trying to find that "rcs -V"so I could patch it to "rcs --version", but I cannot seem to find it.
HELP ?
Is this also why the older version fails?
Lars Poulsen <
[email protected]>
--
LarsPoulsen - 26 Feb 2014
I can't say why Foswik 1.0.9 is failing to save pages. We'd need some error messages or some more to go on. But certainly older versions of Foswiki are going to have trouble with more recent versions of perl. Some commonly used perl code in 1.0.x has been deprecated and will fail with more recent versions of perl.
As far as the RCS Version check, it's done in configure in lib/Foswiki/Configure/Checker.pm, in the subroutine checkRCSProgram - around line 474. You could probablyt sneak around the issue as well by changing from
RcsWrap to
RcsLite for the configured version of RCS.
--
GeorgeClark - 27 Feb 2014
Now I'm confused. It took a bit but I've managed to get rcs 5.9.2 installed on my local test system: However I'm not seeing any issues with configure. Foswiki installed and is running fine.
Could you get some more details about the exact failure in configure? The RCS version issue might be unrelated. Below is what rcs returns on my local system now.
rcs -V
rcs: warning: -V is obsolete; instead, use --version
rcs (GNU RCS) 5.9.2
Copyright (C) 2010-2013 Thien-Thi Nguyen
Copyright (C) 1990-1995 Paul Eggert
Copyright (C) 1982,1988,1989 Walter F. Tichy, Purdue CS
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.
I made a change to
lib/Foswiki/Configure/Checker.pm
to report the rcs version in a NOTE, and it reports 5.9.2 with no issues. So the -V warning is being ignored.
Could your system be running an older version of some of the configure modules? There was a bug a while ago where configure would fail if the RCS version was a 3-part version.
--
GeorgeClark - 27 Feb 2014
Obviously there are several parallel paths I have been looking at here: The old Foswiki 1.0.9 and the new 1.1.9. The old one can't run configure because perl has changed too much since then, and it does not seem worthwhile to try to fix it. Outside of Configure it used to mostly work (with some minor exceptions in user registration etc). Recently some topics won't save; I don't see any error messages, the saved version just does not get updated. But many topics still work fine. But clearly I need to get to the new system.
As for getting 1.1.9 to work, it is quite likely to be interplay between my Linux distribution (Fedora 19 on the system in question) and Foswiki, complicated by the fact that some perl modules have come in via Fedora RPM packages, and others have been loaded by CPAN. I would not be surprised if that could lead to mismatched versions with no easy way to sync them to either the most current CPAN versions or the possibly somewhat older versions captured by the Fedora release process. Is there an automated way to tell CPAN to update everything it knows about (something like "cpan update all")?
For the new Foswiki, it seems I need to get through configure before I can load the content that I have on the older system into it.
So for now I am looking at all the roadblocks in Configure.
(a) RCS version check - I see this in /var/log/httpd/error_log:
[Tue Feb 25 17:32:27.166200 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: rcs: , referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.166324 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: warning: , referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.166460 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: -V is obsolete; instead, use --version, referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.166516 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: , referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.175774 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: rcs: , referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.175876 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: warning: , referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.175977 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: -V is obsolete; instead, use --version, referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.176027 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: , referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.185887 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: rcs: , referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.185991 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: warning: , referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.186090 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: -V is obsolete; instead, use --version, referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.186139 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: , referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.236957 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: ci: warning: -V is obsolete; instead, use --version, referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.243177 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: ci: warning: -V is obsolete; instead, use --version, referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.266312 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: co: warning: -V is obsolete; instead, use --version, referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.277089 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: rlog: warning: -V is obsolete; instead, use --version, referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.284386 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: rlog: warning: -V is obsolete; instead, use --version, referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.291539 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: rlog: warning: -V is obsolete; instead, use --version, referer: http://shadow/rainbow/bin/configure
[Tue Feb 25 17:32:27.325623 2014] [cgi:error] [pid 7569] [client 207.154.90.133:60143] AH01215: rcsdiff: warning: -V is obsolete; instead, use --version, referer: http://shadow/rainbow/bin/configure
(b) When I try to get around that by using
RcsLite I see this a bit further down:
[Tue Feb 25 17:33:09.438995 2014] [:error] [pid 28557] [client 207.154.90.133] ModSecurity: Access denied with code 44 (phase 2). Match of "eq 0" against "MULTIPART_STRICT_ERROR" required. [file "/etc/httpd/conf.d/mod_security.conf"] [line "31"] [id "200002"] [msg "Multipart request body failed strict validation: PE 0, BQ 0, BW 0, DB 0, DA 0, HF 0, LF 0, SM 0, IQ 1, IP 0, IH 0, FL 0"] [hostname "shadow"] [uri "/rainbow/bin/configure"] [unique_id "Uw1EVRpiWTewaHyZHRQbUQAAAAU"]
I had hoped I could avoid this simply by turning off SMTP for now, but even after I edit
LocalSite.cfg by hand to turn off
EnableEmail, I still get this error when saving from the email tab of Configure.
I note that /etc/httpd/modsecurity.d/activated_rules/ is empty.
I do not understand what the "invalid quoting" is about. I have tried to put a backslash in front of the email address, leaving it empty, forcing the default empty, using " at " instead of @ in the email address. All of these get the same complaint about invalid quoting.
--
LarsPoulsen - 27 Feb 2014
I did a "cpan upgrade" to get everything current, but still have the same
ModSecurity problem with the invalid quoting. While it is possible that I might be able to run with a manually configured
LocalSite.cfg it is pretty scary that I cannot complete the documented installation procedure.
--
LarsPoulsen - 27 Feb 2014
For your part a) The warnings during configure. Does configure actually fail? I also get those messages logged. I had not thought to check the logs, since configure appears completely functional. The logs are noisy but it seems inconsequential. The -V option is only used in the configure checker, not in mainline foswiki. So this should not impact the wiki operation.
For part b) I'm completely unfamiliar with mod_security. I've never used it. Is there any chance you could disable it to see if foswiki works without it? The form that is posted by configure is extremely large and complex. I'm not surprised that it might get tripped up. When you save the configuration, it does one large post for every possible field, visible and hidden expert, for the entire configuration. So I don't think you can attribute the fail so a single modified field. Every field is sent on every save. It could be anything.
--
GeorgeClark - 27 Feb 2014
The RCS version issue may not have killed configure, I think it just made the save operation fail and sent me back to the screen that showed the errors. And after I did manually edit
LocalSite.cfg and made it use
RcsLite, it went further.
At this point, the save operation in configure fails with "Internal Server Error". And the only thing I see in the Apache log is the mod_security failure. I have no idea how to not invoke that module, which I think is part of the standard Apache installation.
--
LarsPoulsen - 01 Mar 2014
I found this post:
http://henrytseng.blogspot.com/2009/04/how-to-turn-off-modsecurity-apache.html
Other than that, I've never run into mod_security, and the question has not come up here before that I can recall.
I really think that the RCS error is a red herring. I've got that version installed here, and configure logs all the same errors in the apache error log that you reported. But configure works fine, and foswiki works without errors as well. I think the issue is due to mod_security blocking something critical to foswiki.
--
GeorgeClark - 01 Mar 2014