RCauth.eu and MasterPortal architecture

From PDP/Grid Wiki
(Redirected from AARC Pilot - Architecture)
Jump to navigationJump to search

Introducing the Master Portal

The RCauth.eu and MasterPortal architecture is based on the CILogon Portal Delegation Architecture but with the addition of several components in order to support:

  • interface with VOMS as an attribute provider and retrieve vomsified proxies.
  • design a scalable setup which takes off some of the load of the main certificate issuing component.

High Level Architecture

Master-portal-v1.1.png

  • the yellow services (bottom right box) are the central (European-wide?) CILogon/Online CA services.
  • the red services (center box) are the myproxy credential store plus its frontend services: master portal, ssh server plus the needed extra services. There could be multiple, e.g. one per federation, effectively different OpenID Connect clients.
  • the blue services (left box) are run by the VO
  • the green services are e.g. Grid UIs but could also be CEs or laptops and are using non-web 'SSO'.
  • the purple service is the IdP.

Flow

Here we describe a brief overview of the flow through which users create and retrieve a voms proxy. A detailed explanation will follow later.

1) user enters via very-light-weight VO Portal on the left, specifying something such as requested VOMS FQANs.

2) VO Portal redirects to Master Portal which is a customized CILogon portal doing the CILogin portal delegation. The next few steps are the standard portal delegation mentioned above

3a) redirect to Delegation Service.

3b) Delegation Service sends to WAYF and IdP

3c) return (few steps) to Delegation Service which returns OAuth token to Master Portal

3d) Master Portal uses token to send a request to /userinfo to get user's identity.


When there is no valid certificate in the MyProxy Credential Store step 4) will be done

4a) Master Portal sends CSR and obtains certificate+key. The remaining steps are not part of standard CILogon/OA4MP.

4b) Master Portal will store the cert+key into a seconds myproxy server (MyProxy Credential Store) with the obtained identity. The myproxy server uses server-side VOMS integration.


5) Master Portal can now use jGlobus' or canl-java myproxy API to obtain vomsified proxies from this MyProxy Credential Store, where it will be a trusted retriever. It will send those back (on demand) to the VO portal. When the user asked for invalid VOMS credentials, this will also be fed back to the user.


The next two steps are an extension to enable access on e.g. workernodes or UIs. i.e. non-web 'sso'. It's quite similar to what github is doing.

7) Master Portal allows uploading of ssh public keys which are put in the authorized keys file on SSH Server. See Master Portal sshkey endpoint.

8) When the user logs in onto the SSH Server it will automatically (using the command option in the authorized keys file) run a script which will run something like a myproxy-get-delegation and return a short-lived proxy to the user via e.g. stdout over the ssh. See RCauth.eu and MasterPortal SSH Key Portal. We can probably use the myproxy-server-side voms for that, by passing the right information to the SSH server, alternatively the user or the script can do that on client side.


As an alternative way of accessing a user proxy from the command line with user credentials (username and password) the Master portal can do the following:

7) provision a custom account in for example an LDAP server, belonging to the user, where the user picks a password. Other methods are possible too, as long as they are compatible with PAM.

8) This can then be used by the user to authenticate using PAM against the MyProxy Credential Store to retrieve a short-lived proxy. In this case, it is probably necessary to do the vomsification on client side.

Public Demo

We have several different demonstrations using the production RCauth CA.

Detailed Architecture

MasterPortal detailed flow.png

Detailed Flow

  1. user browses to VO portal
  2. redirect to /authorize on Master Portal (OIDC1)
  3. redirect to /authorize on DS (OIDC2)
  4. redirect to WAYF (SAML)
  5. redirect to IdP (SAML) -> user logs in
  6. redirect back to /authorize on DS (SAML)
  7. redirect to redirect_uri on Master Portal (/ready endpoint) (OIDC2)
    (Master portal retrieves access_token2 and userinfo)
  8. redirect back to redirect_uri on VO portal (OIDC1)


Next steps are all hidden for the end-user.

  1. VO portal retrieves access_token1
  2. VO portal retrieves userinfo from Master Portal using access_token1
  3. VO portal calls /getproxy endpoint on Master Portal using access_token1, optionally with VOMSES and VOMS string
  4. Master Portal does INFO on MyProxy credstore to check for long-lived proxy:
    no proxy yet:
    1. Master Portal creates keypair + CSR
    2. Master Portal calls /getcert on DS using access_token2 and CSR
    3. DS does a MyProxy GET request at online CA, using the CSR
    4. online CA signs the CSR and returns the end-entity certificate to the DS
      DS returns end-entity certificate to Master Portal
      Master Portal uses end-entity certificate and key to delegate (MyProxy PUT) a long-lived proxy to MyProxy credstore
  5. Master Portal retrieves short lived (VOMS) proxy from MyProxy credstore
  6. Master Portal returns proxy to VO portal


Aarc-masterportal-sequence-numbered-v2.png

Other Resources

Getting the software

All sources (Master Portal, VO Portal, SSH Key Portal and Delegation Server) can be found on github, together with released binaries and two sets of ansible scripts for installation.

If you want to rebuild any of the software components, please refer to this guide detailing the build procedure. If you are looking for a deployment guide for the setup described above, check out the Ansible scripts (previously, we also provided deployment scripts using Jenkins but this is has been obsoleted by the Ansible scripts).

GetProxy Endpoint

In order to retrieve proxies instead of end entity certificates from the Master Portal we created an extension to the OIDC/OA4MP Protocol. This is called the OAuth for MyProxy GetProxy Endpoint extension.