Merge branch 'MDL-78684-402' of https://github.com/andelacruz/moodle into MOODLE_402_...
[moodle.git] / course / upgrade.txt
blobd6d60e0ddb9c75dc8df68f5f33f1ef1d7cc9d2c5
1 This files describes API changes in /course/*,
2 information provided here is intended especially for developers.
4 === 4.2 ===
5 * course/mod.php now accepts parameter beforemod for adding course modules. It contains the course module id
6   of an existing course module. The new module is inserted before this module.
7 * The function duplicate_module() now has two new optional parameters:
8   - $sectionid to specify section the duplicated course module is placed in
9   - $changename to disable changing the name of the course module using the 'duplicatedmodule' lang string
10 * The method `make_categories_options`, deprecated since 3.10, has been removed
11 * External function core_course_external::get_courses_by_field and core_course_external::search_courses now return a field
12 called "courseimage" containing a URL pointing to the course image.
13 * External function core_course_external::get_course_contents() does not throw exceptions for invalid course formats anymore.
15 === 4.1 ===
16 * The function course_modchooser() has been finally deprecated and can not be used anymore. Please use
17   course_activitychooser() instead.
18 * A critical accessibility issue is been found (MDL-74800) at the output class
19   core_courseformat\output\local\content\cm\cmname. To solve the problem this output element is not
20   rendered anymore using inplace_editable but using a regular named_templatable interface.
21   Some format plugins that override the deprecated renderer method course_section_cm_name can be affected.
22   Check the current course_section_cm_name code to see how to render it properly.
24 === 4.0 ===
25 * All activity icons have been replaced with black monochrome icons. The background
26 colour for these icons is defined using a new 'FEATURE_MOD_PURPOSE' support variable in the module lib.php file
27 Available purpose types are:
28   - MOD_PURPOSE_COMMUNICATION
29   - MOD_PURPOSE_ASSESSMENT
30   - MOD_PURPOSE_COLLABORATION
31   - MOD_PURPOSE_CONTENT
32   - MOD_PURPOSE_ADMINISTRATION
33   - MOD_PURPOSE_INTERFACE
34   - MOD_PURPOSE_OTHER
35 The colours for these types are defined in theme/boost/scss/moodle/variables.scss
36 * The format_base is now deprecated. Use core_courseformat\base instead.
37 * The new course output components deprecate many renderer methods from course
38 renderer and course format renderer:
39   - core_courseformat\output\local\content: to render the general course structure
40   - core_courseformat\output\local\content\section: to render a section
41   - core_courseformat\output\local\content\cm: to render an activity card inside a section
42   - core_courseformat\output\local\content\cm\*: to render parts of the course structure
43   - core_courseformat\output\local\content\section\*: to render parts of the course section
44 * The previous format renderer page_title method has been moved to course_format::page_title
45 * New format renderer methods to interact with the new output components:
46   - render: override the default templatable mustache location for the new course components.
47   - course_section_updated_cm_item: used when the course editor needs to update a cm item HTML.
48   - render_content: contrib formats should override this method to change the default template.
49 * The following methods are adapted to use outputs but with a deprecation warning and should not be used anymore:
50   - print_single_section_page (replaced by core_courseformat\output\local\content)
51   - print_multiple_section_page (replaced by core_courseformat\output\local\content)
52   - course_activity_clipboard (integrated in replaced by core_courseformat\output\local\content)
53   - format_summary_text (replaced by core_courseformat\output\local\content\section\summay)
54   - change_number_sections (replaced by core_courseformat\output\local\content\addsection)
55   - course_section_cm_list_item (replaced by core_courseformat\output\local\content\section\cmitem)
56   - course_section_cm (replaced by core_courseformat\output\local\content\cm)
57   - course_section_cm_list (replaced by core_courseformat\output\local\content\section\cmlist)
58   - section_edit_control_menu (replaced by core_courseformat\output\local\content\section\controlmenu)
59   - section_right_content (integrated in core_courseformat\output\local\content\section)
60   - section_left_content (integrated in core_courseformat\output\local\content\section)
61   - section_header (replaced by core_courseformat\output\local\content\section\header)
62   - section_footer (integrated in core_courseformat\output\local\content\section)
63   - section_edit_control_items (replaced by core_courseformat\output\local\content\section\controlmenu)
64   - section_summary (replaced by core_courseformat\output\local\content\section\summary)
65   - section_activity_summary (replaced by core_courseformat\output\local\content\section\cmsummary)
66   - section_availability_message (integrated in core_courseformat\output\local\content\section\availability)
67   - section_availability (replaced by core_courseformat\output\local\content\section\availability)
68   - get_nav_links (replaced by core_courseformat\output\local\content\sectionnavigation)
69   - stealth_section_header (replaced by core_courseformat\output\local\content\section\header)
70   - stealth_section_footer (integrated in by core_courseformat\output\local\content\section)
71   - section_nav_selection (replaced by core_courseformat\output\local\content\sectionselector)
72   - course_section_cm_edit_actions (replaced by core_courseformat\output\local\content\cm\controlmenu)
73   - is_cm_conditionally_hidden (incorporated in core_availability\info_module::is_available_for_all)
74   - course_section_cm_name (replaced by core_courseformat\output\local\content\cm\cmname)
75   - course_section_cm_classes (integrated in core_courseformat\output\local\content\cm)
76   - course_section_cm_name_title (replaced by core_courseformat\output\local\cm\title)
77   - course_section_cm_text (integrated in core_courseformat\output\local\content\cm)
78   - course_section_cm_availability (replaced by core_courseformat\output\local\content\cm\availability))
79   - start_section_list (integrated in core_courseformat\output\local\content)
80   - end_section_list (integrated in core_courseformat\output\local\content)
81 * The following abstract methods are deleted:
82   - page_title (moved to core_courseformat\output\local\content)
83 * Course formats should have a renderer (until now it was only highly recommended but not mandatory). For backwards
84 compatibility (to not break third-party plugins without it), legacy_format_renderer has been created and will be used when
85 course formats don't have their own renderer.
86 * New external core_courseformat\external\get_state returns current state information for a given course.
87 * New external core_courseformat\external\update_course runs given action to edit course and gets the affectated state objects.
88 * New external core_course\external\get_state returns current state information for a given course.
89 * New external function core_course_update_course runs given action to edit course status.
90 * The `\core\event\course_category_deleted` event is now created with a snapshot of the category record being deleted,
91   available inside event observers via `$event->get_record_snapshot`
92 * New include_course_editor() function to include and configure course editor modules.
93 * New core_course_drawer() function to render the message drawer in the top of the body of each page.
94 * New course_get_enrolled_courses_for_logged_in_user_from_search which hooks in with external\get_enrolled_courses_by_timeline_classification
95   given COURSE_TIMELINE_SEARCH is set then get_enrolled_courses_by_timeline_classification will deviate to use a string search of enrolled courses.
96 * Class core_course\output\course_module_name is deprecated. Now core_courseformat\output\local\content\cm\cmname controls inline edit.
97 * Calendar menu entry is now moved to User menu items, so the following methods will not return the calendar item anymore:
98   - course_get_user_navigation_options
99   - core_course_externalcore_course_external::get_user_navigation_options
100 * New external \core_course\external\get_enrolled_courses_with_action_events_by_timeline_classification:
101   - Returns courses the user is enrolled in which contain at least one action event in the supplied time/text filtering parameters.
102   - Provides a similar response to get_enrolled_courses_by_timeline_classification, but omits courses which have no matching
103     action events.
104 * The following functions have been deprecated in favour the tertiary navigation constructs:
105   - management_heading
106   - course_search_form
107   - print_course_request_buttons
108 * New page_setup() method in the core_course_category class. This method can be used for a general page setup in the course
109   category pages.
110 * New core_course_category::get_nearest_editable_subcategory():
111   - Return the core_course_category object for the first subcategory that the current user has the permission on it.
112 * The method navigation() in the core_course_bulk_activity_completion_renderer class has been deprecated as the tabs navigation
113   structure in the course competency pages has been replaced with tertiary navigation. To render the navigation, please
114   render_course_completion_action_bar() instead.
115 * The following functions have been deprecated in favour partial course cache rebuild:
116   - course_purge_section_cache (replaced by course_modinfo::purge_course_section_cache_by_id() and course_modinfo::purge_course_section_cache_by_number())
117   - course_purge_module_cache (replaced by course_modinfo::purge_course_module_cache())
118   - get_array_of_activities (replaced by course_modinfo::get_array_of_activities() for better performance)
119 * New course_modinfo::purge_course_cache function was created to purge the cache of a given course.
121 === 3.11 ===
122 * A new callback xxx_coursemodule_definition_after_data that allows plugins to extend activity forms after the data is set.
123 * \core_course_renderer::course_section_cm_completion() has been deprecated. It is not being used anymore and is being replaced by
124   \core_renderer::activity_information().
125 * New Behat steps for checking activity date information in the \behat_course class:
126   - activity_date_in_activity_should_contain_text()
127     - Given the activity date in "<ActivityName>" should contain "<Text>"
128   - activity_dates_information_in_activity_should_exist()
129     - Given the activity date information in "<ActivityName>" should exist
130   - activity_dates_information_in_activity_should_not_exist()
131     - Given the activity date information in "<ActivityName>" should not exist
132 * A user preference usemodchooser has been removed and the activities/resources (non-ajax) activity chooser has been deprecated and will be removed in the future.
134 === 3.10 ===
136 * The function make_categories_options() has now been deprecated. Please use \core_course_category::make_categories_list() instead.
137 * External function core_course_external::get_course_contents now returns a new field contextid with the module context id.
138 * The core_course_external class methods get_courses(), get_courses_by_field() and search_courses() now return a "valueraw" property
139   for each custom course field, which contains the original/unformatted version of the custom field value.
141 === 3.9 ===
143 * The function get_module_metadata is now deprecated. Please use \core_course\local\service\content_item_service instead.
144 * Activity module names are now PARAM_ALPHANUM instead of PARAM_ALPHA so integers can be used in activity module names
145 * The following functions have been added to core_course_renderer class to have more granularity. They can be overriden in
146   extending classes:
147   - course_name
148   - course_enrolment_icons
149   - course_summary
150   - course_contacts
151   - course_overview_files
152   - course_category_name
153   - course_custom_fields
155 === 3.8 ===
157 * The following functions have been finally deprecated and can not be used any more:
158   - core_course_external::get_activities_overview
159 * External function core_course_external::get_enrolled_courses_by_timeline_classification now also supports the classification
160   'allincludinghidden' which delivers all courses including hidden courses. The classification 'all' still returns all courses
161   without hidden courses.
163 === 3.7 ===
165  * The course pattern function in course_summary_exporter::get_course_pattern has been moved to $OUTPUT->get_generated_image_for_id.
166  * The course color function in course_summary_exporter::coursecolor has been moved to $OUTPUT->get_generated_color_for_id.
167  * External function core_course_external::get_course_contents new returns the following additional completiondata field:
168    - valueused (indicates whether the completion state affects the availability of other content)
169  * External function core_course_external::get_course_contents now returns a new contentsinfo field with summary files information.
170  * External function core_course_external::get_course_contents now returns an additional field "tags" returning the content tags.
172 === 3.6 ===
174  * External function core_course_external::get_course_public_information now returns the roles and the primary role of course
175    contacts.
176  * External function core_course_external::get_course_contents now return the following additional file fields:
177    - onclick (onclick javascript action code)
178    - afterlink (after link info to be displayed)
179    - customdata (module custom data (JSON encoded))
180    - completion (to indicate if completion is enabled or not)
181    - completiondata (completion status for the current user in the module)
182  * External function core_group_external::get_course_user_groups now can return all user courses group information.
184 === 3.5 ===
186  * There is a new capability 'moodle/course:setforcedlanguage' to control which users can force the course
187    language; create_course and update_course functions delegate access control to the caller code; if you
188    are calling those functions you may be interested in checking if the logged in user has 'moodle/course:setforcedlanguage' capability.
190 === 3.3 ===
192  * External function core_course_external::get_courses_by_field now returns the course filters list and status.
193  * External function core_course_external::get_courses_by_field now returns the end date of the course.
194  * External function core_course_external::get_course_contents now return the following additional file fields:
195    - mimetype (the file mime type)
196    - isexternalfile (if is a file reference to a external repository)
197    - repositorytype (the repository name in case is a external file)
198    Those fields are VALUE_OPTIONAL for backwards compatibility.
199  * External function core_course_external::get_course_contents now return the following fields for section and modules:
200    - uservisible (whether the section or module is visible by the user)
201    - availabilityinfo (availability information if the course or module has any access restriction set
203 === 3.2 ===
205  * External function core_course_external::get_course_contents now returns the section's number in the course (new section field).
206  * External function core_course_external::get_course_contents now returns if a section is hidden in the course format.
207  * External functions that were returning file information now return the following file fields:
208    filename, filepath, mimetype, filesize, timemodified and fileurl.
209    Those fields are now marked as VALUE_OPTIONAL for backwards compatibility.
210  * The modchooser now uses a renderable and a template, thus its associated renderer
211    methods have been deprecated. Note that the call to core_course_render::course_modchooser,
212    is still required. Deprecated methods:
213    - core_course_renderer::course_modchooser_module_types
214    - core_course_renderer::course_modchooser_module
215    - core_course_renderer::course_modchooser_title
216  * You can now specify a course end date when calling core_course_external::create_courses and core_course_external::update_courses
217    external functions. core_course_external::get_courses external function is now returning courses end date values.