dlnsk/uqfi

Universal question format importer

Installs: 4

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

Open Issues: 0

pkg:composer/dlnsk/uqfi

v0.1.4 2025-12-09 08:00 UTC

This package is auto-updated.

Last update: 2025-12-10 10:01:12 UTC


README

Overview

Universal question format importer is a wrapper to native Moodle's question engine. It uses code of Moodle format imports as is. Some classes and libraries are replaced by stub.

It supports next question's bank formats:

  1. GIFT
  2. AIKEN
  3. MissingWord
  4. MoodleXML
  5. BlackBoard 6

Installation

Simply add a dependency on dlnsk/uqfi to your project's composer.json file if you use Composer to manage the dependencies of your project. Use following command to add the package to your project's dependencies:

composer require dlnsk/uqfi

Usage

// Autoload the dependencies
require 'vendor/autoload.php';

// Initialize library
\Dlnsk\UQFI\Importer::init();

// Use
$format = Dlnsk\UQFI\Importer::getFormat('gift', $file_path);
$questions = $format->readQuestions();

Laravel

If you're going to use this package in Laravel, you don't need to load dependencies and initialise. Just use.

Methods

init()

Importer::init();

Some simple steps to fool Moodle native library.

getFormat()

$format = Importer::getFormat($format, $file_path);

Creates a formatter class for given format and file. The format parameter can be one of "gift", "aiken", "missingword", "moodlexml" or "blackboard6". Keep in mind that "blackboard6" format require zip file as source of a questions bank.

You also can directly create a necessary class:

$format = new Gift($file_path);

readQuestions()

$questions = $format->readQuestions();

Returns the set of question objects with native Moodle structure. This structure maybe good to save questions into Moodle database, but not quite well to use.

readDecoratedQuestions()

$questions = $format->readDecoratedQuestions();

Returns a set of question objects with a slightly fixed structure. We move some dependent fields into parent elements, transform files' data, and so on. The structure of a decorated question is quite close to MoodleXML file.

See BaseFormat class for some helpful methods.