Diferència entre revisions de la pàgina «Moodle API»

De Cacauet Wiki
Salta a la navegació Salta a la cerca
Línia 32: Línia 32:
  
 
== PHP ==
 
== PHP ==
 +
He utilitzat aquests recursos:
 +
* Llibreria una mica adaptada pel Moodle per facilitar les crides CURL: https://github.com/moodlehq/sample-ws-clients/blob/master/PHP-REST/curl.php
 +
* http://stackoverflow.com/questions/33404353/php-create-user-in-moodle-via-webservice
 +
 +
Aquest codi m'ha funcionat amb Moodle 2.9:
 +
<syntaxhighlight lang="php">
 +
 +
<?php
 +
require_once("curl.php");
 +
 +
$courses=array("courses" =>
 +
            array(
 +
                0=>array(
 +
                    "fullname" => "CURS DE TEST2",
 +
                    "shortname" => "test2",
 +
                    "categoryid" => 4
 +
                )
 +
            )
 +
        );
 +
 +
// prep url call
 +
$token = "xxxyyyzzz";
 +
$server = "https://el.meu.moodle.com/webservice/rest/server.php";
 +
$getparams = "?wstoken=".$token."&wsfunction=core_course_create_courses";
 +
$url = $server.$getparams;
 +
$params = $courses;
 +
 +
// exec
 +
$curl = new curl();
 +
$resp = $curl->post($url, $params);
 +
var_dump($resp);
 +
 +
</syntaxhighlight>
  
 
<br>
 
<br>
 
  
 
== Python ==
 
== Python ==
  
 
<br>
 
<br>

Revisió del 14:43, 3 maig 2017

Introducció

El CMS Moodle disposa d'una API per accedir a les seves funcions internes i afegir funcionalitat com, per exemple, crear cursos automàticament des d'un script.

La API és accessible de diferents maneres (SOAP, REST, etc.) de les quals ens interessa REST.

Per activar-la haurem de seguir les passes (són unes quantes) que s'indica dintre del mateix moodle, a la secció:

Site Administration -> Plugins -> Web Services -> Overview

Un cop hagueu creat un rol i usuari amb els permisos adequats per a la API, finalment podeu seguir les passes descrites a la web per accedir a la API:

  • Demanar token
  • Executar funció

Explicat aquí:

https://docs.moodle.org/dev/Creating_a_web_service_client


Custom functions

Això només cal si hem fet funcions personalitzades dins el moodle. Per la API estàndard no cal.

Típicament dóna un error.

Can not find data record in database table external_functions.

Es veu que passa quan creem una nova funció personalitzada a la API. Cal actualitzar unes taules, i això no passa automàticament.

Per forçar l'actualització de les funcions aquí suggereixen elevar la versió de version.php i així el moodle automàticament farà un upgrade.

http://stackoverflow.com/questions/38891022/moodle-custom-service-creation-issue

Un cop fet l'upgrade simulat, tindrem disponible la nova funció.


PHP

He utilitzat aquests recursos:

Aquest codi m'ha funcionat amb Moodle 2.9:

<?php
require_once("curl.php");

$courses=array("courses" =>
            array(
                0=>array(
                    "fullname" => "CURS DE TEST2",
                    "shortname" => "test2",
                    "categoryid" => 4
                )
            )
        );

// prep url call
$token = "xxxyyyzzz";
$server = "https://el.meu.moodle.com/webservice/rest/server.php";
$getparams = "?wstoken=".$token."&wsfunction=core_course_create_courses";
$url = $server.$getparams;
$params = $courses;

// exec
$curl = new curl();
$resp = $curl->post($url, $params);
var_dump($resp);


Python