Skip to content

Magnus2142/Blackboard-LMS-CLI

Repository files navigation

Under Development Public Domain Travis


Logo

Blackboard-LMS-CLI

Command-line tool suite for Blackboard LMS
Explore the docs »

View Demo · Report Bug · Request Feature


About The Project

user@computer:~$ bb

Usage: bb [OPTIONS] COMMAND [ARGS]...

Options:
  --version  Show the version and exit.
  --help     Show this message and exit.

Commands:
  announcements              Commands for listing, creating, deleting and...
  assignments                Commands for creating, listing and...
  contents                   Commands for listing, creating, deleting,...
  courses                    Commands for listing courses
  login                      Authorize user with username and password.
  logout                     Logout user.
user@computer:~$ bb courses list

Id           Course Name

_33050_1     Donn Alexander Morrison testrom
_32909_1     Sammenslått - Ingeniørfaglig systemtenkning INGA2300 INGG2300 INGT2300 (2022 VÅR)
_31606_1     INGT2300 Ingeniørfaglig systemtenkning (2022 VÅR)
_32736_1     Sammenslått - Matematiske metoder 3 for dataingeniører IMAX2150 (2021 HØST)
_28936_1     IMAT2150 Matematiske metoder 3 for dataingeniører (2021 HØST)
_27251_1     IDATT2900 Bacheloroppgave  (start 2021 HØST)

Blackboard LMS CLI is a command-line tool suite that students and staff can use to communicates with the Blackboard Learn REST API. It was created because the blackboard web interface can be ineffective and awkward to use. The CLI aims to offer a simple, intuitive and effective way to execute tasks in the Blackboard LMS.

Built With

The software is written in python. Several libraries were used, but the most essential ones are:

  • Click - A python package for creating beautiful command line interfaces in a composable way with as little code as necessary.
  • Requests - A library used to send HTTP requests in a simple and elegant way.
  • Beautiful Soup - A library used to pull data out from HTML and XML files.

A complete list of all libraries can be found in the dependencies section.

Getting Started

Some instructions on how to quickly make the CLI available on your computer!

Prerequisites

To run this CLI you need python and pip installed.

Installation

NB! Currently, this CLI can only be installed using pip, but we are planning to support other installation methods later.

pip install Blackboard-LMS-CLI

Test if the installation was successful by running $ bb --version command:

bb --version

If it was successfull, the output should be something like this:

bb, version 0.1.0

Shell completion: The CLI also supports shell completion with TAB, but is currently only comaptible with bash, zsh and fish. To activate this you can follow the guide here: Click shell completion help page.

Usage

First of all, you can either login using the command:

bb login

or just execute the command you want, and you'll be logged in if you aren't already.

The CLI is designed in such a way that its commands and subcommands, is structured much alike like the Blackboard Learn REST API modules. bb is the main command, then for example is courses a subcommand of bb, and at last, list is a subcommand of courses. See demo here

All commands contains a help page that can be accessed through adding the flag --help, for example if I want to see the help page about creating a file content:

bb contents create file --help

Output:

Usage: bb contents create file [OPTIONS] TITLE FILE_PATH

  Creates a file content.

Options:
  -c, --course TEXT   COURSE ID, of the course where the content exists
                      [required]
  -f, --folder TEXT   FOLDER ID, of the folder you want to create content in.
                      [required]
  -n, --new-window
  --end-date TEXT     When to make content unavailable. Format: DD/MM/YY
                      HH:MM:SS
  --start-date TEXT   When to make content available. Format: DD/MM/YY
                      HH:MM:SS
  -r, --reviewable    Make content reviewable
  -h, --hide-content  Hide contents for students
  --help              Show this message and exit.

Using the --help flag is very useful, because many commands have many possible options which can be hard to memorize in the beginnning.

Example usage of the CLI:

Dependencies

For this CLI to work you need python and pip installed on your computer.

The following libraries are required:

Configuration

At the moment, the CLI is not configurable. However, this is something we plan on adding in the future.

Ideas configurable elements:

  • A setting that chooses whether ID's such as course id and content id is used as positional arguments or required options.
  • If they want the responses in json byt default or just plain text, formatted by the CLI.

How to test the software

Unit tests have been created for almost all service methods, in other words, where the HTTP requests and processing of data from the Blackboard Learn REST API takes place.

To run the tests:

  1. Make sure to create a virtual python environment in the project. With python package virtualenv it can be created like this:

    virtualenv venv
    source venv/bin/activate
  2. Make sure all requirements are installed:

    python -m pip install -r requirements.txt
  3. Run tests using pytest:

    python -m pytest

Known issues

Even though this CLI aims to be more effective than the Blackboard web interface, we do acknowledge that it has its weaknesses. However, this is issues that isn't about bugs or needed functionality, but limitations of the CLI that either isn't possible to change or requires a comprehensive rework of the project. For bugs or desirable functionality, an issue should be created or contact us by mail.

Cryptic IDs:

All IDs for courses, announcements, contents, etc. have a cryptic ID with the format _33050_1, which is hard to read and awkward to type. For example, it would be more convenient if the ID of a course would be IDATT1001 and announcements and contents could be fetched using their title. However, this isn't possible because it can't guarantee that all course names, announcements, and content titles are unique.

Getting help

If you have questions, concerns, bug reports, etc, please file an issue in this repository's Issue Tracker, or mail us:

Mail info:

Getting involved

This started as a project for our Bachelor Thesis in Computer Engineering and we designed and developed the project in such a way that it was easy to understand and contribute. It was not enough time to implement all desired functionality and invite anyone who wants, to help fix bugs, implement new functionality, etc. One the biggest motivating factors when developing the CLI, was that if it was successful, with useful functionality and a more effective alternative to the Blackboard web interface, both teachers and students on NTNU will use it in their everyday student/work-life.

If you think this is a cool project and want to help us make it great by contributing, please read the CONTRIBUTING file to see how.


Open source licensing info

  1. TERMS
  2. LICENSE
  3. CFPB Source Code Policy

Credits and references

Below is a list of useful reasources and guides that had a meaningful impact or influence on this project:

  • How to build a python CLI - Gave us a quick introduction on how to setup a python project with some basic Click commands.
  • Build a Command-Line To-Do App With Python and Typer - Another quick introduction to create a command-line tool in python, but with typer instead of click. Typer is a pyhton library based on Click, so the syntax was pretty much the same and this article gave us the idea of using the Model-View-Controller software design pattern.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages