Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Moodle timezone set but on-demand reports show as not run #92

Open
ghost opened this issue Jul 21, 2021 · 6 comments
Open

Moodle timezone set but on-demand reports show as not run #92

ghost opened this issue Jul 21, 2021 · 6 comments

Comments

@ghost
Copy link

ghost commented Jul 21, 2021

Moodle config.php has date_default_timezone_set('America/New_York'); and Site Administration/Location/Location Settings shows default timezone as the same, but on-demand reports show as "this query has not yet been run". Adding date_default_timezone_set('America/New_York'); to line 101 of locallib.php fixes this issue. Our system encountered this issue with version 4.0 of this plugin and it is still present in 4.1. I thought about involvement of the setting "allow users to select their own timezone" but the profile of the user attempting the report shows "server timezone (America/New_York)". Is there also some PHP-level setting?

@timhunt
Copy link
Member

timhunt commented Aug 5, 2021

Thank you for the bug report.

We don't see on our system (which is Europe/London).

I cannot immediately see why adding that line of code would fix the problem. I would be better to understand it more before changing things, so any extra information you can give would be helpful.

@U-R-dev
Copy link

U-R-dev commented Dec 31, 2023

We have encountered the same situation. In "Reports" > "Ad-hoc database queries" page, On-demand queries show information on the last runs, such as:

"This query was last run on Friday, 29 December 2023, 7:48 PM. It took 0.017s to run. Available to ...", with correct timestamps in local timezone Asia/Tokyo.

However, clicking any On-demand queries returns "This query has not yet been run." At the same time, under /moodledata/admin_report_customsql/temp/X directory, new csv file with the UTC timestamp is created.

Our environment is as follows:

  • OS: Ubuntu 22.04.3 LTS
  • Moodle Version: 4.3.2
  • Ad-hoc database queries Version: 4.2 for Moodle 3.9+ (2022031800)
  • PHP: 8.0.27
  • DB: Postgres 15.1
  • Server Timezone: Asia/Tokyo (JST, +0900)
  • date.timezone in phpinfo(): Asia/Tokyo
  • moodle's timezone setting: "echo $CFG->timezone" shows "Asia/Tokyo"

As suggested by @mikehenry1979-bah, putting date_default_timezone_set('Asia/Tokyo'); into the top of report_customsql_generate_csv funtion in locallib.php resolves the issue; query result is correctly shown in the query result page, and new csv file with its name including local timezone timestamp created.

Some further investigation revealed that, in view.php file, date_default_timezone_get returns "Asia/Tokyo" at first, but "Europe/London" is returned just after admin_externalpage_setup function is called at the line 43, until echo $OUTPUT->header(); is stated at the line 145. Since report_customsql_generate_csv function is called at the line 124, I assume it creates csv file with filename based on "Europe/London" timezone.

I could not figure out why admin_externalpage_setup function changes date_default_timezone variable, but putting date_default_timezone_set($CFG->timezone); just after admin_externalpage_setup also resolved the issue.

Hope this helps in further investigation.

@timhunt
Copy link
Member

timhunt commented Jan 8, 2024

So, if I understand your analysis correctly, something in admin_externalpage_setup is setting the timezone to "Europe/London". It would be really good to work out what is doing that, since it seems like a bug to me.

@institut-agro-ead
Copy link

Hi,
same issue here.
My take on this is that before $OUTPUT->header() is called, the default server timezone is used, meaning the CSV file is created using the server timezone. But when trying to read the file (after $OUTPUT->header()), the name generated by report_customsql_csv_filename uses the timestamp set in Moodle $CFG object.
The best option would be to use the Moodle $CFG at all times to be consistent.
In locallib.php, report_customsql_temp_cvs_name and report_customsql_scheduled_cvs_name both use the PHP strftime (which by the way is deprecated since 8.1) for which you can’t specify which timezone the given timestamp should use.

To fix that, you have to create a new DateTime obect and set the timestamp and timezone manually before formatting: new DateTime())->setTimestamp($timestamp)->setTimezone(new DateTimeZone($CFG->timezone))->format('Ymd-His').
To avoid repetition in both functions, you could create a specific function for that:

function report_customsql_temp_cvs_name($reportid, $timestamp) {
    global $CFG;
    $path = 'admin_report_customsql/temp/'.$reportid;
    make_upload_directory($path);
    return array($CFG->dataroot.'/'.$path.'/'. report_customsql_formatdatetime_from_timestamp($timestamp).'.csv',
                 $timestamp);
}

function report_customsql_scheduled_cvs_name($reportid, $timestart) {
    global $CFG;
    $path = 'admin_report_customsql/'.$reportid;
    make_upload_directory($path);
    return array($CFG->dataroot.'/'.$path.'/'.report_customsql_formatdatetime_from_timestamp($timestart).'.csv',
                 $timestart);
}

function report_customsql_formatdatetime_from_timestamp($timestamp) {
    global $CFG;
    return (new DateTime())->setTimestamp($timestamp)->setTimezone(new DateTimeZone($CFG->timezone))->format('Ymd-His');
}

@dmid20
Copy link

dmid20 commented Oct 22, 2024

Hi,
it seems this comes from adminlib.php function admin_externalpage_setup. Must be somewhere in the call of admin_get_root(false,false). Afaik it has nothing to do with user timezone or system timzone as it is always Europe/London after calling that function.

My setup is Europe/Berlin for the system, PHP, Moodle and the user!

As workaround I have moved the OUTPUT->header() up behind get_renderer.

// Setup the page.
echo "<p>DEBUG: ".date_default_timezone_get() ."</p>";
admin_externalpage_setup('report_customsql', '', $urlparams, '/report/customsql/view.php', ['pagelayout' => 'report']);
echo "<p>DEBUG: ".date_default_timezone_get() ."</p>";
$PAGE->set_title(format_string($report->displayname));
// date_default_timezone_set($CFG->timezone);
$PAGE->navbar->add(format_string($category->name), report_customsql_url('category.php', ['id' => $report->categoryid]));
$PAGE->navbar->add(format_string($report->displayname));
if ($embed) {
    $PAGE->set_pagelayout('embedded');
}

$output = $PAGE->get_renderer('report_customsql');
// changes here to keep timezone settings
echo $OUTPUT->header();

Also I deleted the duplicate
call of admin_externalpage_setup and title and header within the if (!empty($report->queryparams)) section.

       } else {

/*
            admin_externalpage_setup('report_customsql', '', $urlparams,
                    '/report/customsql/view.php');
            $PAGE->set_title(format_string($report->displayname));
            echo $OUTPUT->header();
*/
            echo $OUTPUT->heading(format_string($report->displayname));

Hope this could be helpful.

@dmid20
Copy link

dmid20 commented Oct 23, 2024

Hi,
after further investigation I found the source - at least for my setup - inside the plugin Logstore-XAPI.
tool/log/store/xapi/src/transformer/utils/create_timestamp.php

/**
 * Transformer utility to create standard timestamp.
 *
 * @package   logstore_xapi
 * @copyright Jerret Fowler <[email protected]>
 *            Ryan Smith <https://www.linkedin.com/in/ryan-smith-uk/>
 *            David Pesce <[email protected]>
 * @license   https://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

namespace src\transformer\utils;
defined('MOODLE_INTERNAL') || die();

date_default_timezone_set('Europe/London');
...

See here: #97

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants