Reputation: 307
I have a web server set up on my laptop. I am building a web application which I am accessing through the local network. I have a php file which contains the following lines:
$command = "/usr/bin/oowriter --invisible --convert-to pdf /var/www/hackathon/document/gaurav.doc -outdir /var/www/hackathon/pdf/"
exec($command, $output, $return_var);
print_r($output);
So, the problem is that when I run the above code in the terminal php runs perfectly. But when accessed via a web browser, output is just empty and no conversion is done as intended.
Apache error log shows the following lines:
[Java framework] Error in function createSettingsDocument (elements.cxx).
javaldx failed!
Warning: failed to read path from javaldx
I have tried solutions from https://wiki.archlinux.org/index.php/Libreoffice#Fixing_Java_Framework_Error. But it didn't work.
I am using OpenJDK 7.
Does anybody have any idea on how to make this work?
Upvotes: 11
Views: 5961
Reputation: 189
I was getting this problem in doc to odf conversion using php file thorugh apache2 in Debian 10 (buster).
In browser and apche logs it shows
"Array ( [0] => javaldx failed! [1] => Warning: failed to read path from javaldx )"
I check syslog at /var/log/syslog and get following errors. which is leads to some permission and directory issue in apache's home directory.
Apr 18 02:44:53 siptrunkbgp kernel: [744789.941286] audit: type=1400 audit(1587192293.959:70491): apparmor="ALLOWED" operation="mkdir" profile="libreoffice-oopslash" name="/var/www/.config/" pid=9835 comm="oosplash" requested_mask="c" denied_mask="c" fsuid=33 ouid=33
Apr 18 02:44:54 siptrunkbgp kernel: [744789.995119] audit: type=1400 audit(1587192294.015:70492): apparmor="ALLOWED" operation="mkdir" profile="libreoffice-soffice" name="/var/www/.config/" pid=9852 comm="soffice.bin" requested_mask="c" denied_mask="c" fsuid=33 ouid=33
So I just create .config directory and give proper permission in my apache root location (/var/www) using below command.
mkdir -p /var/www/.config/libreoffice
chown -Rf www-data.www-data /var/www/.config/
This will allow apache user to create required files for conversion using libreoffice.
Upvotes: 0
Reputation: 81
Fraber's answer solved the problem for me!
Used:
$cmd = 'HOME='.getCWD().' && export HOME && libreoffice --headless ....';
exec($cmd);
libreoffice then created '.config' and 'libreoffice' directories in the php script directory. Obviously it must be writeable by the webserver process.
Upvotes: 7
Reputation: 1254
I got the same error message running "ooffice --headless --convert-to pptx filename" from a Web server (actually "NaviServer" 4.99). The solutions above did not solve my issue, but they got me on the right track. It turned out that NaviServer changes the "HOME" environment variable to it's installation directory /usr/local/ns, so that LibreOffice tried to access and create a .config folder in this directory. I found out by executing the BASH "set" command from the Web server and checking the environment variables.
Upvotes: 3
Reputation: 71
Can't vote, can't comment (yet)... So...
What Tim-Erwin said is true.
The error actually states that Error in function createSettingsDocument which is a hint that some function named createSettingsDocument (note: create Settings Document) is failing....
Here's how you (or atleast I) get it to work:
On my server the needed directory was actually /var/www/libreoffice, while in my desktop machine,the directory would of been /var/www/.config/libreoffice so you need to make sure.
Upvotes: 7
Reputation: 1433
OpenOffice needs a user directory. Since you are trying to invoke OpenOffice with the web server, you have to grant the respective user write access to is. On Debian, for instance, that would mean to allow www-data to write to /var/www/.openoffice.org/:
mkdir /var/www/.openoffice.org
chown www-data /var/www/.openoffice.org
Upvotes: 3