<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
	<id>http://wiki.mipt.ru/index.php?action=history&amp;feed=atom&amp;title=CADO_resource%2Fexample_report</id>
	<title>CADO resource/example report - История изменений</title>
	<link rel="self" type="application/atom+xml" href="http://wiki.mipt.ru/index.php?action=history&amp;feed=atom&amp;title=CADO_resource%2Fexample_report"/>
	<link rel="alternate" type="text/html" href="http://wiki.mipt.ru/index.php?title=CADO_resource/example_report&amp;action=history"/>
	<updated>2026-05-06T19:49:22Z</updated>
	<subtitle>История изменений этой страницы в вики</subtitle>
	<generator>MediaWiki 1.42.1</generator>
	<entry>
		<id>http://wiki.mipt.ru/index.php?title=CADO_resource/example_report&amp;diff=2223&amp;oldid=prev</id>
		<title>Олег Давидович: 1 версия импортирована</title>
		<link rel="alternate" type="text/html" href="http://wiki.mipt.ru/index.php?title=CADO_resource/example_report&amp;diff=2223&amp;oldid=prev"/>
		<updated>2024-10-18T06:31:10Z</updated>

		<summary type="html">&lt;p&gt;1 версия импортирована&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Предыдущая версия&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Версия от 06:31, 18 октября 2024&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Олег Давидович</name></author>
	</entry>
	<entry>
		<id>http://wiki.mipt.ru/index.php?title=CADO_resource/example_report&amp;diff=2222&amp;oldid=prev</id>
		<title>1&gt;Naomiq: /* Workflow report for the CADO plugin */</title>
		<link rel="alternate" type="text/html" href="http://wiki.mipt.ru/index.php?title=CADO_resource/example_report&amp;diff=2222&amp;oldid=prev"/>
		<updated>2020-08-08T04:44:53Z</updated>

		<summary type="html">&lt;p&gt;&lt;span dir=&quot;auto&quot;&gt;&lt;span class=&quot;autocomment&quot;&gt;Workflow report for the CADO plugin&lt;/span&gt;&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Workflow report for the CADO plugin==&lt;br /&gt;
This is created for reporting on workflow status of CADOs created in the [[CADO_resource]], SQL code for use in the Ad-hoc database queries plugin. &lt;br /&gt;
&lt;br /&gt;
There are two versions, one for a MySQL database, and one for a PostgreSQL one.&lt;br /&gt;
The output includes:&lt;br /&gt;
* course, grouping, CADO name&lt;br /&gt;
* workflow status in five phases (Initialised, Creation, Reviewing, Approved, Regeneration)&lt;br /&gt;
* generate-user and approve-user full names&lt;br /&gt;
* modified date&lt;br /&gt;
* comment of last review / approve&lt;br /&gt;
It has:&lt;br /&gt;
* a filter for course date, (using earliest start date and latest end date)&lt;br /&gt;
* a choice of whether the html in the comment is to be included or not (value of 1 or 0 must be entered)&lt;br /&gt;
===MySQL===&lt;br /&gt;
&amp;lt;code sql&amp;gt;&lt;br /&gt;
SELECT c.shortname course&lt;br /&gt;
  , ca.name cado_name&lt;br /&gt;
  , ifnull( g.name, &amp;quot;None&amp;quot;) grouping_name&lt;br /&gt;
  , CASE&lt;br /&gt;
     WHEN ca.timegenerated = 0 THEN &amp;quot;Initialised&amp;quot;&lt;br /&gt;
     WHEN ca.timeproposed = 0 AND (ca.approvecomment is null OR ca.approvecomment = &amp;quot;&amp;quot;) THEN &amp;quot;Creation&amp;quot;&lt;br /&gt;
     WHEN ca.timeapproved is null AND ca.timeproposed &amp;gt; 0 THEN &amp;quot;Reviewing&amp;quot;&lt;br /&gt;
     WHEN ca.timeapproved &amp;gt; 0 THEN &amp;quot;Approved&amp;quot;&lt;br /&gt;
     ELSE &amp;quot;Regeneration&amp;quot;&lt;br /&gt;
   END workflow_status&lt;br /&gt;
  , IF( ca.generateuser = 0, &amp;quot;Anonymous&amp;quot;, concat( u1.firstname, &amp;quot; &amp;quot;, u1.lastname )) originator&lt;br /&gt;
  , IF( ca.approveuser = 0, &amp;quot;Anonymous&amp;quot;, concat( u2.firstname, &amp;quot; &amp;quot;, u2.lastname )) approver&lt;br /&gt;
  , ca.timemodified modify_date&lt;br /&gt;
  , IF( :include_html_in_comment = 1, ca.approvecomment, ExtractValue(ca.approvecomment, &amp;#039;//text()&amp;#039;)) comment&lt;br /&gt;
FROM {cado} ca&lt;br /&gt;
JOIN {course} c ON c.id = ca.course&lt;br /&gt;
JOIN {course_modules} cmod ON cmod.instance = ca.id&lt;br /&gt;
JOIN {modules} m on m.id = cmod.module AND m.name = &amp;quot;cado&amp;quot;&lt;br /&gt;
LEFT JOIN {groupings} g ON cmod.groupingid = g.id&lt;br /&gt;
LEFT JOIN {user} u1 ON ca.generateuser = u1.id&lt;br /&gt;
LEFT JOIN  {user} u2 ON ca.approveuser = u2.id&lt;br /&gt;
WHERE c.startdate &amp;gt;= :course_start_date AND c.enddate &amp;lt;= :course_end_date&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===PostgreSQL===&lt;br /&gt;
&amp;lt;code sql&amp;gt;&lt;br /&gt;
SELECT c.shortname course&lt;br /&gt;
  , ca.name cado_name&lt;br /&gt;
  , coalesce( g.name, &amp;#039;None&amp;#039;) grouping_name&lt;br /&gt;
  , CASE&lt;br /&gt;
     WHEN ca.timegenerated = 0 THEN &amp;#039;Initialised&amp;#039;&lt;br /&gt;
     WHEN ca.timeproposed = 0 AND (ca.approvecomment IS NULL OR ca.approvecomment = &amp;#039;&amp;#039;) THEN &amp;#039;Creation&amp;#039;&lt;br /&gt;
     WHEN ca.timeapproved IS NULL AND ca.timeproposed &amp;gt; 0 THEN &amp;#039;Reviewing&amp;#039;&lt;br /&gt;
     WHEN ca.timeapproved &amp;gt; 0 THEN &amp;#039;Approved&amp;#039;&lt;br /&gt;
     ELSE &amp;#039;Regeneration&amp;#039;&lt;br /&gt;
   END workflow_status&lt;br /&gt;
  , CASE &lt;br /&gt;
     WHEN ca.generateuser = 0 THEN &amp;#039;Anonymous&amp;#039;&lt;br /&gt;
     ELSE concat( u1.firstname, &amp;#039; &amp;#039;, u1.lastname )&lt;br /&gt;
     END originator&lt;br /&gt;
  , CASE &lt;br /&gt;
     WHEN ca.approveuser = 0 THEN  &amp;#039;Anonymous&amp;#039;&lt;br /&gt;
     ELSE concat( u2.firstname, &amp;#039; &amp;#039;, u2.lastname )&lt;br /&gt;
     END approver&lt;br /&gt;
  , ca.timemodified modify_date&lt;br /&gt;
  , CASE &lt;br /&gt;
     WHEN :include_html_in_comment = 1 THEN ca.approvecomment&lt;br /&gt;
     ELSE array_to_string( xpath(&amp;#039;//text()&amp;#039;, concat(&amp;#039;&amp;lt;div&amp;gt;&amp;#039;, ca.approvecomment, &amp;#039;&amp;lt;/div&amp;gt;&amp;#039;)::xml)::text[] , &amp;#039; &amp;#039; ) &lt;br /&gt;
     END approve_comment&lt;br /&gt;
FROM {cado} ca&lt;br /&gt;
JOIN {course} c ON c.id = ca.course&lt;br /&gt;
JOIN {course_modules} cmod ON cmod.instance = ca.id&lt;br /&gt;
JOIN {modules} m ON m.id = cmod.module AND m.name = &amp;#039;cado&amp;#039;&lt;br /&gt;
LEFT JOIN {groupings} g ON cmod.groupingid = g.id&lt;br /&gt;
LEFT JOIN {user} u1 ON ca.generateuser = u1.id&lt;br /&gt;
LEFT JOIN  {user} u2 ON ca.approveuser = u2.id&lt;br /&gt;
WHERE c.startdate &amp;gt;= :course_start_date AND c.enddate &amp;lt;= :course_end_date&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;/div&gt;</summary>
		<author><name>1&gt;Naomiq</name></author>
	</entry>
</feed>