NAME
WebService::Moodle::Simple - Client API and CLI for Moodle Web Services
SYNOPSIS
CLI
moodlews login - login with your Moodle password and retrieve token
moodlews add_user - Create a Moodle user account
moodlews get_users - Get all users
moodlews enrol - Enrol user into a course
moodlews set_password - Update a user account password
API
use WebService::Moodle::Simple;
my $moodle = WebService::Moodle::Simple->new(
domain => 'moodle.example.edu',
target => 'example_webservice'
);
my $rh_token = $moodle->login( username => 'admin', password => 'p4ssw0rd');
DESCRIPTION
WebService::Moodle::Simple is Client API and CLI for Moodle Web Services
__THIS IS A DEVELOPMENT RELEASE. API MAY CHANGE WITHOUT NOTICE__.
USAGE
CLI
Get instructions on CLI usage
moodlews
Example - Login and Get Users
moodlews login -u admin -d moodle.example.edu -p p4ssw0rd -t example_webservice
Retrieve the user list using the token returned from the login command
moodlews get_users -o becac8d120119eb2a312a385644eb709 -d moodle.example.edu -t example_webservice
Unit Tests
prove -rlv t
Full Unit Tests
TEST_WSMS_ADMIN_PWD=p4ssw0rd \
TEST_WSMS_DOMAIN=moodle.example.edu \
TEST_WSMS_TARGET=example_webservice prove -rlv t
__NOTE: Full unit tests write to Moodle Database - only run them against a test Moodle server__.
Methods
$OBJ->login( username => str, password => str, )
Returns { msg => str, ok => bool, token => str }
$OBJ->set_password( username => str, password => str, token => str, )
$OBJ->add_user( firstname => str, lastname => str, email => str, username => str, password => str, token => str, )
$OBJ->get_users( token => str, )
$OBJ->enrol_student( username => str, course => str, token => str, )
$OBJ->get_course_id( short_cname => str, token => str, )
$OBJ->get_user( token => str, username => str, )
$OBJ->suspend_user( token => str, username => str, suspend => bool default TRUE )
If suspend is true/nonzero (which is the default) it kills the user's session and suspends their account preventing them from logging in. If suspend is false they are given permission to login. NOTE: This will only work if the Moodle server has had this patch (or its equivalent) applied: https://github.com/fabiomsouto/moodle/compare/MOODLE_22_STABLE...MDL-31465-MOODLE_22_STABLE
$OBJ->raw_api( method => moodle webservice method name, token => str, params => hashref of method parameters )
returns Moodle's response.
AUTHOR
Andrew Solomon <andrew@geekuni.com>
COPYRIGHT
Copyright 2014- Andrew Solomon
ACKNOWLEDGEMENT
Built by Dist::Milla
LICENSE
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.