-
Notifications
You must be signed in to change notification settings - Fork 66
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Setting up without vue-msal #51
Comments
thanks I have the same issue |
I updated the code above. I stumbled on an issue where the package was constantly fetching a new access token over the internet, with every page load. It appears you have to input your app Client ID into the scopes to get an access token. The msal library uses the access token to maintain token expiration in cache. Without the access token it's read as non-existant and a new token is fetched each time. |
@OssiPesonen Much Appreciated! |
Thank you very much, I will definitely try this out. Would you like to rewrite it for nuxt.js 3? Also you could create a PR with a sample (nuxt2 or nuxt3) in the official Microsoft repository: Thanks! |
@OssiPesonen thanks heaps! I am going to try this out today... |
@OssiPesonen I've wired it up and it works great! Thanks heaps :) |
Any example for nuxt |
It appears obvious that the maintainers of this repo have long abandoned it. It's been nearly 1.5 years since the last update, and Azure's MSAL version is already in 2.18.0.
I recently also tried to set up MSAL for a Vue.js. app and stumbled into this package, as well as the vue-msal-2 package, but had no luck in getting them to work. So, I went and installed the @azure/msal-browser (latest version) and set it up manually, which was relatively easy for an app running on Nuxt.js. You can do this as well. No need for a wrapper. I'll try and write down the steps I took for anyone who stumbles into this repo.
Steps to set up @azure/msal-browser
Initialize
First thing you need to do is initialize MSAL. You need to set up a configuration object and pass it to the
msa.PublicClientApplication
function. Note that these settings are for my use case, and I will refer you to the msal-browser package documentation to figure out your needs. My use case is I have an Azure AD B2C tenant and an application there for an SPA that uses a redirect method instead of a popup window.The example below is a nuxt.js plugin I set up in the plugins folder (
/plugins/msal.js
) which injects themsal
into your Nuxt application, making it available there. No need to copy paste the whole thing, just grab what you need here.Set up a function to handle the redirect from Azure
I set up a helper function to be called on the sign in process page, which basically handles a redirect promise (if available), fetches the user accounts and makes a silent token request. MSAL holds the token in localStorage (or sessionStorage) so it doesn't have to make trips to the server if the token is still viable.
Once you have a token you can redirect the user to some other page, or if it fails you can throw him back to the login page.
Auth middleware (optional)
You can set up a middleware for Nuxt.js to make sure there's a viable token in play before allowing users to route to some pages.
The example above should try and fetch the token and simply ignore it's response, but in case there's no token or account, msal will throw an error and you can redirect the user to a login page.
I hope that helps and people won't waste time on this repo!
The text was updated successfully, but these errors were encountered: