weekly release 4.0dev
[moodle.git] / mod / forum / upgrade.txt
1 This files describes API changes in /mod/forum/*,
2 information provided here is intended especially for developers.
4 === 3.11 ===
6 * The get_forum_discussions_paginated web service has been deprecated in favour of get_forum_discussions.
7 * The forum post exporter now includes a "timemodified" field for each post, which is included in several WS methods:
8     * mod_forum_get_discussion_posts
9     * get_discussion_posts_by_userid
10     * get_discussion_post
11     * add_discussion_post
13 === 3.10 ===
15 * Changes in external function mod_forum_external::get_discussion_posts_by_userid
16   Now returns the posts of a given user checking the current user capabilities ($USER, the user who is requesting the posts).
17   Previously, it returned the posts checking the capabilities of the user that created the posts.
19 === 3.8 ===
21 * The following functions have been finally deprecated and can not be used anymore:
22     * forum_scale_used()
23 * In order for the forum summary report to calculate word count and character count data, those details are now stored
24     for each post in the database when posts are created or updated. For posts that existed prior to a Moodle 3.8 upgrade, these
25     are calculated by the refresh_forum_post_counts ad-hoc task in chunks of 5000 posts by default. Site admins are able to modify this
26     default, by setting $CFG->forumpostcountchunksize to the required integer value.
28 === 3.7 ===
29   * Changed the forum discussion rendering to use templates rather than print functions.
30   * Added new forum entities, factories, exporters, renderers, and vaults in the local namespace to better encapsulate the forum data.
31   * Deprecated all of the forum_print_* functions in lib.php.
32   * The forum_print_latest_discussions function has been deprecated and will not be replaced.
33   * The get_forum_discussion_posts web service has been deprecated in favour of get_discussion_posts.
34   * The forum_count_replies function has been deprecated in favour of get_reply_count_for_post_id_in_discussion_id in
35     the Post vault.
36   * External function get_forums_by_courses now returns two additional fields "duedate" and "cutoffdate" containing the due date and the cutoff date for posting to the forums respectively.
37   * External function get_forum_discussion_posts now returns an additional field "tags" returning the post tags.
38   * New external function mod_forum_external::get_forum_discussions returns a list of forum discussions optionally sorted and paginated.
39     Use mod_forum_external::get_forum_discussions instead.
40   * External function mod_forum_external::add_discussion_post() has a new 'messageformat' param to be able to handle other formats different from FORMAT_HTML (that continues being the default one). Also a new 'topreferredformat' option enables the automatic conversion between any format and the preferred format (given the editor preference) before contents are saved.
42 === 3.6 ===
44   * forum_print_post should be surrounded with calls to forum_print_post_start and forum_print_post_end to create the proper HTML structure for the post.
46 === 3.4 ===
47   * External function get_forum_discussion_posts now returns an additional field "ratinginfo" containing rating information.
49 === 3.3 ===
50   * External function get_forums_by_courses now returns and additional field "istracked" that indicates if the user
51    is tracking the related forum.
52   * The legacy forum.js file has been removed, this includes the js functions:
53     forum_produce_subscribe_link, forum_produce_tracking_link, lockoptions_timetoitems,
54     lockoptions_timefromitems, lockoptions, lockoption, unlockoption
55   * External function can_add_discussion now returns two additional fields:
56    "canpindiscussions" that indicates if the user can add pinned discussions.
57    "cancreateattachment" that indicates if the user can add attachments to the discussion.
59 === 3.2 ===
60  * The setting $CFG->forum_replytouser has been removed in favour of a centralized noreplyaddress setting.
61    Please use $CFG->noreplyaddress setting instead.
62  * The following functions have been finally deprecated and should no longer be used.
63   - forum_count_unrated_posts
64   - forum_tp_count_discussion_read_records
65   - forum_get_user_discussions
66   - forum_tp_count_forum_posts
67   - forum_tp_count_forum_read_records
68   - forum_get_open_modes
69   - forum_get_child_posts
70   - forum_get_discussion_posts
71   - forum_get_ratings
72   - forum_get_tracking_link
73   - forum_tp_count_discussion_unread_posts
74   - forum_convert_to_roles
75   - forum_tp_get_read_records
76   - forum_tp_get_discussion_read_records
77   - forum_user_enrolled
78   - forum_user_can_view_post
79   - forum_shorten_post
80   - forum_is_subscribed
81   - forum_subscribe
82   - forum_unsubscribe
83   - forum_subscribed_users
84   - forum_is_forcesubscribed
85   - forum_forcesubscribe
86   - forum_get_forcesubscribed
87   - forum_get_subscribed_forums
88   - forum_get_optional_subscribed_forums
89   - forum_get_potential_subscribers
90  * External functions that were returning file information now return the following file fields:
91    filename, filepath, mimetype, filesize, timemodified and fileurl.
92    Those fields are now marked as VALUE_OPTIONAL for backwards compatibility.
94 === 3.1 ===
95  * The inteface to forum_get_email_message_id() has changed and no longer needs the $host argument.
97 === 3.0 ===
98  * External function get_forums_by_courses now returns and additional field "cancreatediscussions" that indicates if the user
99    can create discussions in the forum.
100  * A new optional parameter (groupid) has been added to get_forum_discussions.
101    This parameter can override the automatically calculated current group.
102  * New constant FORUM_POSTS_ALL_USER_GROUPS, to be used as parameter in functions where we'd need to retrieve all the user posts.
104 === 2.8 ===
105  * The following functions have all been marked as deprecated. Many of
106    these have not been supported in many releases and should not be relied
107    upon:
108      forum_count_unrated_posts
109      forum_tp_count_discussion_read_records
110      forum_get_user_discussions
111      forum_tp_count_forum_posts
112      forum_tp_count_forum_read_records
113      forum_get_open_modes
114      forum_get_child_posts
115      forum_get_discussion_posts
116      forum_get_ratings
117      forum_get_tracking_link
118      forum_tp_count_discussion_unread_posts
119      forum_convert_to_roles
120      forum_tp_get_read_records
121      forum_tp_get_discussion_read_records
122      forum_user_enrolled
123      forum_user_can_view_post
124  * The following functions have been deprecated and replaced. Please see the phpdoc for each on the new function to use instead:
125    * forum_is_subscribed
126    * forum_subscribe
127    * forum_unsubscribe
128    * forum_subscribed_users
129    * forum_is_forcesubscribed
130    * forum_forcesubscribe
131    * forum_get_forcesubscribed
132    * forum_get_subscribed_forums
133    * forum_get_optional_subscribed_forums
134    * forum_get_potential_subscribers
135  * External function mod_forum_external::get_forum_discussions has been deprecated.
136    Use mod_forum_external::get_forum_discussions_paginated instead.
138 === 2.6 ===
140 * The file post_form.php should not be included, the class it contained has
141   been moved so that it can benefit from autoloading.
142 * The function forum_shorten_post() has been deprecated. It was doing a poor
143   job of shortening forum post text and the shorten_text() function does a
144   much better job.
145 * The constant FORUM_TRACKING_ON has been deprecated and replaced by
146   FORUM_TRACKING_FORCED. The value between them is maintained, so they are
147   interchangeable, but code should migrate to the new name.
149 === 2.5 ===
151 The function forum_check_throttling has been changed so that a warning object is returned when a user has reached the 'Post threshold for warning' or
152 'Post threshold for blocking' setting, rather than echoing this on screen. This allows the warning to be moved inside the post form as it can be added
153 as a HTML element, where it is more noticeable. False is returned if there is no need to warn, or restrict the user from posting - see MDL-39182.
155 === 2.3.5, 2.4.2 ===
157 * mod/forum:allowforcesubscribe capability will be forcefully assigned to frontpage role, as it was mistakenly missed off
158 when the capability was initially created. If you don't want users with frontpage role to get forum (with forcesubscribe) emails,
159 then please remove this capability for frontpage role.