Skip to content

internet2/grouper-ext-auth

main
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?
Code

Latest commit

 

Git stats

Files

Permalink
Failed to load latest commit information.
Type
Name
Latest commit message
Commit time
August 19, 2022 13:42
August 19, 2022 13:42
December 4, 2023 10:01
January 18, 2024 19:44
August 19, 2022 13:42
August 19, 2022 13:42
January 15, 2024 00:05

Grouper External Authentication Plugin

Grouper plugin that provides configurable authentication. Features include

  • Authentication for UI, without requiring a separate process or container

  • Supports SAML2, OIDC, and CAS

Usage

Grouper Version 4.x

Note
For a fully integrated sample configuration, see the docker-compose setup in the src/test/docker folder of the Git repository. The environment includes sample Grouper configurations for SAML2, OIDC, or CAS, along with a Shibboleth IDP that can authenticate Grouper using any of these methods.
  1. Add plugin to Grouper image (latest versions can be downloaded from https://github.internet2.edu/internet2/grouper-ext-auth/releases)

    COPY grouper-authentication-plugin.jar /opt/grouper/plugins
  2. Enable Plugins

    In grouper.properties, add properties

    grouper.osgi.enable = true
    grouper.osgi.jar.dir = /opt/grouper/plugins
    grouper.osgi.framework.boot.delegation=org.osgi.*,javax.*,org.apache.commons.logging,edu.internet2.middleware.grouperClient.*,edu.internet2.middleware.grouper.*,org.w3c.*,org.xml.*,sun.*
    
    grouperOsgiPlugin.0.jarName = grouper-authentication-plugin.jar

    grouper.osgi.jar.dir should point to the directory you copied the file to in your image build file

    grouperOsgiPlugin.0.jarName should be the name of the file you copied in

  3. Configure UI

    In `grouper-ui.properties, add properties appropriate for desired authentication. Note that only one can be used.

    Most of the configuration for the underlying authentication library is exposed to the Grouper configuration. Any field in the Java classes can be directly set using the field name or a setter used by using a related property (setting attribute=value will call setAttribute(value) )

    1. SAML2

      For SAML2, for example:

      grouper.is.extAuth.enabled = true
      external.authentication.grouperContextUrl = https://grouper-ui.unicon.local/grouper
      
      external.authentication.provider = saml
      external.authentication.saml.identityProviderEntityId = https://idp-host-name/idp/shibboleth
      external.authentication.saml.serviceProviderEntityId = http://localhost:8080/grouper
      external.authentication.saml.serviceProviderMetadataPath = file:/opt/grouper/sp-metadata.xml
      external.authentication.saml.identityProviderMetadataPath = file:/opt/grouper/idp-metadata.xml
      external.authentication.saml.keystorePath = file:/opt/grouper/here.key
      external.authentication.saml.keystorePassword = testme
      external.authentication.saml.privateKeyPassword = testme
      external.authentication.saml.attributeAsId = urn:oid:0.9.2342.19200300.100.1.1
    2. OIDC

      For OIDC, for example:

      grouper.is.extAuth.enabled = true
      external.authentication.grouperContextUrl = https://grouper-ui.unicon.local/grouper
      
      external.authentication.provider = oidc
      external.authentication.oidc.clientId = *****
      external.authentication.oidc.discoveryURI = https://idp-host-name/.well-known/openid-configuration
      external.authentication.oidc.secret = *****
      external.authentication.oidc.claimAsUsername = preferred_username
    3. CAS

      For CAS, for example:

      grouper.is.extAuth.enabled = true
      external.authentication.grouperContextUrl = https://grouper-ui.unicon.local/grouper
      
      # Note for CAS: you'll need to make sure that the CAS server SSL certificate is available in the trust store
      external.authentication.provider = cas
      external.authentication.cas.prefixUrl = https://idp-host-name/idp/profile/cas
      external.authentication.cas.protocol = CAS20

Version 5.x+

TODO

More Information

If assistance is needed (e.g., bugs, errors, configuration samples), feel free to open a ticket in the github repository or ask on the Slack channel