feat : add admin

pull/38/head
Maxence GUITARD 1 year ago
parent 86cb4700d9
commit 9e49536a88

@ -0,0 +1,30 @@
using Microsoft.AspNetCore.Cryptography.KeyDerivation;
using Microsoft.AspNetCore.Identity;
using System.Security.Cryptography;
using System.Text;
namespace Blazor.Models;
public class AdministratorModel
{
public int Id { get; set; }
public string Username { get; set; }
public string HashedPassword { get; set; }
public void HashPassword(string password)
{
using (MD5 md5 = MD5.Create())
{
byte[] inputBytes = Encoding.UTF8.GetBytes(password);
byte[] hashBytes = md5.ComputeHash(inputBytes);
StringBuilder sb = new StringBuilder();
for (int i = 0; i < hashBytes.Length; i++)
{
sb.Append(hashBytes[i].ToString("x2"));
}
HashedPassword = sb.ToString();
}
}
}

@ -1,13 +0,0 @@
using Microsoft.AspNetCore.Cryptography.KeyDerivation;
using Microsoft.AspNetCore.Identity;
using System.Security.Cryptography;
namespace Blazor.Models;
public class AdministratorsModel : PasswordHasher<string>
{
public int Id { get; set; }
public string Username { get; set; }
public string hashedPassword { get; set; }
}

@ -1,20 +1,20 @@
@page "/addAdministrators"
@page "/addAdministrator"
@using Blazor.Models
<h3>AddAdministrators</h3>
<h3>AddAdministrator</h3>
<EditForm Model="@administratorsModel" OnValidSubmit="@HandleValidSubmit">
<EditForm Model="@administratorModel" OnValidSubmit="@HandleValidSubmit">
<DataAnnotationsValidator />
<ValidationSummary />
<p>
<label for="username">
Username:
<InputText id="username" @bind-Value="administratorsModel.Username" />
<InputText id="username" @bind-Value="administratorModel.Username" />
</label>
<label for="hashedPassword">
Password:
<InputText id="hashedPassword" @bind-Value="administratorsModel.hashedPassword" />
<InputText id="hashedPassword" @bind-Value="administratorModel.HashedPassword" />
</label>
</p>

@ -0,0 +1,51 @@
using Blazored.LocalStorage;
using Microsoft.AspNetCore.Components.Forms;
using Microsoft.AspNetCore.Components;
using Blazor.Models;
using Blazor.Services;
namespace Blazor.Pages.Admins
{
public partial class AddAdministrator
{
private AdministratorModel administratorModel = new();
[Inject]
public IDataService DataService { get; set; }
[Inject]
public NavigationManager NavigationManager { get; set; }
private async void HandleValidSubmit()
{
administratorModel.HashPassword(administratorModel.HashedPassword);
await DataService.Add(administratorModel);
var formData = new List<KeyValuePair<string, string>>();
formData.Add(new KeyValuePair<string, string>("username", administratorModel.Username));
formData.Add(new KeyValuePair<string, string>("password", administratorModel.HashedPassword));
var formContent = new FormUrlEncodedContent(formData);
string apiUri = "https://trusting-panini.87-106-126-109.plesk.page/api/add/administrators";
using (var httpClient = new HttpClient())
{
var response = await httpClient.PostAsync(apiUri, formContent);
if (response.IsSuccessStatusCode)
{
var responseBody = await response.Content.ReadAsStringAsync();
}
else
{
var errorResponse = await response.Content.ReadAsStringAsync();
}
}
NavigationManager.NavigateTo("administrators");
}
}
}

@ -1,27 +0,0 @@
using Blazored.LocalStorage;
using Microsoft.AspNetCore.Components.Forms;
using Microsoft.AspNetCore.Components;
using Blazor.Models;
using Blazor.Services;
namespace Blazor.Pages.Admins
{
public partial class AddAdministrators
{
private AdministratorsModel administratorsModel = new();
[Inject]
public IDataService DataService { get; set; }
[Inject]
public NavigationManager NavigationManager { get; set; }
private async void HandleValidSubmit()
{
await DataService.Add(administratorsModel);
NavigationManager.NavigateTo("administrators");
}
}
}

@ -5,7 +5,7 @@
<h3>Administrators</h3>
<div>
<NavLink class="btn btn-primary" href="addAdministrators" Match="NavLinkMatch.All">
<NavLink class="btn btn-primary" href="addAdministrator" Match="NavLinkMatch.All">
<i class="fa fa-plus"></i> Ajouter
</NavLink>
</div>

@ -9,6 +9,7 @@ using Blazor.Modals;
using Blazor.Services;
using Blazored.Modal;
using Blazored.Modal;
using Blazor.Pages.Chapters;
namespace Blazor.Pages.Admins;
@ -43,13 +44,13 @@ public partial class Administrators
}
// When you use a real API, we use this follow code
//var response = await Http.GetJsonAsync<Item[]>( $"http://my-api/api/data?page={e.Page}&pageSize={e.PageSize}" );
var response = (await Http.GetFromJsonAsync<Administrator[]>($"{NavigationManager.BaseUri}fake-administrator.json")).Skip((e.Page - 1) * e.PageSize).Take(e.PageSize).ToList();
//var response = await Http.GetFromJsonAsync<ChaptersModel[]>( $"https://trusting-panini.87-106-126-109.plesk.page/api/administrators?page={e.Page}&pageSize={e.PageSize}" );
var response = Http.GetFromJsonAsync<Administrator[]>($"https://trusting-panini.87-106-126-109.plesk.page/api/administrators").Result;
if (!e.CancellationToken.IsCancellationRequested)
{
totalItem = (await Http.GetFromJsonAsync<List<Administrator>>($"{NavigationManager.BaseUri}fake-administrator.json")).Count;
administrators = new List<Administrator>(response); // an actual data for the current page
totalItem = administrators.Count;
}
}
@ -61,13 +62,13 @@ public partial class Administrators
return;
}
var currentData = await LocalStorage.GetItemAsync<AdministratorsModel[]>("data");
var currentData = await LocalStorage.GetItemAsync<AdministratorModel[]>("data");
// Check if data exist in the local storage
if (currentData == null)
{
// this code add in the local storage the fake data (we load the data sync for initialize the data before load the OnReadData method)
var originalData = Http.GetFromJsonAsync<AdministratorsModel[]>($"trusting-panini.87-106-126-109.plesk.page/api/chapters").Result;
var originalData = Http.GetFromJsonAsync<AdministratorModel[]>($"https://trusting-panini.87-106-126-109.plesk.page/api/administrators").Result;
await LocalStorage.SetItemAsync("data", originalData);
}
}

@ -13,7 +13,7 @@
</label>
<label for="hashedPassword">
Password:
<InputText id="hashedPassword" @bind-Value="administratorsModel.hashedPassword" />
<InputText id="hashedPassword" @bind-Value="administratorsModel.HashedPassword" />
</label>
</p>

@ -10,7 +10,7 @@ namespace Blazor.Pages.Admins
[Parameter]
public int Id { get; set; }
private AdministratorsModel administratorsModel = new();
private AdministratorModel administratorsModel = new();
[Inject]
public IDataService DataService { get; set; }
@ -26,7 +26,7 @@ namespace Blazor.Pages.Admins
var administrator = await DataService.GetAdminById(Id);
// Set the model with the admin
administratorsModel = new AdministratorsModel
administratorsModel = new AdministratorModel
{
Id = administrator.Id,
Username = administrator.Username

@ -5,7 +5,7 @@
<h3>Chapters</h3>
<div>
<NavLink class="btn btn-primary" href="addChapter" Match="NavLinkMatch.All">
<NavLink class="btn btn-primary" href="addQuestion" Match="NavLinkMatch.All">
<i class="fa fa-plus"></i> Ajouter
</NavLink>
</div>

@ -149,7 +149,7 @@ namespace Blazor.Services
return admin;
}
public async Task Update(int id, AdministratorsModel model)
public async Task Update(int id, AdministratorModel model)
{
// Get the current data
var currentData = await _localStorage.GetItemAsync<List<Administrator>>("data");
@ -165,13 +165,13 @@ namespace Blazor.Services
// Modify the content of the adminnistrator
admin.Username = model.Username;
admin.hashedPassword = model.hashedPassword;
admin.HashedPassword = model.HashedPassword;
// Save the data
await _localStorage.SetItemAsync("data", currentData);
}
public async Task Add(AdministratorsModel model)
public async Task Add(AdministratorModel model)
{
// Get the current data
var currentData = await _localStorage.GetItemAsync<List<Administrator>>("data");
@ -184,7 +184,7 @@ namespace Blazor.Services
{
Id = model.Id,
Username = model.Username,
hashedPassword = model.hashedPassword
HashedPassword = model.HashedPassword
});

@ -15,9 +15,9 @@ namespace Blazor.Services
Task Update(int id, ChapterModel model);
Task Add(AdministratorsModel model);
Task Add(AdministratorModel model);
Task Update(int id, AdministratorsModel model);
Task Update(int id, AdministratorModel model);
Task<Administrator> GetAdminById(int id);

@ -4,6 +4,6 @@ public class Administrator
{
public int Id { get; set; }
public string Username { get; set; }
public string hashedPassword { get; set; }
public string HashedPassword { get; set; }
}

Loading…
Cancel
Save