Skip to content

Commit

Permalink
MDL-47965 tag: Enforcing security of tag auto completion
Browse files Browse the repository at this point in the history
  • Loading branch information
Frederic Massart authored and Sam Hemelryk committed Nov 3, 2014
1 parent babaf59 commit 5d0b3b2
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 9 deletions.
2 changes: 1 addition & 1 deletion tag/tag.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,13 +10,13 @@ YUI().use('yui2-autocomplete', 'yui2-datasource', 'yui2-animation', 'yui2-connec
fieldDelim: "\t"
};
myDataSource.maxCacheEntries = 60;
myDataSource.minQueryLength = 3;

// Instantiate the AutoComplete
var myAutoComp = new Y.YUI2.widget.AutoComplete("id_relatedtags", "relatedtags-autocomplete", myDataSource);
document.getElementById('id_relatedtags').style.width = '30%';
myAutoComp.allowBrowserAutocomplete = false;
myAutoComp.maxResultsDisplayed = 20;
myAutoComp.minQueryLength = 3;
myAutoComp.delimChar = [","," "];
myAutoComp.formatResult = function(oResultData, sQuery, sResultMatch) {
return (sResultMatch);
Expand Down
32 changes: 24 additions & 8 deletions tag/tag_autocomplete.php
Original file line number Diff line number Diff line change
Expand Up @@ -27,16 +27,32 @@
require_once('../config.php');
require_once('lib.php');

require_login();

if (empty($CFG->usetags)) {
print_error('tagsaredisabled', 'tag');
// Tags are disabled.
die();
}

require_login(0, false);
if (isguestuser()) {
// Guests should not be using this.
die();
}

$query = optional_param('query', '', PARAM_RAW);
// If a user cannot edit tags, they cannot add related tags which is what this auto complete is for.
require_capability('moodle/tag:edit', context_system::instance());

$query = optional_param('query', '', PARAM_TAG);

if ($similar_tags = tag_autocomplete($query)) {
foreach ($similar_tags as $tag) {
echo clean_param($tag->name, PARAM_TAG) . "\t" . tag_display_name($tag) . "\n";
}
echo $OUTPUT->header();

// Limit the query to a minimum of 3 characters.
$similartags = array();
if (core_text::strlen($query) >= 3) {
$similartags = tag_autocomplete($query);
}

foreach ($similartags as $tag) {
echo clean_param($tag->name, PARAM_TAG) . "\t" . tag_display_name($tag) . "\n";
}

echo $OUTPUT->footer();

0 comments on commit 5d0b3b2

Please sign in to comment.