Skip to content

This app allows you to use Azure Active Directory services to authenticate users on a Meraki network

License

Notifications You must be signed in to change notification settings

BenaroyaResearch/meraki2azure_ad

 
 

Repository files navigation

Meraki Captive Portal with Azure Active Directory

This Node.js app was created to facilitate the authorization of users registered on an Azure Active Directory with Meraki wireless infrastructures. Instead of using a RADIUS server for the authentication, you can spin up a web server that will be serving as your Captive Portal, which will then authenticate the user using OAuth

References

This application and the step by step below were created / cloned based on the code provided by Microsoft, hosted here. Additionally, the information available at Meraki's documentation about building your own JavaScript captive portal or the click-through-api description. This one is also helpful.

Quick Start

In order to work with Meraki's captive portal, your server will need to run on a publicly available IP, i.e., you will need to host it out in the Internet. There are several alternatives to address this. For development purposes, you can use ngrok, which will create introspectable tunnels to your localhost. For production environments, you can use Heroku, which is a PAAS that has a free tier of service or Azure Webapp which also have a Free plan.

Once you have the public URL where the server will run, take note of that. It will be referred as https://public-url.example.com in this document.

Meraki Dashboard Setup

The steps below were copied from Meraki's official documentation Configuring a Custom-Hosted Splash Page

Configure Access Control

  • In Dashboard, navigate to Configure > Access control.
  • Select the SSID you want to configure from the SSID drop-down.
  • Under Network access > Association requirements, choose "Open", "WPA2," or "WEP."
  • Under Network access > Network sign-on method, choose "Click-through splash page" or "Sign-on splash page."
  • Enable walled garden (located under Network access > Walled garden) and enter the public IP address or domain name of your web server.
  • Click "Save Changes."

Enabling a Custom-Hosted Splash page on the Meraki Cloud

  • Navigate to Configure > Splash page
  • Select the SSID you want to configure from the SSID drop-down.
  • Under Custom splash URL select the radio button Or provide a URL where users will be redirected:
  • Type the URL of your custom splash page: https://public-url.example.com
  • Click Save Changes.

Azure Setup

Step 1: Register an Azure AD Tenant

To use this sample you will need a Windows Azure Active Directory Tenant. If you're not sure what a tenant is or how you would get one, read What is an Azure AD tenant? or Sign up for Azure as an organization. These docs should get you started on your way to using Windows Azure AD.

Step 2: Create an App Registration

Create an App Registration object

  • In Manage -> Authentication:
    • Add a redirect URI https://public-url.example.com/auth/openid/return. You can add many, if you access it from CNAME in another domain.
    • Add the logout URL https://public-url.example.com/logout
    • Check the box ID tokens (used for implicit and hybrid flows)
  • In Manage -> Certificates & secrets:
    • Add a new Client secret
    • Careful, the max age in 24 months... Don't forget to renew before expiration ;-)
  • In Manage -> API permissions:
    • Grant the Microsoft.Graph User.Read permission.

Step 3: Write down the following needed parameters

  • TENANT_ID: your Tenant ID
  • CLIENT_ID: your App Registration ID
  • CLIENT_SECRET: your Client secret value

This APP setup

Step 1: Download node.js for your platform

To successfully use this sample, you need a working installation of Node.js.

Step 2: Download the Sample application and modules

Next, clone the sample repo and install the NPM. From your shell or command line:

git clone [email protected]:spie-ics-ag/meraki2azure_ad.git
cd meraki2azure_ad
npm install

Step 3: Configure your server

Some mandatory parameters are read from the environment variables. You need to export them as follow before starting your app:

export CLOUD_INSTANCE=https://login.microsoftonline.com/
export AZ_TENANT_ID=11111111-1111-1111-1111-111111111111
export AZ_CLIENT_ID=00000000-0000-0000-0000-000000000000
export AZ_CLIENT_SECRET=xxxxx~xxxxxx~xxxxxxxxxxxxxxxxxxxxxxxxxxx
export REDIRECT_URL=https://public-url.example.com
export SESSION_SECRET=<A_Secret_Key>

Optionally, if you want to change the CSS and the logos, you can override the public directory path to your customized path, with:

export PUBLIC_DIR_PATH=custom_public

Note: the PUBLIC_DIR_PATH is relative to the src folder. This is useful for Azure Storage Mount

You can also change portal default title and default SSID with:

export PORTAL_TITLE="Guest Captive Portal"
export SSID="Guest WiFi"

Step 4: Run the application

Run the app. Use the following command in terminal.

npm run start

You're done

You will have a server successfully running on https://public-url.example.com (or on http://localhost:3000 if you are testing it locally).

Testing before the Meraki config is done

You can test the application without the Meraki config (for example, to validate the connection and authentication to the Azure AD is working properly). For this, just pass a fake base_grant_url parameter to your server: https://public-url.example.com?base_grant_url=whatever You will get the Login page, will be able to login to Azure AD, but the redirection will fail (as you didn't pass a valid base_grant_url). But if you go again to https://public-url.example.com/auth/signin, you'll see you are successfully logged in.

User Experience

When the user selects the configured wireless SSID, a splash page will be shown prompting for their Azure AD Credentials.

About

This app allows you to use Azure Active Directory services to authenticate users on a Meraki network

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 81.8%
  • CSS 7.9%
  • EJS 7.9%
  • Dockerfile 2.3%
  • Procfile 0.1%