Project

uw_sws

0.0
Repository is archived
No commit activity in last 3 years
No release in over 3 years
Interfaces with UW Student Web Service
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

>= 1.6.7
 Project Readme

UW Student Web Service

This implements most of the v5 UW Student Webservice endpoints. Each endpoint is querried for their json response and a hash is then returned. This gem has the capability to cache all web requests to assit with speedy development.

USE

Installation

gem install uw_sws

Examples

First, configure the gem to how you want to use it.

require 'uw_sws'
cert    = "/TheFullPath/ToYour/x509Certificate.pem"
key     = "/TheFullPath/ToYour/x509Key"
url     = "https://ucswseval1.cac.washington.edu/student/v5/"
service = UwSws.new(cert: cert, key: key, base: url, use_cache: false)

Now get all the Geology courses from 1985?

courses = service(1985, "winter", curriculum: "GEOG")

For cases where you need to page through results you can check for the existance of service.next and make follow up queries based on it's data.

courses = service.courses(1985, "autumn", curriculum: "GEOG", size: 25)
puts service.next

For a full list of examples see /test

Caching

If you pass use_cache: true as a parameter to UwSws.new all web requests will be cached in your local file system. However, you will need to have a cache directory in the root of whatever projects you are using this gem in.

Endpoint Implementation

All links below go to the official service documentation. The code block refers to it's implementation in this gem. See the tests for how to use all the supported endpoints.

service = UwSws.new(...params...)

Fully Supported

Partially Supported (may or may not work)

Not implemented in this gem

Most of these are not implemented due to additional security requirements beyond a simple 509 cert. Requirements such as permissions in ASTRA or x-uw-act-as permissions passed in the header. Feel free fork and make a pull request with working tests if you have those permissions.

Development

Installation

Ignore the cache warnings after bundle install.

git clone git@github.com:UWFosterIT/uwsws.git
cd uwsws
bundle install

Setup and Tests

Change the cache symlink to point to a valid path or create a directory for it like below. Also, in /test you will need to provide the full path to your x.509 cert and key before running rake.

rm cache
mkdir cache
rake

You may get 1 or 2 test failing, "financial info", if that endpoint isn't in production yet. If something else fails it's most likely your cert or its permissions granted to it.

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request

Changes Since < 2.0.0

  • v4 is no longer used, all queries are now against v5
  • no more public endpoints, all queries now require a cert
  • Endpoints that ended with _search have been changed to their plural form (person_search to people)
  • A few new endpoints were added, see list above for whats supported