How to Set Up SSO SAML for Node-RED
Step-by-step guide on setting up SSO SAML for your self-hosted FlowFuse platform
SSO plays a crucial role in modern enterprise environments by simplifying user authentication across multiple applications. At FlowFuse, we recognize the significance of SSO and offer robust support for integrating it with your self-hosted platform. In this comprehensive guide, we will focus on configuring SSO SAML, specifically using Google as the Identity Provider (IdP). We also support SSO with LDAP. For more information, refer to Setting up LDAP SSO for your Self-Hosted FlowFuse.
# What is SSO?
Single Sign-On (SSO) is a technology that allows users to access multiple applications or services with one set of login credentials. When a user logs in to one central system, known as the Identity Provider (IdP) such as Google, Microsoft Azure AD, or Okta, it authenticates the user and creates a session token. This token is then used to access other connected applications without requiring the user to log in again. The IdP verifies the token and shares the authentication information with other applications, ensuring secure and seamless access across multiple platforms. This reduces the need to remember multiple passwords and enhances security by centralizing authentication.
# Understanding SAML
SAML (Security Assertion Markup Language) is a protocol used in SSO scenarios to exchange authentication and authorization data between an Identity Provider (IdP) and a Service Provider (SP). Here’s how it works step-by-step:
-
User Request: A user attempts to access a service or application that is protected by SAML-based SSO.
-
Redirect to IdP: The Service Provider (SP), recognizing that the user needs authentication, redirects them to the Identity Provider (IdP).
-
User Authentication: The IdP prompts the user to authenticate themselves. This authentication can involve various methods, such as username/password, multi-factor authentication (MFA), or other authentication mechanisms supported by the IdP.
-
Generating SAML Assertion: Upon successful authentication, the IdP generates a SAML assertion. This assertion contains information about the user's identity (like username, email) and any attributes or roles associated with the user.
-
Sending SAML Assertion: The IdP sends this SAML assertion back to the Service Provider (SP), typically through the user's browser. The assertion is digitally signed by the IdP to ensure its authenticity and integrity.
-
Assertion Validation: The Service Provider (SP) receives the SAML assertion. It validates the assertion to ensure it comes from a trusted IdP and that the assertions' contents are accurate and have not been tampered with.
-
Granting Access: If the assertion is valid, the SP grants access to the user based on the information in the SAML assertion. This allows the user to access the protected application or service without needing to provide separate credentials to the SP.
# Benefits of Using SSO in the Workspace
-
Improved User Experience: Users only need to remember one set of credentials, making the login process simpler and reducing password fatigue. For instance, In a manufacturing environment, employees often need to access multiple systems, such as Node-RED, ERP systems, and quality control applications. With SSO, they only need to remember one set of credentials, simplifying the login process and reducing password fatigue.
-
Simplified Management: Administrators can manage user access and permissions from a single platform, making it easier to onboard new employees and revoke access when someone leaves. This centralized management ensures that only authorized personnel can access the application flows.
-
Increased Security: Centralized authentication via SSO reduces the risk of weak or reused passwords, allowing for the implementation of stronger security policies. This is critical in a workspace where sensitive data and operational systems must be protected against unauthorized access.
-
Enhanced Productivity: SSO allows employees to log in once and gain access to all necessary applications, saving time and reducing interruptions.
# Setting up SSO For Your Self-Hosted FlowFuse Platform
Before proceeding, ensure you have deployed FlowFuse on your server with an Enterprise license and configured it with email. Without email configuration, the SSO setup option won't appear in your FlowFuse.Furthermore, Make sure you have a Google Workspace account created and verified your domain within Google Workspace. FlowFuse supports other providers for SAML SSO as well; check our documentation on supported providers for details.
If you haven't deployed FlowFuse yet, refer to our documentation on installing FlowFuse or our blog on deploying FlowFuse on Ubuntu with Docker.
# Configuring SSO in your Self-Hosted FlowFuse
- To configure FlowFuse with SSO, make sure you are logged in as an administrator.
- Go to Admin settings by clicking on the profile icon in the top-right corner and then selecting "Admin settings".
- Click on "Settings" from the left sidebar and switch to the SSO section.
- Click on the top-right "Create SSO configuration".
- Enter a name for your configuration, then enter the domain that the platform will use for SSO and select "SAML" option and click on "create configuration" button.
- In the next tab, you'll find the ACS URL and Entity ID. Copy and save them somewhere in the notepad.
- Tick "Manage roles using group assertions" if needed. If enabled, keep the Group Assertion Name to its default value and select the team scope:
- "Apply to selected teams" restricts management to the provided list of groups, For adding the list refer to SAML Groups configuration, suitable for shared-tenancy platforms like FlowFuse Cloud.
- "Apply to all teams" allows SAML groups to manage all teams, suitable for a self-hosted installation with a single SSO configuration.
- Click on "Update configuration", we will back to update this configuration with our configuration provided by our Google workpsace later.
# Creating the SAML APP in Google Workspace.
- Open the main menu from the top-right corner by clicking on menu icon.
-
Click on the "Apps" icon, which expands additional choices. Then click on the "Web and mobile apps."
-
Then the new tab opens, click on to the "Add app" from the top.
- The options open select the "Add custom SAML apps."
- Enter the app name description and upload an icon for the app.
- Now copy your Copy the SSO URL, entity ID and certificate or you can simply download it in the one file by clicking on the Download metadata button.
- Click on the continue.
- In the next tab, enter the ACS URL and entity id provided by your self-hosted flowfuse platform.
-
Enter the start URL as
forge.<your-domain>.com
, we are specify that after successfull sign in the user should be redirected to this url. -
Next, click on "Continue" button and then click on "finish".
# Updating the FlowFuse SSO configuration and enabling it
Now that we have created the SAML app in the workspace, we need to update the FlowFuse configuration and connect it to the app created in the workspace to enable SSO.
- Go to the SSO section of the admin settings in your self-hosted FlowFuse platform. Click on the three-dot icon located at the right corner of the added configuration and select "Edit."
- Add the copied values for the fields: Identity Provider Single Sign-On URL, Identity Provider Issuer ID / URL, and X.509 Certificate Public Key provided by the provider. I instructed you in the above section to copy or download them.
- Click on the "Active" option to enable the SSO in the same form.
- Click on "Update configuration".
# Signing in Using SSO
To sign in using SSO, users of your self-hosted FlowFuse must have a FlowFuse account created with an email ID associated with the domain configured with SSO. For more information, refer to creating users in FlowFuse. Additionally, the user must already be logged in with that email in the browser.
- Open your platform in the browser, Enter the email address in the username/email field.
- Click on "Login".
- A Google tab will open, displaying the email addresses you are signed in with. Select the email address you entered into the username/email field.
Note: Admin users will still be able to log in with their original FlowFuse username/password - this ensures they don't get locked out of the platform if there is a problem with the SSO configuration
# Conclusion
In this guide, we've covered setting up SSO SAML for your self-hosted FlowFuse platform, exploring how SSO and SAML enhance user experience, improve security, and simplify management. You've learned to create an SSO configuration in FlowFuse, set up a SAML app in Google Workspace, and enable seamless authentication.
Written By:
Published on:
Recommended Articles:
- Why FlowFuse is the Complete Toolkit For Building UNS?
- Getting Started: Integrating Siemens S7 PLCs with Node-RED
- FlowFuse 2.13: Remote Instances, UNS Schemas & Improved Management at Scale
- MQTT: The Frontrunner for Your UNS Broker - Part 2
- MQTT: The Frontrunner for Your UNS Broker - Part 1