Sample Setup
React Application
An Application may be hosted in the Agilicus platform, or external. For this example we are going to show how to develop a new application, initially not hosted.
Overview
An Application may be hosted in the Agilicus platform, or external. For this example we are going to show how to develop a new application, initially not hosted. For steps we will need:
- Authentication Client (OpenID Connect client id)
- Application (to attach permissions to, externally hosted)
- Create group, assign users to it
Application Setup
We can do the first two steps aove in a single step with the “New Application” configuration. First, under the Application menu, select ‘New’. Select ‘manually’.
data:image/s3,"s3://crabby-images/cb82e/cb82eaa8b2cbf0795174e034d4c38cf45f0027b2" alt="Sample React Application 2 New Application"
Now we give the application a name. The name will eventually be part of the URL (as a hostname) so keep it a single word. We add a description (which end users will see in the catalog), and a category (which will be used for grouping in reports).
data:image/s3,"s3://crabby-images/0cee4/0cee425d0d8f07bb983a2b26e09b7407dd501d34" alt="Sample React Application 3 New Application: Define"
We now indicate how we will ultimately access this application. Since it is (currently) external, this does not matter, leave the top item checked. Later when we move it to be hosted this will become a URL.
data:image/s3,"s3://crabby-images/f4bee/f4bee844dde92528356c5c55d70d93924bba8f3a" alt="Sample React Application 4 New Application: Hostname"
Now we indicate how the user accesses the application. Since we are just developing it, and it is on our desktop, leave this as “over the public Internet” (e.g. the application is not hosted in or through the Agilicus platform for the data path).
data:image/s3,"s3://crabby-images/8b3e1/8b3e1ff06ed097239e4709af1960afb0f7bb0ad5" alt="Sample React Application 5 New Application: Access"
We now indicate that our application will participate in the authentication. This means that it has a built-in library handling OpenID Connect.
data:image/s3,"s3://crabby-images/b60b8/b60b8f563b43424b0720f9934c0b0ee9eaba2371" alt="Sample React Application 6 New Application: Authentication"
We must now configure the redirect URI (which is part of the OpenID Connect specification). Here we will use http://localhost:3000/ since we are hosting this on our desktop. Later we will add the production redirect URI in the Authentication Client.
data:image/s3,"s3://crabby-images/ec94c/ec94cfebef39cd909b551e94655e1df0f0b2993c" alt="Sample React Application 7 New Application: Redirect"
We must now indicate how users are granted access. If we say “is used by all users in my organisation”, this means that the “All users” group will be granted access.
If we say “has named users with a single role”, this means authorisation is Boolean (allow/deny), but for a named set of users. We will use this option for the sample.
If our application has distinct roles for the users (e.g. Admin, Editor, Viewer), we can use the “has named users with distinct roles”.
data:image/s3,"s3://crabby-images/832b5/832b5a74484570c87d85db939f048c12612de02c" alt="Sample React Application 8 New Application: Users"
Now we are complete, we will hit apply.
data:image/s3,"s3://crabby-images/fd276/fd27663708703f94c67718f1ab3787a82b945883" alt="Sample React Application 9 New Application: Apply"
We can inspect the Authentication Client created. Later when we change the redirect URI we can change it here.
At this time we will change the application allowed from ‘All’ to ‘Sample-React-App’, forcing it to only allow our new application.
data:image/s3,"s3://crabby-images/ddf7b/ddf7bfd0b4615a8c5d5fbde66b9e9918ddf8e052" alt="Sample React Application 10 51184d71 new application authentication client"
Group Create, Permissions Assign
Create a new group. Assign yourself (and any other users)
data:image/s3,"s3://crabby-images/23d74/23d74e6c554d29aaeab6e2933adaca820ef86392" alt="Sample React Application 11 New Application: Groups"
Now, create a new row in the “Application Permissions”, add the new group, and assign ‘Self’ as a permission to the application column.
data:image/s3,"s3://crabby-images/0a6a5/0a6a598d6fa8b013915af309b41a9806aca5523e" alt="Sample React Application 12 New Application: Permissions"
Sample Code
See github repo for a sample using react-openidconnect library.
import React, {Component} from 'react';
import Authenticate from 'react-openidconnect';
import logo from './logo.svg';
import './App.css';
var OidcSettings = {
authority: 'https://auth.cloud.egov.city/',
client_id: 'sample-react-auth',
redirect_uri: 'http://localhost:3000/',
response_type: 'id_token token code',
scope: 'openid profile email',
post_logout_redirect_uri: 'https://localhost:3000/',
};
class App extends Component {
constructor(props) {
super(props);
this.user = 'unknown';
this.userLoaded = this.userLoaded.bind(this);
this.userUnLoaded = this.userUnLoaded.bind(this);
this.state = {user: undefined};
}
userLoaded(user) {
if (user) {
this.user = user;
console.log(user);
this.setState({user: user});
}
}
userUnLoaded() {
this.user = 'unknown';
this.setState({user: undefined});
}
NotAuthenticated() {
return (
<div className="App">
<header className="App-header">
<img src={logo} className="App-logo" alt="logo" />
<p> Click to authenticate </p>
</header>
</div>
);
}
render() {
return (
<Authenticate
OidcSettings={OidcSettings}
userLoaded={this.userLoaded}
userunLoaded={this.userUnLoaded}
renderNotAuthenticated={this.NotAuthenticated}
>
`<div className="App">
<header className="App-header">
<img src={logo} className="App-logo" alt="logo" />
<p> Welcome User! {this.user} </p>
</header>
</div>`
</Authenticate>
);
}
}
export default App;