This project contains sample code for demonstrating the Blackboard Learn REST APIs in Python. This sample code was built with Python 2.7.10.
###Project at a glance:
- Target: Blackboard Learn SaaS Release 2015.11.0-ci.23+a9a4758 minimum
- Source Release: v1.0
- Release Date 2016-02-24
- Author: moneil
- Tested on Blackboard Learn SaaS Release 2015.11.0-ci.23+a9a4758
###Requirements:
- Python 2.7.10
- Developer account - register at https://developer.blackboard.com
- Test instance
You will first need to install Python 2.7.10. You can use tools like brew or ports to install, or run the installation manually.
You may also install Python tools for your IDE or use a text editor and terminal to run the python code.
restdemo.py - this is the main script
auth.py - this script contains the code for authenticating the application and managing tokens
datasouce.py - this script contains examples for each of the REST endpoints for managing Data Sources in Learn
term.py - this script contains examples for each of the REST endpoints for managing Terms in Learn
course.py - this script contains examples for each of the REST endpoints for managing Courses in Learn
user.py - this script contains examples for each of the REST endpoints for managing Users in Learn
membership.py - this script contains examples for each of the REST endpoints for managing Memberships in Learn Courses
The rest demo script demonstrates authenticating a REST application, management and use of the authorization token, and creating, updating, discovering, and deleting supported Learn objects.
NOTE: Before running the example code you must register a developer account and application as described on the Developer Community What is the Developer Portal: Developer Registration and Application Management and Managing REST Integrations in Learn: The REST Integrations Tool for System Administrators pages. You must also configure the script as outlined in the below Configure the Script section.
When run with only a target URL the script will in the following order
Authenticate
Create, Read, and Update a Data Source
Create, Read, and Update a Term
Create, Read, and Update a Course
Create, Read, and Update a User
Create, Read, and Update a Membership
Delete created objects in reverse order of create - membership, user, course, term, datasource.
When run with a specific command on an object only that operation will be run - you are responsible for system cleanup.
All generated output is sent to the terminal (or IDE output window).
e.g.:
$ python restdemo.py -h
restdemo.py -t|--target <target root URL> -c|--command <command>
e.g.:$ restdemo.py -t www.myschool.edu -c create_course
command: <command>_<object> where <command> is one of the following:
create, read, update, delete
and <object> is one of the following:
datasource, term, course, user, membership
-t is required; No -c args will run demo in predetermined order.
-c commands require a valid datasource PK1 -
a datasource get will be run in these cases, defaulting to create
if the demo datasource does not exist.
For example:
$ python restdemo.py -t localhost:9877
Runs the full CRUD demo
$ python restdemo.py -t localhost:9877 -c create_datasource
Runs the datasource.py:createDataSource() demo code and does not clean up the remote system after running you must run:
$ python restdemo.py -t localhost:9877 -c delete_datasource
to remove the created data source.
To run the demo if you have not already done so you must as outlined above register the application via the Developer Portal and add the application to your test environment using the REST API Integration tool.
Before executing the script to run against your test server you must configure it with your registered application's Key and Secret.
Open auth.py and edit lines 37 and 38.
On line 37 replace "insert_your_application_key_here" with the key issued when you registered your application.
On line 38 replace "insert_your_application_secret_here" with the secret issued when you registered your application.
Once you have setup your test server and changed auth.py to reflect your application's key and secret you may run the command line tools as outlined above or via your IDE.
For a thorough walkthrough of this code, visit the corresponding Blackboard Developer Community REST Demo Using Python.