Skip to content
Permalink
6bb982f099
Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Go to file
 
 
Cannot retrieve contributors at this time
65 lines (45 sloc) 3.08 KB
## Overview
This set of docker images supports a demonstration of the TIER architecture, and
how it can be used for role-based access control (RBAC) in a complex setting.
For more information about this demo, see [Tier Canvas Provisioning Demo -
TechEx
2017](https://docs.google.com/presentation/d/1RT448nvR3gZ2hFUteqSQ6LgOYMwlgua0x0hQBZFrVWE/edit#slide=id.p)
The Group Docker image is based on Unicon's work, and relies on a seperate MySQL container for subject source and grouper's own database. The Grouper component has the Grouper UI, Grouper Web Services, and an active Grouper Daemon which runs the Grouper Loader. The Grouper loader kicks off all loader jobs and AMQP Message Publisher every 10 seconds, so changes are rapidly propagated through the demo.
> This image does not follow best Docker practices. It is intended from demo/class usage. It can also be useful for use as a base image for Grouper development.
This demo also includes a working version of using an attribute on a group to restrict release of group information via isMemberOf to only specific SPs. Original write-up: https://spaces.internet2.edu/display/Grouper/UW-Madison+Group+Membership+Delivery+to+Shibboleth
## Building
To build the demo:
```
./build.sh
```
In order to configure the Canvas provisioning components, you'll need a Canvas
instance and will need to generate an API key. Please see [Getting Started With
the Canvas
API](https://canvas.instructure.com/courses/785215/pages/getting-started-with-the-api)
for more information about this.
There are a number of containers in the demo, so you may need to increase RAM
devoted to Docker. The demo seems to run well with 4 CPUs and 8GB.
## Running
To run the demo:
```
$ docker-compose up
```
You can log into the Grouper UI with "tjordan/12345". The account is a sysadmin. Through the back door (port 8080), anyone can access Grouper but through the portal proxy, the user will need to be a member of app:grouper:users. There are lots of "user" accounts that can be enrolled in courses and granted access to various parts of the demo. You can view them all at http://localhost:3000/users.
The LDAP admin bind account is "cn=admin,dc=example,dc=edu/password". The MySql admin account is "root/<nopassword>". There are a few schemas here for the SIS app (used as subject source) and Grouper's own database
## Published Ports / Where to Go
* https://localhost:9443 -> Portal/Proxy web app
* https://localhost:443 -> ShibIdP
* localhost:3306 -> MySQL Database
* localhost:389 -> LDAP...used only for authentication
* http://localhost:8080 -> Grouper Back Door. Uses LDAP auth.
* http://localhost:15672 -> RabbitMQ Web Interface (log in with guest/guest)
* http://localhost:3000 -> SIS Web App. Use to add / edit users, and enroll them in courses
## Authors
* James Babb (james.babb@wisc.edu)
* Tom Jordan (tom.jordan@wisc.edu)
* Jon Miner (jon.miner@wisc.edu)
* TIER API & Entity Registry Working Group (tier-api@internet2.edu)
* Based on Unicon Grouper Demo Container by:
* John Gasper (jgasper@unicon.net)
* David Langenberg (dlangenberg@unicon.net)
## LICENSE