Workshop: Difference between revisions
David Mudrak (talk | contribs) m (Created a new page) |
David Mudrak (talk | contribs) |
||
(5 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
{{Work in progress}}{{Moodle 2.0}} | {{Work in progress}}{{Moodle 2.0}} | ||
This page describes the current implementation of the [[Workshop module]]. See [[Workshop 2.0 specification]] | This page describes the current implementation of the [[Workshop module]]. See also [[Workshop 2.0 specification]] and [[Workshop 2.0 testing]]. | ||
= | == Overview of Workshop architecture == | ||
== Database structure == | Rewriting Workshop from scratch for Moodle 2.0 was a great opportunity to use new APIs and approaches to activity module development. In some areas, Workshop was a pioneering component adopting new frameworks - like File API, HTML rendering or subplugins support. | ||
Many of Workshop features are implemented as subplugins (see mod/workshop/db/subplugins.php). That allows to extend current functionality without hacking Workshop core system. | |||
=== Workshop core === | |||
Workshop core consists of common module functions in lib.php (required by Moodle itself) and methods of class workshop defined in locallib.php. | |||
=== Grading strategies === | |||
Grading strategies are defined as workshopform subplugins in mod/workshop/form/ subdirectories. At any given time, just one type of the subplugin is used by workshop. But the data are kept so teachers can switch strategies as they need. | |||
=== Allocators === | |||
Allocation subplugins are used to allocate submissions to the students for peer-review. They are defined as workshopallocation subplugins in mod/workshop/allocation/ subdirectories. Teacher can use any installed allocator to distribute submission. Allocators are responsible for creating records in workshop_assessment table. | |||
=== Grading evaluators === | |||
Grading evaluators calculate grades for assessments (aka grading grades). They are defined workshopeval subplugins in mod/workshop/eval/ subdirectories. | |||
== Diagrams and schemas == | |||
=== Database structure === | |||
[[Image:workshop_erd.png|400px|thumb|left|ER diagram of DB tables used in/by Workshop module]] | [[Image:workshop_erd.png|400px|thumb|left|ER diagram of DB tables used in/by Workshop module]] | ||
<br clear="all"/> | <br clear="all"/> | ||
== | === XML structure === | ||
For the purpose of backup/moodle2, the following XML schema is used. | |||
[[Image:workshop_xml.png|400px|thumb|left|XML diagram of elements tree in workshop.xml]] | |||
<br clear="all"/> | |||
=== Classes === | |||
The following UML diagram explains the structure of classes defined in workshop subplugins. | |||
[[Image:workshop_classes.png|400px|thumb|left|UML class diagram]] | |||
<br clear="all"/> | |||
=== Gradebook integration === | |||
[[Image:workshop_grades_calculation.png|400px|thumb|left|The scheme of grades calculation in Workshop]] | [[Image:workshop_grades_calculation.png|400px|thumb|left|The scheme of grades calculation in Workshop]] | ||
<br clear="all"/> | <br clear="all"/> | ||
== Debugging and testing == | |||
* [[Workshop/fakesubmissions.php]] |
Latest revision as of 12:54, 23 April 2012
Note: This page is a work-in-progress. Feedback and suggested improvements are welcome. Please join the discussion on moodle.org or use the page comments.
Moodle 2.0
This page describes the current implementation of the Workshop module. See also Workshop 2.0 specification and Workshop 2.0 testing.
Overview of Workshop architecture
Rewriting Workshop from scratch for Moodle 2.0 was a great opportunity to use new APIs and approaches to activity module development. In some areas, Workshop was a pioneering component adopting new frameworks - like File API, HTML rendering or subplugins support.
Many of Workshop features are implemented as subplugins (see mod/workshop/db/subplugins.php). That allows to extend current functionality without hacking Workshop core system.
Workshop core
Workshop core consists of common module functions in lib.php (required by Moodle itself) and methods of class workshop defined in locallib.php.
Grading strategies
Grading strategies are defined as workshopform subplugins in mod/workshop/form/ subdirectories. At any given time, just one type of the subplugin is used by workshop. But the data are kept so teachers can switch strategies as they need.
Allocators
Allocation subplugins are used to allocate submissions to the students for peer-review. They are defined as workshopallocation subplugins in mod/workshop/allocation/ subdirectories. Teacher can use any installed allocator to distribute submission. Allocators are responsible for creating records in workshop_assessment table.
Grading evaluators
Grading evaluators calculate grades for assessments (aka grading grades). They are defined workshopeval subplugins in mod/workshop/eval/ subdirectories.
Diagrams and schemas
Database structure
XML structure
For the purpose of backup/moodle2, the following XML schema is used.
Classes
The following UML diagram explains the structure of classes defined in workshop subplugins.
Gradebook integration