AGDownloader is a simple and easy-to-use downloader for AulaGlobal (the implementation of moodle by the University Carlos III of Madrid). It is a command-line tool, with an easy-to-use Terminal User Interface, that allows you to download all the files from all the courses a user has access to.
You can also indicate the course ID or names of the courses you want to download, and the program will only download the files from those courses.
To download the program, go to the releases page and download the latest version for your operating system. You can also build the program from source by following the instructions below.
Note
Darwin = MacOS ARM = M1/M2/M3 and Snapdragon
To use AGDownloader, execute the following command:
./AGDownloader
The program will guide you through the process of obtaining the token and setting the other parameters, including the token.
Alternatively, you can specify some the program's parameters through the CLI.
In order for the application to retrieve the data from AulaGlobal, you must log in with the use of a token.
Currently, you can't obtain the token through the website. Fortunately, there are other ways, like obtaining it through the session cookie, or inspecting the requests made by the mobile application.
The easiest way is through the cookie. The program will guide you through the process, and save the token in the token-file
file.
Deprecated way of obtaining the token
To obtain the token, you must log in to AulaGlobal and go to the preferences panel. There, you will find the token under the "Security keys" section. Copy the token and paste it into the program when prompted.You can specify the program's parameters in order to automate and tweak the download process.
You can see a full list of parameters through the use of the --help
flag:
./AGDownloader --help
Usage of ./AGDownloader:
--courses strings Ids or names of the courses to be downloaded, enclosed in ", separated by spaces.
"all" downloads all courses
--dir string Directory where you want to save the files
--fast Set MaxGoroutines to the number of files for fastest downloading
--l string Language of the course names: ES (Español) or EN (English) (default "ES")
--p int Number of cores to be used while downloading
--token string Aula Global user security token 'aulaglobalmovil'
This is an example of a full command:
./AGDownloader --token aaaa1111bbbb2222cccc3333dddd4444 --dir download_files --p 4 --courses "Inteligencia Distribuidos 123445"
This program will run with the secret token aaaa1111bbbb2222cccc3333dddd4444
, in the AulaGlobal-Copy/
sub-folder, using 5 cores, and downloading all courses that contain the words "Inteligencia" or "Distribuidos" in their name, or the course with the ID 123445
.
You can choose the language of the course names with the --l
parameter. The possible values are:
ES
: SpanishEN
: English
You can specify the courses you want to download by using the --courses
parameter. You can specify the courses by their ID or by their name. If you want to download all the courses, you can use the keyword "all"
.
./AGDownload --courses "Ingeniería Inteligencia"
This parameter will download all the courses that contain the words "Ingeniería" or "Inteligencia" in their name.
You can specify the directory where you want to save the files by using the --dir
parameter. You must specify the path to the directory where you want to save the files. If you want to download the files in the same directory where the program is being run, you can put a dot.
./AGDownload --dir .
You can specify the number of cores you want to use while downloading the files by using the --p
parameter. The default value is 4.
./AGDownload --p 8
You can also specify the --fast
flag that sets the number of processes to the total number of files you will be downloading. This is the fastest way of downloading but may consume more resources.
To build the program from source, you will need to have Go installed on your computer. You can download it from the official website. Once you have installed Go, you can clone the repository and build the program by running the following commands:
git clone git@github.com:Astrak00/AGDownloader.git
cd AGDownloader/
go build
This will create an executable file called AGDownloader that you can run.
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
This project was inspired by the need to download all the files from all the courses in AulaGlobal. This is a tedious task that can take a lot of time, so I decided to create a tool that would allow me to do this in a simple and easy way.
Previously, I had created a similar tool in Python, but I decided to create a new one in Go because I wanted to learn more about this language and the faster execution time it offers was very appealing to me.
The idea of using the mobile token to authenticate the user was inspired by the project created by Josersanvil. I decided to use this method because it is more secure than using the user's password and because this year, the university removed the login with user and password.
This project is licensed under the MIT License.