]> git.mjollnir.org Git - moodle.git/commitdiff
Merged MDL-13676: last-minute field change to fix an Oracle problem
authormoodler <moodler>
Fri, 29 Feb 2008 08:44:23 +0000 (08:44 +0000)
committermoodler <moodler>
Fri, 29 Feb 2008 08:44:23 +0000 (08:44 +0000)
admin/roles/assign.php
admin/roles/override.php
course/edit_form.php
course/lib.php
group/lib.php
lib/accesslib.php
lib/db/install.xml
lib/db/upgrade.php
version.php

index 2e46637536f83e7bd09f4fae294f96bb5ba66a51..fe574597abc0da3ce3ecd48f39e93c1beabf83f0 100755 (executable)
         if ($aliasnames = get_records('role_names', 'contextid', $coursecontext->id)) {
             foreach ($aliasnames as $alias) {
                 if (isset($assignableroles[$alias->roleid])) {
-                    $assignableroles[$alias->roleid] = $alias->text.' ('.$assignableroles[$alias->roleid].')';
+                    $assignableroles[$alias->roleid] = $alias->name.' ('.$assignableroles[$alias->roleid].')';
                 }
             }
         }
index 4a76aeb5a938dc86ddf5d42c2eeb17a359008169..27a6c8518dfd3f93849d685b5e8bc5e904b9c7bc 100755 (executable)
         if ($aliasnames = get_records('role_names', 'contextid', $coursecontext->id)) {
             foreach ($aliasnames as $alias) {
                 if (isset($overridableroles[$alias->roleid])) {
-                    $overridableroles[$alias->roleid] = $alias->text.' ('.$overridableroles[$alias->roleid].')';
+                    $overridableroles[$alias->roleid] = $alias->name.' ('.$overridableroles[$alias->roleid].')';
                 }
             }
         }
index ac9b4e9afe3d3add4210b0d009c614b166813ae2..1b1c976014e9b80df1bc3acf3e578876fd64a2cb 100644 (file)
@@ -377,7 +377,7 @@ class course_edit_form extends moodleform {
                 $mform->addElement('text', 'role_'.$role->id, $role->name);
                 if ($coursecontext) {
                     if ($rolename = get_record('role_names', 'roleid', $role->id, 'contextid', $coursecontext->id)) {
-                        $mform->setDefault('role_'.$role->id, $rolename->text); 
+                        $mform->setDefault('role_'.$role->id, $rolename->name); 
                     }  
                 }
             }
index 2ea0de8e6beb67aeb2ce8409ab3ccdf69bd2a635..567d0b0715a1fb772ca0fae70acc67f349bf307a 100644 (file)
@@ -1861,7 +1861,7 @@ function print_course($course) {
                 
                  /// Rename some of the role names if needed
                 if (isset($context)) {
-                    $aliasnames = get_records('role_names', 'contextid', $context->id,'','roleid,contextid,text');
+                    $aliasnames = get_records('role_names', 'contextid', $context->id,'','roleid,contextid,name');
                 }
 
                 foreach ($rusers as $ra) {
@@ -1869,7 +1869,7 @@ function print_course($course) {
                         $fullname = fullname($ra->user, $canviewfullnames); 
 
                         if (isset($aliasnames[$ra->roleid])) {
-                            $ra->rolename = $aliasnames[$ra->roleid]->text;
+                            $ra->rolename = $aliasnames[$ra->roleid]->name;
                         }
 
                         $namesarray[] = format_string($ra->rolename) 
@@ -2925,14 +2925,14 @@ function update_course($data) {
             
             } else if ($t = get_record('role_names', 'contextid', $context->id, 'roleid', $roleid)) {
                 
-                $t->text = $dvalue;
+                $t->name = $dvalue;
                 update_record('role_names', $t);    
                        
             } else {
                 
                 $t->contextid = $context->id;
                 $t->roleid = $roleid;
-                $t->text = $dvalue;
+                $t->name = $dvalue;
                 insert_record('role_names', $t);  
             }
             
index 8f9d38311b74cac89b5e20b7c161bbbb8048e57a..1e27f5c813029451c1729bf3c95f30acebdbeb44 100644 (file)
@@ -559,7 +559,7 @@ function groups_calculate_role_people($rs,$contextid) {
     }
     
     // Get role aliases for course in array of roleid => obj->text
-    if(!($aliasnames=get_records('role_names','contextid',$contextid,'','roleid,text'))) {
+    if(!($aliasnames=get_records('role_names','contextid',$contextid,'','roleid,name'))) {
         $aliasnames=array();
     }
 
@@ -592,7 +592,7 @@ function groups_calculate_role_people($rs,$contextid) {
                 $roledata->id=$rec->roleid;
                 $roledata->shortname=$rec->roleshortname;
                 if(array_key_exists($rec->roleid,$aliasnames)) {
-                    $roledata->name=$aliasnames[$rec->roleid]->text;
+                    $roledata->name=$aliasnames[$rec->roleid]->name;
                 } else {
                     $roledata->name=$rec->rolename;
                 }
index fa9e0aa35872be63fe36f57839304e353a8ce278..c62f1b6b753b230b01abcc702ea6927ea2cafd05 100755 (executable)
@@ -4027,16 +4027,25 @@ function get_user_roles_in_context($userid, $context, $view=true){
 
     $rolestring = '';
     $SQL = 'select * from '.$CFG->prefix.'role_assignments ra, '.$CFG->prefix.'role r where ra.userid='.$userid.' and ra.contextid='.$context->id.' and ra.roleid = r.id';
+    $rolenames = array();
     if ($roles = get_records_sql($SQL)) {
         foreach ($roles as $userrole) {
             // MDL-12544, if we are in view mode and current user has no capability to view hidden assignment, skip it
             if ($userrole->hidden && $view && !has_capability('moodle/role:viewhiddenassigns', $context)) {
                 continue;
             }
+            $rolenames[$userrole->roleid] = $userrole->name;
             $rolestring .= '<a href="'.$CFG->wwwroot.'/user/index.php?contextid='.$userrole->contextid.'&amp;roleid='.$userrole->roleid.'">'.$userrole->name.'</a>, ';
         }
+
+        $rolenames = role_fix_names($rolenames, $context);   // Substitute aliases
+
+        foreach ($rolenames as $roleid => $rolename) {
+            $rolenames[$roleid] = '<a href="'.$CFG->wwwroot.'/user/index.php?contextid='.$context->id.'&amp;roleid='.$roleid.'">'.$rolename.'</a>';
+        }
+        $rolestring = implode(',', $rolenames);
     }
-    return rtrim($rolestring, ', ');
+    return $rolestring;
 }
 
 
@@ -4199,7 +4208,7 @@ function get_assignable_roles ($context, $field="name") {
 
     // apply context role aliases if name requested
     if ($field == 'name') {
-        $f = "COALESCE(rn.text, r.name) AS name";
+        $f = "COALESCE(rn.name, r.name) AS name";
     } else {
         $f = "r.$field";
     }
@@ -4257,7 +4266,7 @@ function get_assignable_roles_for_switchrole ($context, $field="name") {
 
     // apply context role aliases if name requested
     if ($field == 'name') {
-        $f = "COALESCE(rn.text, r.name) AS name";
+        $f = "COALESCE(rn.name, r.name) AS name";
     } else {
         $f = "r.$field";
     }
@@ -5284,7 +5293,7 @@ function user_has_role_assignment($userid, $roleid, $contextid=0) {
  */
 function role_get_name($role, $coursecontext) {
     if ($r = get_record('role_names','roleid', $role->id,'contextid', $coursecontext->id)) {
-        return strip_tags(format_string($r->text));
+        return strip_tags(format_string($r->name));
     } else {
         return strip_tags(format_string($role->name));
     }
@@ -5300,7 +5309,7 @@ function role_fix_names($roleoptions, $coursecontext) {
     if ($aliasnames = get_records('role_names', 'contextid', $coursecontext->id)) {
         foreach ($aliasnames as $alias) {
             if (isset($roleoptions[$alias->roleid])) {
-                $roleoptions[$alias->roleid] = $alias->text;
+                $roleoptions[$alias->roleid] = $alias->name;
             }
         }
     }
index d2ec5ebc2f091028636ac311ed22163e0463377a..24b58eec8f7c5272d8d25f020e209d8e768e0797 100644 (file)
@@ -1,5 +1,5 @@
 <?xml version="1.0" encoding="UTF-8" ?>
-<XMLDB PATH="lib/db" VERSION="20080227" COMMENT="XMLDB file for core Moodle tables"
+<XMLDB PATH="lib/db" VERSION="20080229" COMMENT="XMLDB file for core Moodle tables"
     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xsi:noNamespaceSchemaLocation="../../lib/xmldb/xmldb.xsd"
 >
         <FIELD NAME="id" TYPE="int" LENGTH="10" NOTNULL="true" UNSIGNED="true" SEQUENCE="true" ENUM="false" NEXT="roleid"/>
         <FIELD NAME="roleid" TYPE="int" LENGTH="10" NOTNULL="true" UNSIGNED="true" DEFAULT="0" SEQUENCE="false" ENUM="false" PREVIOUS="id" NEXT="contextid"/>
         <FIELD NAME="contextid" TYPE="int" LENGTH="10" NOTNULL="true" UNSIGNED="true" DEFAULT="0" SEQUENCE="false" ENUM="false" PREVIOUS="roleid" NEXT="text"/>
-        <FIELD NAME="text" TYPE="text" LENGTH="small" NOTNULL="true" SEQUENCE="false" ENUM="false" PREVIOUS="contextid"/>
+        <FIELD NAME="text" TYPE="text" LENGTH="small" NOTNULL="true" SEQUENCE="false" ENUM="false" PREVIOUS="contextid" NEXT="name"/>
+        <FIELD NAME="name" TYPE="char" LENGTH="255" NOTNULL="true" SEQUENCE="false" ENUM="false" PREVIOUS="text"/>
       </FIELDS>
       <KEYS>
         <KEY NAME="primary" TYPE="primary" FIELDS="id" NEXT="roleid"/>
index f97ef022c7d3bf894ae52b95bc7589d7e353d698..9c377d8688972e90519f76af53588903940b87b0 100644 (file)
@@ -2921,6 +2921,29 @@ function xmldb_main_upgrade($oldversion=0) {
         upgrade_main_savepoint($result, 2007101508.07);
     }
 
+    if ($result && $oldversion < 2007101508.08) {    // MDL-13676
+
+    /// Define field name to be added to role_names
+        $table = new XMLDBTable('role_names');
+        $field = new XMLDBField('name');
+        $field->setAttributes(XMLDB_TYPE_CHAR, '255', null, XMLDB_NOTNULL, null, null, null, null, 'text');
+
+    /// Launch add field name
+        $result = $result && add_field($table, $field);
+    /// Copy data from old field to new field
+        $result = $result && execute_sql('UPDATE '.$CFG->prefix.'role_names SET name = text');
+
+    /// Define field text to be dropped from role_names
+        $table = new XMLDBTable('role_names');
+        $field = new XMLDBField('text');
+
+    /// Launch drop field text
+        $result = $result && drop_field($table, $field);
+
+    /// Main savepoint reached
+        upgrade_main_savepoint($result, 2007101508.08);
+    }
 
 
     return $result;
index a50787ef116eee8e3af0189ac7b78ca6a00df67b..33d6881f99f4f5a134761c149bcdfa9c99dc2a98 100644 (file)
@@ -6,7 +6,7 @@
 // This is compared against the values stored in the database to determine
 // whether upgrades should be performed (see lib/db/*.php)
 
-    $version = 2007101508.07;  // YYYYMMDD      = date of the 1.9 branch (don't change)
+    $version = 2007101508.08;  // YYYYMMDD      = date of the 1.9 branch (don't change)
                                //         X     = release number 1.9.[0,1,2,3...]
                                //          Y.YY = micro-increments between releases