| Size: 3938 Comment:  | Size: 3274 Comment:  | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 6: | Line 6: | 
| Line 17: | Line 16: | 
| Time estimated:: | Time estimated:: | 
| Line 20: | Line 19: | 
| Line 23: | Line 21: | 
| The doms auth system is responsible for ensuring that no user can access files without sufficient credentials. Furthermore, parts or entire doms record should be blockable with the auth system. | |
| Line 24: | Line 23: | 
| The doms auth system is responsible for ensuring that no user can access files without sufficient credentials. Furthermore, no doms record should be viewable without the nessesary credentials. These are two different requirements. | The Auth system is based around Fedora as the Authorization provider. Object policies are expressed in Fedora in XACML. There is meant to be a number of Authentication providers. | 
| Line 26: | Line 25: | 
| 1. Auth check on bitstorage access 1. Auth check on long post viewing | The auth system is layered. Authentication happens on the outer layer, against whatever Authentication providers we link with. The trusted services on the outer layer establishes the users roles/attributes. These are then communicated to Fedora, which evaluates them against the authorization policy. | 
| Line 29: | Line 27: | 
| == Bitstorage auth design == The design is as follows: 1. Each file in bitstorage is assigned a permanent URL 1. An Apache server is set up to handle these URLs 1. This apache server has the nessesary rewrite filters set up to forward the request to a php application. 1. Php application ('''Written by IT service''') 1. Extract Wayf credentials from the user. There might be no credentials, which is not yet an error. 1. Extract the user IP (or domain), and set this as a user property 1. Call the DomsAuth service with the permanent URL and the credentials if any (and the IP property), ('''Written by IT Digitale Ressourcer''') 1. Doms Auth lookup the corresponding file object in fedora, and attempts to read this with the supplied credentials. If succesful, true is returned. Else false. 1. If the DomsAuth service gave false and the user had no WAYF credentials, redirect the user to a wayf login page. 1. If the DomsAuth service gave false, but the user had WAYF credentials, report error. 1. If the DomsAuth service gave true, stream the file through the php app to the user 1. Stream app. This app streams the given file from whereever into the php script so the user can read it. ('''Written by IT Maintenance''') It can be seen that the php app will become a bottleneck. There are several designs that could work around this. Having several identical apache servers, and using a round robin dns would split the load. | With this design, we can have a single Authorization provider, and thus one place to define policies, but integrate with numerous signon systems. | 
| Line 49: | Line 30: | 
| === Components === 1. Some service that converts user roles into credentials that Fedora can work with 1. A system that transparently handles the credentials when requesting files from bitstorage 1. A system that transparently handles the credentials when displaying Doms objects in Summa | |
| Line 55: | Line 41: | 
Task Doms Auth system
- Title
- Doms Auth system
- State
- Not started
- Time used
- Time estimated
Description
The doms auth system is responsible for ensuring that no user can access files without sufficient credentials. Furthermore, parts or entire doms record should be blockable with the auth system.
The Auth system is based around Fedora as the Authorization provider. Object policies are expressed in Fedora in XACML. There is meant to be a number of Authentication providers.
The auth system is layered. Authentication happens on the outer layer, against whatever Authentication providers we link with. The trusted services on the outer layer establishes the users roles/attributes. These are then communicated to Fedora, which evaluates them against the authorization policy.
With this design, we can have a single Authorization provider, and thus one place to define policies, but integrate with numerous signon systems.
Components
- Some service that converts user roles into credentials that Fedora can work with
- A system that transparently handles the credentials when requesting files from bitstorage
- A system that transparently handles the credentials when displaying Doms objects in Summa
Sub tasks
| Title | State | Time used | Time estimated | 
Documentation
Progress history
| Iteration | Time used | Status | Notes | Tasks adressed |