Quick Start Guide
A+ LMS is complex environment, but this short guide will get you going. A template course, which also works as full manual, is provided as an A+ course. This guide will go through the steps to get there.
Architecture
A+ LMS consists of multiple smaller web services that provide different features for the system. A+ front or the portal takes care of users and records for them. Other services typically provide different assessment features or other interactive course materials.
This design creates a bit of a challenge as the software is not just a single binary, but it also makes development of features flexible. Check out the architecture page for more details.
Requirements
Currently, we support Linux and macOS. You can get A+ LMS working on Windows, but it will require some skill and no documentation is provided for that. Note that you also need administrator privileges (e.g. sudo rights) to install required software. Furthermore, due to Docker you will have similar permissions any case, so there can not be other users on your machine.
Course material, including the template course, is managed using git. Git is a version-control system or more a change management tool. It is used to track changes to the course material and then to update production with a new version.
Containers are used in A+ LMS a lot, because they provide sandboxing and an easy method to deliver software images.
To run A+ LMS locally, you will need to install Docker, a containerization software.
Follow this guide to install Docker Community Edition on your machine.
In short, on Linux install docker-ce
from docker repositories and on macOS download and install Docker for Mac.
Currently, we still use docker-compose to start local testing environment, so you will need to install it too.
Follow this guide to install it.
Note that you can use path $HOME/.local/bin
to store the script as long as you add it to your PATH
(more in freedesktop file-hierarchy).
To summarize, you need these tools:
- Linux or macOS
- git
- docker-ce (Docker Community Edition, Docker for Mac)
- docker-compose
Our wiki page for A+ interns has instructions for installing docker-compose.
Start your first course
First, download a copy of the A-plus manual, it will work as your template.
Open terminal and move to a folder where you want to store your courses.
Then execute git clone https://github.com/apluslms/aplus-manual.git my_new_course
.
Move in the course folder cd my_new_course
.
Second, update git submodules as RST extensions are still distributed this way.
So, execute git submodule init && git submodule update
.
We now have the course material in the correct place and it’s ready for compilation.
We store only the source material in the git repository and final presentation and configuration files are built on your machine for local developing and on the server for production.
So, compile course material with the command ./docker-compile.sh
.
Now everything is ready for running the manual course.
Start A+ LMS with command ./docker-up.sh
.
You will see a lot of log messages from a few containers and after a while, there won’t be any new messages.
A+ LMS is now running.
To stop A+ LMS, press Q, S, ESC or CTRL+C in the terminal. S and ESC will keep the database and other files, while Q and CTRL+C will remove all data assosiated with running the system. For rapidly testing parts of your course, you can press S or ESC to stop A+ and then restart with the same data. Time to time, it’s good to remove the data, so all the test submissions are cleaned for example.
You now open http://localhost:8000 and you should see the A+ front page. Open the course and read more. The test environment has four users: teacher, assistant, student, and root. The password for every user is the same as the user name.
To summarize, execute the following:
git clone https://github.com/apluslms/aplus-manual.git my_new_course
cd my_new_course
git submodule init
git submodule update
./docker-compile.sh
./docker-up.sh
Troubles?
- Ports: you can’t have anything in ports
8000
,8080
or3000
as they are used by A+ LMS.