Merge branch 'MDL-70789-311' of git://github.com/paulholden/moodle into MOODLE_311_STABLE
[moodle.git] / course / upgrade.txt
blob158bb11186c82b85138e32f005a588e19854c390
1 This files describes API changes in /course/*,
2 information provided here is intended especially for developers.
4 === 3.11 ===
5 * A new callback xxx_coursemodule_definition_after_data that allows plugins to extend activity forms after the data is set.
7 === 3.10 ===
9 * The function make_categories_options() has now been deprecated. Please use \core_course_category::make_categories_list() instead.
10 * External function core_course_external::get_course_contents now returns a new field contextid with the module context id.
11 * The core_course_external class methods get_courses(), get_courses_by_field() and search_courses() now return a "valueraw" property
12   for each custom course field, which contains the original/unformatted version of the custom field value.
14 === 3.9 ===
16 * The function get_module_metadata is now deprecated. Please use \core_course\local\service\content_item_service instead.
17 * Activity module names are now PARAM_ALPHANUM instead of PARAM_ALPHA so integers can be used in activity module names
18 * The following functions have been added to core_course_renderer class to have more granularity. They can be overriden in
19   extending classes:
20   - course_name
21   - course_enrolment_icons
22   - course_summary
23   - course_contacts
24   - course_overview_files
25   - course_category_name
26   - course_custom_fields
28 === 3.8 ===
30 * The following functions have been finally deprecated and can not be used any more:
31   - core_course_external::get_activities_overview
32 * External function core_course_external::get_enrolled_courses_by_timeline_classification now also supports the classification
33   'allincludinghidden' which delivers all courses including hidden courses. The classification 'all' still returns all courses
34   without hidden courses.
36 === 3.7 ===
38  * The course pattern function in course_summary_exporter::get_course_pattern has been moved to $OUTPUT->get_generated_image_for_id.
39  * The course color function in course_summary_exporter::coursecolor has been moved to $OUTPUT->get_generated_color_for_id.
40  * External function core_course_external::get_course_contents new returns the following additional completiondata field:
41    - valueused (indicates whether the completion state affects the availability of other content)
42  * External function core_course_external::get_course_contents now returns a new contentsinfo field with summary files information.
43  * External function core_course_external::get_course_contents now returns an additional field "tags" returning the content tags.
45 === 3.6 ===
47  * External function core_course_external::get_course_public_information now returns the roles and the primary role of course
48    contacts.
49  * External function core_course_external::get_course_contents now return the following additional file fields:
50    - onclick (onclick javascript action code)
51    - afterlink (after link info to be displayed)
52    - customdata (module custom data (JSON encoded))
53    - completion (to indicate if completion is enabled or not)
54    - completiondata (completion status for the current user in the module)
55  * External function core_group_external::get_course_user_groups now can return all user courses group information.
57 === 3.5 ===
59  * There is a new capability 'moodle/course:setforcedlanguage' to control which users can force the course
60    language; create_course and update_course functions delegate access control to the caller code; if you
61    are calling those functions you may be interested in checking if the logged in user has 'moodle/course:setforcedlanguage' capability.
63 === 3.3 ===
65  * External function core_course_external::get_courses_by_field now returns the course filters list and status.
66  * External function core_course_external::get_courses_by_field now returns the end date of the course.
67  * External function core_course_external::get_course_contents now return the following additional file fields:
68    - mimetype (the file mime type)
69    - isexternalfile (if is a file reference to a external repository)
70    - repositorytype (the repository name in case is a external file)
71    Those fields are VALUE_OPTIONAL for backwards compatibility.
72  * External function core_course_external::get_course_contents now return the following fields for section and modules:
73    - uservisible (whether the section or module is visible by the user)
74    - availabilityinfo (availability information if the course or module has any access restriction set
76 === 3.2 ===
78  * External function core_course_external::get_course_contents now returns the section's number in the course (new section field).
79  * External function core_course_external::get_course_contents now returns if a section is hidden in the course format.
80  * External functions that were returning file information now return the following file fields:
81    filename, filepath, mimetype, filesize, timemodified and fileurl.
82    Those fields are now marked as VALUE_OPTIONAL for backwards compatibility.
83  * The modchooser now uses a renderable and a template, thus its associated renderer
84    methods have been deprecated. Note that the call to core_course_render::course_modchooser,
85    is still required. Deprecated methods:
86    - core_course_renderer::course_modchooser_module_types
87    - core_course_renderer::course_modchooser_module
88    - core_course_renderer::course_modchooser_title
89  * You can now specify a course end date when calling core_course_external::create_courses and core_course_external::update_courses
90    external functions. core_course_external::get_courses external function is now returning courses end date values.