Skip to content

Commit

Permalink
MDL-17135 fixing XSRF regression; adding description and removing inc…
Browse files Browse the repository at this point in the history
…omplete support for localised function names; removing string that will not be used in final version of UI (this would only confuse&slow down translators)
  • Loading branch information
skodak committed Oct 21, 2009
1 parent cfb99b7 commit e97ccab
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 44 deletions.
52 changes: 21 additions & 31 deletions admin/webservice/service_functions.php
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@

require_once('../../config.php');
require_once($CFG->libdir.'/adminlib.php');
require_once($CFG->libdir.'/externallib.php');

$id = required_param('id', PARAM_INT);
$fid = optional_param('fid', 0, PARAM_INT);
Expand Down Expand Up @@ -55,53 +56,41 @@
$DB->delete_records('external_services_functions', array('externalserviceid'=>$service->id, 'functionname'=>$function->name));
redirect($thisurl);

} else if ($action === 'add') {

if (optional_param('save', 0, PARAM_ACTION)) {
} else if ($action === 'add' and confirm_sesskey() and $service and empty($service->component)) {

if ($fid and $function = $DB->get_record('external_functions', array('id'=> $fid))) {
ignore_user_abort(true); // no interruption here!
$functionname = optional_param('function', 0, PARAM_ACTION);
if (!empty($functionname)) {
$function = $DB->get_record('external_functions', array('name'=> $functionname), '*', MUST_EXIST);
// make sure the function is not there yet
if ($DB->record_exists('external_services_functions', array('externalserviceid'=>$service->id, 'functionname'=>$function->name))) {
redirect($thisurl);
}
$new = new object();
$new->externalserviceid = $service->id;
$new->functionname = $functionname;
$DB->insert_record('external_services_functions', $new);
// make sure the function is not there yet
if ($DB->record_exists('external_services_functions', array('externalserviceid'=>$service->id, 'functionname'=>$function->name))) {
redirect($thisurl);
}
else {
$errormessage = get_string('nofunctionselected', 'webservice');
}

$new = new object();
$new->externalserviceid = $service->id;
$new->functionname = $function->name;
$DB->insert_record('external_services_functions', $new);
redirect($thisurl);
}

// Prepare the list of function to choose from
$select = "name NOT IN (SELECT s.functionname
FROM {external_services_functions} s
WHERE s.externalserviceid = :sid
)";
$functions = $DB->get_records_select_menu('external_functions', $select, array('sid'=>$id), 'name', 'id, name');
$functionchoices = array();

foreach ($functions as $functionname) {
$functionchoices[$functionname] = $functionname . ': ' . get_string($functionname, 'servicedescription');
}
$functionchoices = $DB->get_records_select_menu('external_functions', $select, array('sid'=>$id), 'name', 'id, name');

// Javascript for the function search/selection fields
$PAGE->requires->yui_lib('event');
$PAGE->requires->js($CFG->admin.'/webservice/script.js');
$PAGE->requires->js_function_call('capability_service.cap_filter_init', array(get_string('search'))); //TODO generalize javascript

admin_externalpage_print_header();
if (!empty($errormessage)) {
echo $OUTPUT->notification($errormessage);
}

echo $OUTPUT->heading($service->name);
echo $OUTPUT->box_start('generalbox boxwidthwide boxaligncenter centerpara');
echo $OUTPUT->box_start('generalbox boxwidthwide boxaligncenter centerpara');

//TODO: hmm, is this supposed to be replaced by the roles UI, right? If not the use of output lib is definitely wrong, we need more buttons (Cancel!) and custom JS, etc.
//TODO: add JS disabling of submit button if no functio nselected, the error string is not user friendly

//the service form
$form = new html_form();
$form->url = new moodle_url('service_functions.php', array('id' => $id, 'action' => 'add', 'save' => 1)); // Required
Expand All @@ -117,8 +106,9 @@
//function section (search field + selection field)
$select = new html_select();
$select->options = $functionchoices;
$select->name = 'function';
$select->name = 'fid';
$select->id = 'menucapability'; //TODO generalize javascript
$select->nothinglabel = '';
$select->nothingvalue = '';
$select->listbox = true;
$select->tabindex = 0;
Expand Down Expand Up @@ -163,8 +153,8 @@
$durl = "service_functions.php?sesskey=".sesskey();

foreach ($functions as $function) {
//TODO: manage when the description is into a module/plugin lang file
$description = "<span style=\"font-size:90%\">".get_string($function->name,'servicedescription')."</span>";
$function = external_function_info($function);
$description = "<span style=\"font-size:90%\">".$function->description."</span>"; //TODO: must use class here!
if (empty($service->component)) {
$delete = "<a href=\"$durl&amp;action=delete&amp;fid=$function->id&amp;id=$service->id\">$strdelete</a>";
$table->data[] = array($function->name, $description, $delete);
Expand Down
12 changes: 0 additions & 12 deletions lang/en_utf8/servicedescription.php

This file was deleted.

1 change: 0 additions & 1 deletion lang/en_utf8/webservice.php
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@
$string['functions'] = 'Functions';
$string['iprestriction'] = 'IP restriction';
$string['manageprotocols'] = 'Manage protocols';
$string['nofunctionselected'] = 'Please select a function to add';
$string['potusers'] = 'Not authorised users';
$string['potusersmatching'] = 'Not authorised users matching';
$string['protocol'] = 'Protocol';
Expand Down

0 comments on commit e97ccab

Please sign in to comment.