mirror of
https://github.com/moodle/moodle.git
synced 2025-08-05 08:56:36 +02:00
MDL-80309 tasks: Clean up mtrace logs
This commit is contained in:
parent
2d2dc7e154
commit
76c940134c
4 changed files with 34 additions and 3 deletions
|
@ -45,5 +45,6 @@ function tool_task_status_checks() : array {
|
||||||
* @param string $eol End of line character
|
* @param string $eol End of line character
|
||||||
*/
|
*/
|
||||||
function tool_task_mtrace_wrapper(string $message, string $eol): void {
|
function tool_task_mtrace_wrapper(string $message, string $eol): void {
|
||||||
echo s($message . $eol);
|
$message = s($message);
|
||||||
|
echo $message . $eol;
|
||||||
}
|
}
|
||||||
|
|
|
@ -111,6 +111,7 @@ require_sesskey();
|
||||||
\core\session\manager::write_close();
|
\core\session\manager::write_close();
|
||||||
|
|
||||||
// Prepare to handle output via mtrace.
|
// Prepare to handle output via mtrace.
|
||||||
|
require('lib.php');
|
||||||
$CFG->mtrace_wrapper = 'tool_task_mtrace_wrapper';
|
$CFG->mtrace_wrapper = 'tool_task_mtrace_wrapper';
|
||||||
|
|
||||||
// Run the specified tasks.
|
// Run the specified tasks.
|
||||||
|
|
|
@ -89,6 +89,7 @@ echo $OUTPUT->select_element_for_append();
|
||||||
|
|
||||||
// Prepare to handle output via mtrace.
|
// Prepare to handle output via mtrace.
|
||||||
echo html_writer::start_tag('pre', ['style' => 'color: #fff; background: #333; padding: 1em; min-height: 24lh']);
|
echo html_writer::start_tag('pre', ['style' => 'color: #fff; background: #333; padding: 1em; min-height: 24lh']);
|
||||||
|
require('lib.php');
|
||||||
$CFG->mtrace_wrapper = 'tool_task_mtrace_wrapper';
|
$CFG->mtrace_wrapper = 'tool_task_mtrace_wrapper';
|
||||||
|
|
||||||
// Run the specified task (this will output an error if it doesn't exist).
|
// Run the specified task (this will output an error if it doesn't exist).
|
||||||
|
|
|
@ -1516,12 +1516,40 @@ class manager {
|
||||||
$command = "{$phpbinary} {$scriptpath} {$taskarg}";
|
$command = "{$phpbinary} {$scriptpath} {$taskarg}";
|
||||||
|
|
||||||
// Execute it.
|
// Execute it.
|
||||||
passthru($command);
|
self::passthru_via_mtrace($command);
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This behaves similar to passthru but filters every line via
|
||||||
|
* the mtrace function so it can be post processed.
|
||||||
|
*
|
||||||
|
* @param string $command to run
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public static function passthru_via_mtrace(string $command) {
|
||||||
|
$descriptorspec = [
|
||||||
|
0 => ['pipe', 'r'], // STDIN.
|
||||||
|
1 => ['pipe', 'w'], // STDOUT.
|
||||||
|
2 => ['pipe', 'w'], // STDERR.
|
||||||
|
];
|
||||||
|
flush();
|
||||||
|
$process = proc_open($command, $descriptorspec, $pipes, realpath('./'), []);
|
||||||
|
if (is_resource($process)) {
|
||||||
|
while ($s = fgets($pipes[1])) {
|
||||||
|
mtrace($s, '');
|
||||||
|
flush();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fclose($pipes[0]);
|
||||||
|
fclose($pipes[1]);
|
||||||
|
fclose($pipes[2]);
|
||||||
|
proc_close($process);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Executes an ad hoc task from web invocation using PHP CLI.
|
* Executes an ad hoc task from web invocation using PHP CLI.
|
||||||
*
|
*
|
||||||
|
@ -1586,7 +1614,7 @@ class manager {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Execute it.
|
// Execute it.
|
||||||
passthru($command);
|
self::passthru_via_mtrace($command);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue