Anonymous Users: Difference between revisions
m (→Core Code) |
|||
Line 18: | Line 18: | ||
=== Global === | === Global === | ||
[[Image:Anon global.png]] | |||
=== Course === | === Course === | ||
[[Image:Anon course.png]] | |||
=== Activity === | === Activity === | ||
[[Image:Anon activity.png]] | |||
=== User Profile === | === User Profile === | ||
[[Image:Anon profile.png]] | |||
== Code Changes == | == Code Changes == |
Revision as of 15:37, 10 December 2009
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
Objective
To allow users to switch into an anonymous mode when using certain activities eg when posting to a forum, so that the user's real identity cannot be ascertained by other non-privileged users.
Possible Use Cases
- Activity: for example a forum may be switched into anonymous mode by teacher rendering all posts anonymous.
- User: a user may choose to participate in an activity anonymously. In this case the teacher would switch the activity into an optional mode. For example, the forum module, when posting to a forum in an optional anonymous mode, the student could choose at the time of posting whether the post should be anonymous;
- Role Play: a teacher may choose to run the whole course in an anonymous mode to allow students to role play. In this case the anonymous mode will be forced to "yes" in the course settings.
Settings
Global
Course
Activity
User Profile
Code Changes
New Table
A new table user_course_alias will be added
field | type | description |
---|---|---|
id | int | autoincrement |
userid | int | id from the user table |
courseid | int | id from the course table |
alias | string | the user's alias for this given course |
Core Code
The fullname function in lib/moodlelib.php will need to be changed. Currently it is defined as:
function fullname($user, $override=false)
where the user object is only required to contain firstname and lastname properties.
Proposed changes are:
function fullname($user, $override=false, $courseid=null, $link=false, $anonymous=null, $viewanonymous=false)
where the user object is required to contain firstname, lastname, alias
So what do we return?
$anonymous | $viewanonymous | return example |
---|---|---|
no | no | firstname lastname |
no | yes | firstname lastname |
yes | no | alias |
yes | yes | alias (firstname lastname) |
backwards compatbility
- If no anonymous mode is given then we check the current context to see if anonymous mode should be running. Check activity, course, global settings and determine anonymity status. We can grab the current context from the $PAGE object, otherwise find another way to do it.
- If no alias property is defined in the user object then we return get_string('anonymoususer') ie a global, default string;