Skip to content

Latest commit

 

History

History
582 lines (331 loc) · 18.9 KB

uniweb-api.md

File metadata and controls

582 lines (331 loc) · 18.9 KB

uniweb API logo

UNIWeb API

Preamble

Before you spend time reading about the UNIWeb API, it is important to determine whether you need the API at all. There are some scenarios that can be resolved with the API, but that can also be resolved in a simpler way. One such case is the embedding of UNIWeb pages into an institutional website. UNIWeb pages allow for a special parameter to signal that the page will be embedded.

<iframe src="https://uniweb.uottawa.ca/?embed=1#!uottawa/members/1667/profile" width="400" height="300"></iframe>

The ?embed=1 part of the URI tells UNIWeb to only show the main content of the page and hide everything else. With this approach, user profiles and other pages can easily be reused in different contexts within an institutional website.

API Overview

The purpose of the API is to integrate UNIWeb with other systems within your organization. The Authenticated API provides secure read/write access to information stored by UNIWeb, and it provides a mechanism to reduce the need to duplicate data.

The UNIWeb API provides:

  • An interface that allows you to control who has access to your institution's data through our API.
  • A means by which to securely read and update your institution's information.
  • Rich data in simple, straightforward JSON for maximum readability and reusability.
  • The choice to pre-filter the requested data, to obtain just the subset of information in which you are interested.

The UNIWeb API uses Internet Engineering Task Force (IETF) open authentication standard OAuth 2.0, for authentication and authorization using the Resource Owner Password Credentials Grant protocol. In this protocol, only users with granted permission can access the API.

The following four steps are required to access a resource through API:

  1. Get permission to create OAuth 2.0 Clients
  2. Create a OAuth 2.0 client and obtain client credentials
  3. Use your Oauth 2.0 client credentials to retrieve an access token.
  4. Use your access token to interact with the API. Your token is valid for an hour from the time it is issued.

These steps are explained in more details below.

Setting up Authorized Clients

1. Get permission to create OAuth 2.0 Clients

A System Administrator, can grant any user permission to create OAuth 2.0 clients. If you are not the System Administrator yourself, ask the System Administrator to give you this permission, as example below shows:

Example above shows Access Control page, accessible from Administration panel, to John Doe, the System Administrator. In this example, role Health Science IT Administrator has the permission to create OAuth 2.0 clients for Health Sciences department. John Doe assigns this role to Jane Roe. Jane Roe can now create OAuth 2.0 clients.

2. Create a OAuth 2.0 client and obtain client credentials

Using the UNIWeb Interface, you can create, edit, view and remove OAuth 2.0 clients. Each client has a unique username referred to as Client ID, and a system generated random password, referred to as Client Secret. Example below shows Jane Roes's OAuth 2.0 Administration page.

In this example, Jane Roe has created two OAuth 2.0 clients. Clicking on the view button for Alice reveals her Client Secret as shown below:

In this hypothetical case, Alice's Client ID is Alice and her Client Secret is 7740731b32440350fccd. These credentials are used in the next step to authenticate Alice.

3. Authenticate and get an Access Token

With the client credentials obtained in step 3, you can authenticate to the UNIWeb Token Endpoint, and get an Access Token. An Access Token is valid for one hour, and it will be used in the next step to retrieve resources from UNIWeb Resource Endpoint.

With these pieces of information you will be allowed to make API requests. To do so, you can use one of our pre-built client libraries

4. Access information through structured requests

API requests are made by submitting JSON objects to the server. They tell the server which action, resources, sections and fields are desired and what filters to apply. In particular, the request objects can have the following properties: action, content, filter, and resource.

Example request object:

{
    "action": "read",
    "content": "members",
    "filter": {
        "loginName": "[email protected]"
    },
    "resource": [
        "profile/biography",
        "profile/selected_degrees"
    ]
}

Example response for the above request:

{
    "[email protected]": {
        "profile/biography": "Bob always knew he would be a great scientist",
        "profile/selected_degrees": [
            {
                "degree_name": "PhD",
                "organization": "McGill University",
                "specialty": "Materials Engineering"
            },
            {
                "degree_name": "Engineering",
                "organization": "University of Ottawa"
            }
        ]
    }
}

API Requests

Before requesting information from UNIWeb, it is necessary to understand the terminology used to identify pieces of data stored in the system. The information within a UNIWeb page is usually divided into sections, sub-sections, sub-subsections and so on. A section contains a list of items. An item within a section is made out fields. An API request is the mechanism for obtaining the field values of all items within a section.

Resource Paths

In UNIWeb, a resource is always associated to a type of content. Current content types are: 'members', 'units' and 'groups'.

To request a resource, it is necessary to provide a path to it within UNIWeb. A request path can be specified as a string by separating each element in the path with '/'. The path must have the following form:

page/section/section/section/...

`page` The 'page' where the information is displayed within UNIWeb. For example, 'profile', 'cv' or 'graph'.
`section/...` Sequence of section, subsection, sub-subsection,... that contain the target set of items to retrieve.

For example, the string

cv/education/degrees

refers to all the items within the section Degrees, which is a subsection of the Education section in the CV page of UNIWeb members.

Optionally, a request path can be specified as a JSON object. In particular, this is needed if one desires to request only a subset of the field values of an item. In this case, the resource path can be given as

   {"page/section/section/section/...": ["field name A", "field name B", ...]}

It is also possible to encode the entire path as a JSON object. This is useful when requesting multiple sections under a common parent section or page:

   "page":{
       "parent_section":[
         "child_section A",
         "child_section B"
       ]
   }

The resource path above is equivalent to specifying two separate resource paths as strings:

   [
       "page/parent_section/child_section A",
       "page/parent_section/child_section B"
   ]

Naming Conventions

The names of sections and fields used by the API are derived from the English titles of their respective sections and fields shown in the UNIWeb UI. Spaces, slashes and question marks are not allowed in resource names. In addition, resource names are always lowercased. To "normalize" a string to meet API rules, do the following:

  1. Lowercase the given string
  2. Replace the substrings " / ", "/", and " " with "_"
  3. Replace the substrings "?" with the empty string ""

For example, the string "Postal / Zip Code" is normalized to "postal_zip_code".

Section Names

The names of sections in resource paths must: (1) correspond to the sections names shown in the UNIWeb UI, and (2) be normalized according to the API naming rules described above. For example, the path to the Address resource in a CV is written as

cv/personal_information/address

The names of fields in resource paths must: (1) correspond to the field labels in the UNIWeb UI, and (2) be normalized according to the API naming rules described above. For example, the fields shown below in the Address section can be requested as

["address_type", "address_-_line_1", "location", "postal_zip_code"]

Stucturing Requests

API requests are given as JSON objects with one or more of the following properties.

`action` required A string value specifying the desired action to take.
`add` creates a new item for entry into the database
`edit` edits a section field
`options` returns a list of options possible to obtain additional system information
`clear` clears section data
`info` retrieves section info
`read` returns a list of resources (e.g. members, units, etc)
`content` required Selects the type of content to retrieve.Show optionsHide options
`members` refers to the departmental unit, such as 'Engineering'
`units` refers to your institution listing of possible titles, such as 'Professor'
`groups` may be either a UNIWeb username, login email address or UNIWeb ID. This represents the most user-specific filter option
`resource` required One or more paths to the requested resources.Show optionsHide options

The value of this property can be a string, an object or an array of strings/objects. The format and naming conventions of resource paths are described in the section Resource Paths above.

`filter` optional An object value with filering settings.Show optionsHide options
`unit` refers to the departmental unit, such as 'Engineering'
`title` refers to your institution listing of possible titles, such as 'Professor'
`loginName` may be either a UNIWeb username, login email address or UNIWeb ID. This represents the most user-specific filter option
`modified_since` A TIMESTAMP in the range '1970-01-01 00:00:01' UTC to '2038-01-19 03:14:07' UTC. Only items modified on or after the given date are returned.
`index_by` optional Selects how the response indexed the resources in the answer.Show optionsHide options
`uniweb_id` The internal ID of each resource is used [the default].
`login_name` The login name is used [only if `content` is 'members'].
`employee_id` The institutions employee ID is used [only if `content` is 'members'].
`language` optional Responses use the default institution's language unless specified otherwise.Show optionsHide options
`fr` French is used for the response.
`en` English is used for the response.

Example Requests

Simple Single Resource Read Request

The request that follows would return the public profile information of all people in the Department of Civil Engineering as JSON.

{
    "action": "read",
    "content": "members",
    "filter": {
        "unit": "Civil Engineering"
    },
    "resources": "profile"
}

Requesting to Read Multiple Resources in a Single Request

The request that follows would return two resources belonging to the user with login name [email protected], which include:

  1. the publicly available research interest tags found on his Profile
  2. the Degree Name, Specialization, and Thesis Title fields from his CV found under Education > Degrees
{
    "action": "read",
    "content": "members",
    "language": "fr",
    "filter": {
        "unit": "McGill",
        "title": "Professor",
        "login": "[email protected]"
    },
    "resources": [
        "profile/research_interests",
        {
            "cv/education/degrees": [
                "degree_name",
                "specialization",
                "thesis_title"
            ]
        }
    ]
}

Error Messages

Errors will give information about what went wrong with a corresponding request. They will be of the following form:

{
    "error": {
        "message": "Error validating access token.",
        "type": "OAuthException",
        "code": 98,
        "error_subcode": 223
    }
}