There is no license information available for the latest version (0.1.3) of this package.

A Laravel package to authenticate against Moodle and retrieve course data

0.1.3 2023-03-09 08:45 UTC

This package is auto-updated.

Last update: 2024-04-17 17:19:41 UTC


README

A Laravel package to authenticate with Moodle and retrieve course information.

Installation

composer require networkrailbusinesssystems/laravel-moodle

The package should auto register the service providers.

Migrations

The package includes a migration to make the password column nullable and adds a username field to the users table.

php artisan migrate

Configuration

Optionally, publish the config file. This is required if you want to customise which fields are synchronised from Moodle to your user model.

php artisan vendor:publish

Update your auth.php config file, providers > users > drivers to moodle

Update the .env file with the MOODLE_BASE_URL with the url of your Moodle installation and MOODLE_ADMIN_TOKEN with a token for an existing user that has permission to search existing users.

User Model

When a user logs in for the first time their email, username and id are set from Moodle in the user model. If you want to customise the fields that are synchronised then publish the laravel-moodle config file and update the sync_attributes array.

Any fields that you synchronise will need to added to the protected $fillable array in your User model.

If you want to use a different model to App\User then update the user_model in the laravel-moodle config file.

Credentials

The package expects the credentials from the LoginController to be an array containing username and password, but if you want to use username instead then add MOODLE_LOGIN_ATTRIBUTE=username to your .env file.

Users set as a Site Administrator in Moodle will not be able to login using LaravelMoodle until they manually generate a token for their account as per step #5 below.

Middleware

The package contains a middleware that you can use to check if the user has a moodle token in their session. If they don't it will log the user out from their Laravel session and redirect the user ot the login page.

To use globally list the NetworkRailBusinessSystems\LaravelMoodle\Middleware\MoodleToken::class in the $middleware property of app/Http/Kernel.php.

To use on specific routes add 'laravel-moodle' => \NetworkRailBusinessSystems\LaravelMoodle\Middleware\MoodleToken::class to the $routeMiddleware in app/Http/Kernel.php and then add to your route.

Route::get('/', function () {})->middleware('laravel-moodle');

Moodle Configuration

In order to access data from Moodle, it needs to be configured first as the web service features are disabled by default.

  1. Enable Web Services for mobile devices
    • Site Administration > Mobile app > Mobile settings
    • Enable web services for mobile devices - yes
    • Save changes
  2. Enable Web Services (yes, again)
    • Site Administration > Advanced features
    • Enable Web Services - yes
    • Save changes
  3. Create new webservice
    • Site Administration > Plugins > Web services > External Services
    • Add Custom Service or use an existing custom service
      • Name: Web Service
      • Short name: web_service
      • Enabled: true
      • Authorised users only: false
      • Can download files: true
      • Save changes
  4. Enable the following functions in the new Moodle web service
    • Site Administration > Plugins > Web services > External Services
    • On the newly created Web Service, click functions and add the following
      • core_badges_get_user_badges
      • core_calendar_get_calendar_monthly_view
      • core_completion_get_activities_completion_status
      • core_completion_get_course_completion_status
      • core_course_get_categories
      • core_course_get_contents
      • core_course_get_course_module
      • core_course_get_courses
      • core_course_get_courses_by_field
      • core_course_search_courses
      • core_enrol_get_enrolled_users
      • core_user_get_users
      • enrol_manual_enrol_users
      • enrol_manual_unenrol_users
      • enrol_self_enrol_user
      • gradereport_overview_get_course_grades
      • mod_assign_get_assignments
      • mod_assign_get_submissions
      • mod_assign_get_submission_status
      • mod_assign_save_submission
      • mod_page_get_pages_by_courses
      • mod_page_view_page
      • mod_resource_get_resources_by_courses
      • mod_resource_view_resource
      • mod_book_get_books_by_courses
      • mod_scorm_get_scorm_scoes
      • mod_scorm_get_scorms_by_courses
  5. Create a token for the admin user (used in the Laravel .env file)
    • Site Administration > Plugins > Web services > Manage tokens
    • Click Add
      • Search for the admin user you want to use
      • Select your Web Service
      • Save changes
  6. Allow users to create tokens for the new Web Service so they can create a token when they log in
    • Site Administration > Users > Define Roles
    • Edit Authenticated user
    • Capabilities > Create a web service token > Allow
    • Save

Endpoints

Use the LaravelMoodle facade to access the web service data.

use NetworkRailBusinessSystems\LaravelMoodle\LaravelMoodle as LaravelMoodle;

The package uses Spatie Data Transfer Objects to format the response into objects.

Get Courses

Returns a collection of courses.

$data = LaravelMoodle::getCourses();

foreach ($data->courses as $course) {
    echo $course->fullname; // My First Course
}

echo $data->courses[0]->fullname; // My First Course

To filter the list of courses pass in the term and the field. you can use id, ids, shortname and category id.

// Get course with id 3
$data = LaravelMoodle::getCourses('2', 'id');

// Get courses with ids 2 & 3
$data = LaravelMoodle::getCourses('2,3', 'ids');

Get Course By Id

Once you know the course ID (int) you can get a specific course.

$course = LaravelMoodle::getCourse(2);

echo $course->fullname; // My First Course

Search Courses

Pass in your search term as the first parameter (string).

$searchResults = LaravelMoodle::searchCourses('search term');

echo $searchResults->total; // 1
echo $searchResults->courses[0]->fullname; // My First Course

Optionally pass in page number (integer) and per page (integer).

$searchResults = LaravelMoodle::searchCourses('search term', 2, 15);

You can also limit the search to only enrolled courses by specifying 1 as the 4th parameter.

$searchResults = LaravelMoodle::searchCourses('search term', 2, 15, 1);

Get Course Contents By Id

Once you know the course Id you can get the contents of a specific course.

$courseContents = LaravelMoodle::getCourseContents(1);

echo $courseContents[0]->name; // Topic name
echo $courseContents[0]->modules[0]->name; // Activity name

Get Course Module By Id

Once you know the module id from the course contents you can get more details about the module.

$module = LaravelMoodle::getCourseModule(11);

echo $module->cm->name; // Topic name

Get Course Pages

Once you know the course id you can get the pages for the course.

$pages = LaravelMoodle::getCoursePages(1);

echo $pages->pages[0]->name; // Page name

Get Course Page

Get a specific course page by module id.

$page = LaravelMoodle::getCoursePage($courseId, $moduleId);

Get Course Scorms

Once you know the course id you can get the scorms for the course.

$scorms = LaravelMoodle::getCourseScorms(1);

echo $scorms->scorms[0]->name; // Example scorm

Get Course Scorm

Get a specific course scorm by module id.

$scorm = LaravelMoodle::getCourseScorm($courseId, $moduleId);

Get Course Resources

Once you know the course id you can get the resources.

$resources = LaravelMoodle::getCourseResources(1);
echo $resources->resources[0]->name;

Get Course Resource

Get a specific course resource by module id.

$resource = LaravelMoodle::getCourseResource($courseId, $moduleId);

Get Course Completion

You can get the course completion status by passing in the user id and the course id.

$completion = LaravelMoodle::getCourseCompletion(2, 2);

Get Course Activities Completion

You can get details of a course's activities completion by passing in the user id and the course id.

$activities = LaravelMoodle::getCourseActivitiesCompletion(2, 2);

echo $activities->statuses[0]->state;

Get Course Assignments

Get the assignments for a specific course by passing in the course id.

$data = LaravelMoodle::getCourseAssignments(2);

echo $data->courses[0]->assignments[0]->name;
echo $data->courses[0]->assignments[0]->id;

Get Course Assignment

Get a specific course assignment by the module id.

$assignment = LaravelMoodle::getCourseAssignment($courseId, $moduleId);

Get Assignment Submission Status

Provides information on the previous attempts for an assignment. User id is optional as it defaults to the current user.

LaravelMoodle::getAssignmentSubmissionStatus($assignmentId, $userId);

Save Course Assignment

Submit the online text for a specific assignment. Returns true on success.

$submit = LaravelMoodle::saveCourseAssignment($assignmentId, 'The content');

echo $submit; // true

If there is an issue submitting then an array of warnings will be returned, with the error details in the item and message.

$submit = LaravelMoodle::saveCourseAssignment($assignmentId, '');

echo $submit[0]->item; // Nothing was submitted
echo $submit[0]->message; // Could not save submission

Get User Grades

Get the grades for a user. Default to 0 for the current logged in user.

$grades = LaravelMoodle::getUserGrades();

echo $grades->grades[0]->courseid; // 2
echo $grades->grades[0]->grade; // A

Get Course Grade for User

Get the grade for a user for a specific course. Default to 0 for the current logged in user. Returns null for grade if course not found.

$grade = LaravelMoodle::getCourseGrade(2);

echo $grade->courseid; // 2
echo $grade->grade; // A

Search Users

Search for users. Default search field is username if not provided.

// Defaults to searching by username
$users = LaravelMoodle::searchUsers('testuser');

// Override to search by email address
$users = LaravelMoodle::searchUsers('test.user@fake.email', 'email');

echo $users->users[0]->fullname; // Test User

Enrol User On A Course

You can enrol a user onto a course by specifying the user id then the course id. By default they have the student role, but you can specify the role id.

The user performing the call must be an Admin or Manager in Moodle or a teacher in the course.

There is a null response from Moodle when successful, but enrolUserOnCourse returns true when successful and MoodleException if it fails.

// Defaults role to student
LaravelMoodle::enrolUserOnCourse(2, 2);

// Override role to editing teacher
LaravelMoodle::enrolUserOnCourse(2, 2, 3);

Unenrol User On A Course

You can unenrol a user on a course. Role id is not required. It will default to the student role.

LaravelMoodle::unenrolUserOnCourse($userId, $courseId, $roleId);

Get Enrolled Users For A Course

You can get a collection of users enrolled on a course. These are Moodle users and not Laravel user models.

$enrolledUsers = LaravelMoodle::getEnrolledUsersForCourse(2);

echo $enrolledUsers[0]->fullname; // Test User
echo $enrolledUsers[0]->roles[0]->shortname; // Student

Get Categories

Get all categories.

$categories = LaravelMoodle::getCategories();

echo $categories[0]->name; // Category name

Search Categories

Search for categories. Defaults to searching name if second parameter isn't passed. The search term is an exact match only.

$categories = LaravelMoodle::searchCategories('Business Briefing System');

echo $categories[0]->name; // Business Briefing System

View Page Event

Trigger the view page event for activity auto completion. Pass in the page id. Returns true if successful and MoodleException if unsuccessful.

$pageViewed = LaravelMoodle::viewPageEvent(1);

dd($pageViewed); // true

HasDates Trait

The package has a HasDates trait that can be added to FlexibleDataTransferObjects to convert the timestamp from Moodle into a Carbon instance to allow easier formatting for presentation.

$data = LaravelMoodle::getCourses();

$data->courses[0]->asDate('startdate')->format('d/m/Y');
$data->courses[0]->dates()->startdate->format('d/m/Y');
$data->courses[0]->dates()->enddate->format('d/m/Y');