I'm working on a new application in Blazor. I have asp.net identity setup and working.
Is there a way to be authenticated, but not authorized?
For example, initially we are requiring users to register, but are not adding their roles until we manually add them.
So the user could be authenticated by entering the correct user name and password, but has no roles, so there would be no menu items.
Is there a way to do this in Blazor razor with asp.net identity?
<AuthorizeView Roles="@X.Shared.Constants.AspNetRolesConstants.Administrator.ToString()">
<Authorized>
<h3>Welcome to X Research!</h3>
</Authorized>
<NotAuthorized>
<h3>Welcome to X Research!</h3>
<br />
Please Log in!
<br /><br />
(If you are returned to this page, please contact an Administrator to have roles added for your account!)
</NotAuthorized>
</AuthorizeView>
I read this article, but it doesn't seem to do what I want to do.
Thanks.
Update
When I use the above AuthorizeView
etc., then when you are not logged in, I see this:
So I would rather not show 'Not Authorized' on the main Index.razor page if they need to log in.
Maybe there is a way to redirect to my Login page if they are not authenicated?
Yes you can redirect to other Pages just inject the NavigationManager:
@inject NavigationManager NavManager
<h1>Redirect Page</h1>
<p>Redirecting to Default Page</p>
@code {
protected override void OnInitialized()
{
NavManager.NavigateTo("/");
}
}