1.45.0 • Published 2 months ago

uaa-singular v1.45.0

Weekly downloads
126
License
-
Repository
github
Last release
2 months ago

UAA Singular Login for Web Applications

Singular is a Javascript module that enables web applications to easily identify a user via their authenticated browser session at the UAA identity server. Singular has no external client-side dependencies, and the latest version of Singular will work with UAA 4.10.0 and later.

License

Singular is licensed under the Apache License, Version 2.0.

Compatibility

Singular should work with any web browser which supports Javascript localStorage, postMessage, and DOMContentLoaded, which includes these versions of major desktop browsers.

ChromeFirefoxIEOperaSafariEdge
41+ ✔17+ ✔11+ ✔28+ ✔9+ ✔12.0+ ✔

Server-side Prerequisites

OAuth client setup

Singular requires a configured OAuth client in the UAA which requires at least the following properties. For more information about creating clients in the UAA, see the API documentation.

PropertyValue
authorized_grant_typesimplicit
scope["openid"]
autoapprove["openid"]
redirect_uri[ "http://<singular-domain>/PATH/TO/SINGULAR/postauth.html","http://<singular-domain>/PATH/TO/SINGULAR/postaccess.html" ]

For the example index.html, you will also need to add http://<singular-domain>/index.html to the redirect_uri configuration. /PATH/TO/SINGULAR/ should be updated to reflect the path to your singularLocation, which is the static assets directory where singular.js and associated html files are served from your app.

Alternatively, you can provide http://<singular-domain>/** as the redirect_uri if you believe you will not have any concerns about redirecting users to any path location within your domain.

UAA version compatibility

Singular VersionUAA VersionUAA-Release Version
v1.0.X3.8.0 +v20 +
v1.2.X4.10.0 +v55 +
v1.3.X4.10.0 +v55 +

Installing Singular

The uaa-singular package can be downloaded with the command: npm install uaa-singular

This will create the node_modules directory in your current directory (if one doesn't exist yet) and will download the package to that directory.

Using Singular

To enable Singular login on a page, include the main script in the header:

    <script type="application/javascript" src="node_modules/uaa-singular/singular/singular.js"></script>

Then use the Singular.init method to configure and start the authentication. The call to Singular.init can occur anywhere in the DOM.

<script type="application/javascript">
  Singular.init({
    // Static assets directory where singular.js and associated html files are served from your app
    singularLocation: './node_modules/uaa-singular/singular/',
    clientId: 'exampleClient',
    uaaLocation: 'https://login.example.com',
    onIdentityChange: function (identity) {
      // perform custom login behavior
    },
    onLogout: function () {
      // perform logout behavior
    }
  });
</script>

Getting an access token

It is possible to obtain an access token using sungular library. Use Singular.access function to do that. This function returns a promise

var tokenPromise = Singular.access('resource.read,someotherscope');
    tokenPromise
      .then(function(token){
        console.log("Access token with resource.read and someotherscope scopes: " + token )
      })
      .catch(function(error){
        console.log("Error: " + error )
      })

Make sure client has scopes resource.read and someotherscope.

Define all custom behavior for the application in onIdentityChange. The argument passed to this callback will either be an object containing the identity claims of the logged-in user, or null indicating a logout. The application should treat this identity idempotently, as this callback may be invoked many times in the lifetime of the page as users log in and out of the UAA. The properties available for configuration in Singular can all be passed as fields in the argument of init.

PropertyDescriptionDefault
singularLocationlocation where singular.js and associated html files are served from your appby defaults detects the location of the singular.js script - this will not work and must be set explicitly if you webpack your Javascript into a single file
onIdentityChangea function of one argument which is used as a handler for any changes in the currently logged-in user
onLogouta function that specifies the actions to take upon ending the user's session
clientIdthe ID of an implicit-grant OAuth client on the UAA server"client"
checkIntervalmilliseconds between subsequent checks for session changes1000
uaaLocationthe location of the UAA server with no ending slash, as a URI including the protocol"http://localhost:8080/uaa"
storageKeythe key to use in the local browser storage for storing the identity claims of the current user, which need be reconfigured only in the case that the default value conflicts with an existing storage key used by the application"singularUserIdentityClaims"
authTimeoutmilliseconds to wait for an identity token to be retrieved before treating it as an error and logging the user out20000
appendFramesOnInitwhen true, Singular frames will be appended to the body on Init, instead of waiting for the DOMContentLoaded browser eventfalse

Running the tests

npm run get-uaa
npm run start-uaa
npm run start-singular-app
npm test

start-uaa and start-singular-app spawn background processes. Be sure to run npm run stop-uaa and npm run stop-singular-app when finished.

1.45.0

2 months ago

1.44.0

2 months ago

1.43.0

3 months ago

1.39.0

7 months ago

1.40.0

6 months ago

1.42.0

4 months ago

1.41.0

5 months ago

1.38.0

8 months ago

1.37.0

9 months ago

1.36.0

10 months ago

1.35.0

1 year ago

1.29.0

1 year ago

1.32.0

1 year ago

1.33.0

1 year ago

1.30.0

1 year ago

1.31.0

1 year ago

1.28.0

2 years ago

1.21.0

5 years ago

1.20.0

5 years ago

1.19.0

5 years ago

1.18.0

5 years ago

1.15.0

6 years ago

1.14.0

6 years ago

1.13.0

6 years ago

1.12.0

6 years ago

1.11.0

6 years ago

1.10.0

6 years ago

1.9.0

6 years ago

1.8.0

6 years ago

1.7.0

6 years ago

1.6.0

6 years ago

1.5.0

7 years ago

1.4.0

7 years ago

1.3.2

7 years ago

1.3.1

7 years ago

1.3.0

7 years ago

1.2.2

7 years ago

1.2.1

7 years ago

1.0.3

7 years ago

1.0.2

7 years ago

1.0.1

7 years ago

1.2.0

7 years ago

1.1.0

7 years ago