Skip to content

Commit

Permalink
webservice MDL-17135 add notification when the current required capab…
Browse files Browse the repository at this point in the history
…ility doesn't exist anymore + remove TODO comment about checking that the service names are unique because we should end up to find a way to i18n service names => The uniqueness should be checked during service discovery
  • Loading branch information
mouneyrac committed Nov 5, 2009
1 parent 09179b7 commit cf9235d
Showing 1 changed file with 23 additions and 15 deletions.
38 changes: 23 additions & 15 deletions admin/webservice/forms.php
Original file line number Diff line number Diff line change
Expand Up @@ -37,32 +37,43 @@ function definition() {
$mform->addElement('text', 'name', get_string('name'));
$mform->addRule('name', get_string('required'), 'required', null, 'client');
$mform->addElement('advcheckbox', 'enabled', get_string('enabled', 'webservice'));



/// needed to select automatically the 'No required capability" option
$currentcapabilityexist = false;
if (empty($service->requiredcapability))
{
$service->requiredcapability = "norequiredcapability";
$currentcapabilityexist = true;
}

// Prepare the list of capabilites to choose from
$systemcontext = get_context_instance(CONTEXT_SYSTEM);
$allcapabilities = fetch_context_capabilities($systemcontext);
$capabilitychoices = array();
$capabilitychoices['norequiredcapability'] = get_string('norequiredcapability', 'webservice');
foreach ($allcapabilities as $cap) {
$capabilitychoices[$cap->name] = $cap->name . ': ' . get_capability_string($cap->name);
if (!empty($service->requiredcapability) && $service->requiredcapability == $cap->name) {
$currentcapabilityexist = true;
}
}

$mform->addElement('searchableselector', 'requiredcapability', get_string('requiredcapability', 'webservice'),$capabilitychoices, array('size' => 12));
// TODO: change to capability selection or even better if new forms element used,
// we also need to indicate if current capability does not exist in system!
$mform->addElement('searchableselector', 'requiredcapability', get_string('requiredcapability', 'webservice'), $capabilitychoices, array('size' => 12));

/// display notification error if the current requiredcapability doesn't exist anymore
if(empty($currentcapabilityexist)) {
global $OUTPUT;
$mform->addElement('static', 'capabilityerror', '', $OUTPUT->notification(get_string('selectedcapabilitydoesntexit','webservice', $service->requiredcapability)));
$service->requiredcapability = "norequiredcapability";
}
$mform->addElement('advcheckbox', 'restrictedusers', get_string('restrictedusers', 'webservice'));

$mform->addElement('hidden', 'id');
$mform->setType('id', PARAM_INT);

$this->add_action_buttons(true);

///this three lines are needed to select automatically the 'No required capability" option
if (empty($service->requiredcapability))
{
$service->requiredcapability = "norequiredcapability";
}


$this->set_data($service);
}

Expand All @@ -77,10 +88,7 @@ function definition_after_data() {
}

function validation($data, $files) {
$errors = parent::validation($data, $files);

//TODO: better make sure the service name is unique

$errors = parent::validation($data, $files);
return $errors;
}
}

0 comments on commit cf9235d

Please sign in to comment.