164 lines
6.9 KiB
Plaintext
164 lines
6.9 KiB
Plaintext
@page
|
|
@model LoginModel
|
|
|
|
@{
|
|
ViewData["Title"] = "Log in";
|
|
}
|
|
|
|
<h1>@ViewData["Title"]</h1>
|
|
<div class="row">
|
|
<div class="col-md-4">
|
|
<section>
|
|
<form id="account" method="post">
|
|
<h2>Use a local account to log in.</h2>
|
|
<hr />
|
|
<div asp-validation-summary="ModelOnly" class="text-danger" role="alert"></div>
|
|
<div class="form-floating mb-3">
|
|
<input asp-for="Input.Email" class="form-control" autocomplete="username" aria-required="true" placeholder="name@example.com" />
|
|
<label asp-for="Input.Email" class="form-label">Email</label>
|
|
<span asp-validation-for="Input.Email" class="text-danger"></span>
|
|
</div>
|
|
<div class="form-floating mb-3">
|
|
<input asp-for="Input.Password" class="form-control" autocomplete="current-password" aria-required="true" placeholder="password" />
|
|
<label asp-for="Input.Password" class="form-label">Password</label>
|
|
<span asp-validation-for="Input.Password" class="text-danger"></span>
|
|
</div>
|
|
<div class="checkbox mb-3">
|
|
<label asp-for="Input.RememberMe" class="form-label">
|
|
<input class="form-check-input" asp-for="Input.RememberMe" />
|
|
@Html.DisplayNameFor(m => m.Input.RememberMe)
|
|
</label>
|
|
</div>
|
|
<div>
|
|
<button id="login-submit" type="submit" class="w-100 btn btn-lg btn-primary">Log in</button>
|
|
</div>
|
|
<div>
|
|
<p>
|
|
<a id="forgot-password" asp-page="./ForgotPassword">Forgot your password?</a>
|
|
</p>
|
|
<p>
|
|
<a asp-page="./Register" asp-route-returnUrl="@Model.ReturnUrl">Register as a new user</a>
|
|
</p>
|
|
<p>
|
|
<a id="resend-confirmation" asp-page="./ResendEmailConfirmation">Resend email confirmation</a>
|
|
</p>
|
|
</div>
|
|
</form>
|
|
</section>
|
|
</div>
|
|
<div class="col-md-4" id="ldapLogin">
|
|
<form v-on:submit.prevent="ldapLogin" id="login" method="post">
|
|
<h2>Use a local account to log in.</h2>
|
|
<hr />
|
|
<div class="text-danger" role="alert"></div>
|
|
<div class="form-floating mb-3">
|
|
<input v-model="ldapLoginInfo.username" id="ldapUsername" class="form-control" autocomplete="username" aria-required="true" placeholder="name@example.com" />
|
|
<label id="ldapEmailLabel" class="form-label">Email</label>
|
|
<span id="ldapEmailError" class="text-danger"></span>
|
|
</div>
|
|
<div class="form-floating mb-3">
|
|
<input v-model="ldapLoginInfo.password" id="ldapPassword" class="form-control" type="password" autocomplete="current-password" aria-required="true" placeholder="password" />
|
|
<label id="ldapPasswordLabel" class="form-label">Password</label>
|
|
<span id="ldapPasswordError" class="text-danger"></span>
|
|
</div>
|
|
<div>
|
|
<button id="ldap-login-submit" type="submit" class="w-100 btn btn-lg btn-primary">Log in</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
<div class="col-md-6 col-md-offset-2">
|
|
<section>
|
|
<h3>Use another service to log in.</h3>
|
|
<hr />
|
|
@{
|
|
if ((Model.ExternalLogins?.Count ?? 0) == 0)
|
|
{
|
|
<div>
|
|
<p>
|
|
There are no external authentication services configured. See this <a href="https://go.microsoft.com/fwlink/?LinkID=532715">article
|
|
about setting up this ASP.NET application to support logging in via external services</a>.
|
|
</p>
|
|
</div>
|
|
}
|
|
else
|
|
{
|
|
<form id="external-account" asp-page="./ExternalLogin" asp-route-returnUrl="@Model.ReturnUrl" method="post" class="form-horizontal">
|
|
<div>
|
|
<p>
|
|
@foreach (var provider in Model.ExternalLogins!)
|
|
{
|
|
<button type="submit" class="btn btn-primary" name="provider" value="@provider.Name" title="Log in using your @provider.DisplayName account">@provider.DisplayName</button>
|
|
}
|
|
</p>
|
|
</div>
|
|
</form>
|
|
}
|
|
}
|
|
</section>
|
|
</div>
|
|
</div>
|
|
|
|
@section Scripts {
|
|
<partial name="_ValidationScriptsPartial" />
|
|
|
|
<script>
|
|
|
|
$(function () {
|
|
app.mount('#ldapLogin');
|
|
});
|
|
|
|
const app = Vue.createApp({
|
|
data() {
|
|
return {
|
|
ldapLoginInfo: {
|
|
username: '',
|
|
password: '',
|
|
},
|
|
};
|
|
},
|
|
mounted() {
|
|
|
|
},
|
|
watch: {
|
|
|
|
},
|
|
methods: {
|
|
ldapLogin() {
|
|
console.log(JSON.stringify(this.ldapLoginInfo))
|
|
fetch('/AdminAPI/LdapLogin', {
|
|
method: 'POST',
|
|
headers: {
|
|
'Content-Type': 'application/json'
|
|
},
|
|
body: JSON.stringify(this.ldapLoginInfo)
|
|
})
|
|
.then(response => {
|
|
if (!response.ok) {
|
|
throw new Error('Name module already exist');
|
|
}
|
|
alert('Module information saved successfully');
|
|
})
|
|
.catch(error => {
|
|
console.error('There was a problem with the update operation:', error);
|
|
alert('Failed to save data: ' + error.message);
|
|
});
|
|
},
|
|
fetchControllerMethodList() {
|
|
fetch('/AdminAPI/GetListClassAndMethodInformation', {
|
|
method: 'POST'
|
|
})
|
|
.then(response => response.json())
|
|
.then(data => {
|
|
if (data != null) {
|
|
this.controllerMethodData = data;
|
|
}
|
|
})
|
|
.catch(error => {
|
|
console.error('There was a problem with the fetch operation:', error);
|
|
});
|
|
},
|
|
},
|
|
});
|
|
</script>
|
|
}
|