]> source.dussan.org Git - nextcloud-server.git/commitdiff
Respect user settings in php.ini if they are big enough
authorMicke Nordin <kano@sunet.se>
Fri, 29 Apr 2022 06:21:53 +0000 (08:21 +0200)
committerbackportbot-nextcloud[bot] <backportbot-nextcloud[bot]@users.noreply.github.com>
Mon, 22 Aug 2022 21:36:31 +0000 (21:36 +0000)
In the admin guide:
* https://docs.nextcloud.com/server/latest/admin_manual/configuration_files/big_file_upload_configuration.html

it is mentioned that you can tweek:
* max_input_time
* max_execution_time

in order to enable larger file uploads. However, the current codebase
will hard code these values to one hour, no matter what the user sets in
php.ini.

This patch will allow the user to set these settings in php.ini and they
will be respected, if and only if, they are set to something bigger than
3600 seconds.

Signed-off-by: Micke Nordin <kano@sunet.se>
lib/base.php

index 66e57459a91d0178746ca2a9e8abb0f0b0350018..780d3fbeef796e58f2de4d88f71aec99ecd89033 100644 (file)
@@ -623,16 +623,32 @@ class OC {
                        throw new \RuntimeException('Could not set timezone to UTC');
                }
 
+
                //try to configure php to enable big file uploads.
-               //this doesn´t work always depending on the web server and php configuration.
-               //Let´s try to overwrite some defaults anyway
+               //this doesn´t work always depending on the webserver and php configuration.
+               //Let´s try to overwrite some defaults if they are smaller than 1 hour
+               // One hour is 3600 seconds
+               $time_limit = 3600;
+
+               $max_execution_time_from_ini = @ini_get('max_execution_time');
+               $biggest_max_execution_time = $time_limit;
+               if (isset($max_execution_time_from_ini)) {
+                       $biggest_max_execution_time = max($time_limit, intval($max_execution_time_from_ini));
+               }
+               @ini_set('max_execution_time', strval($biggest_max_execution_time));
+
+               $max_input_time_from_ini = @ini_get('max_input_time');
+               $biggest_max_input_time = $time_limit;
+               if (isset($max_input_time_from_ini)) {
+                       $biggest_max_input_time = max($time_limit, intval($max_input_time_from_ini));
+               }
+               @ini_set('max_input_time', strval($biggest_max_input_time));
 
-               //try to set the maximum execution time to 60min
+               //try to set the maximum execution time to the largest time limit we have
                if (strpos(@ini_get('disable_functions'), 'set_time_limit') === false) {
-                       @set_time_limit(3600);
+                       $biggest_time_limit = max($time_limit, $biggest_max_execution_time, $biggest_max_input_time);
+                       @set_time_limit($biggest_time_limit);
                }
-               @ini_set('max_execution_time', '3600');
-               @ini_set('max_input_time', '3600');
 
                self::setRequiredIniValues();
                self::handleAuthHeaders();