summaryrefslogtreecommitdiff
path: root/Models
diff options
context:
space:
mode:
authorSergey Chebotar <s.chebotar@gmail.com>2023-03-07 08:18:01 +0300
committerSergey Chebotar <s.chebotar@gmail.com>2023-03-07 08:18:01 +0300
commit45af463dbe359332967c75e4fdb8ab50e2d9e847 (patch)
tree3acf3cfe57dbf5d4fb7bf0fd01207677e0d3de95 /Models
parent0c4d13caed53b2702eef41461d0c8a4b25df48f6 (diff)
Create admin user seed
Diffstat (limited to 'Models')
-rw-r--r--Models/IdentitySeedData.cs30
1 files changed, 30 insertions, 0 deletions
diff --git a/Models/IdentitySeedData.cs b/Models/IdentitySeedData.cs
new file mode 100644
index 0000000..dcaa5c3
--- /dev/null
+++ b/Models/IdentitySeedData.cs
@@ -0,0 +1,30 @@
+using Microsoft.AspNetCore.Identity;
+
+namespace MyDarling.Models;
+
+public class IdentitySeedData
+{
+ public static void CreateAdminAccount(IServiceProvider serviceProvider, IConfiguration configuration)
+ {
+ CreateAdminAccountAsync(serviceProvider, configuration).Wait();
+ }
+
+ public static async Task CreateAdminAccountAsync(IServiceProvider serviceProvider, IConfiguration configuration)
+ {
+ serviceProvider = serviceProvider.CreateScope().ServiceProvider;
+ UserManager<IdentityUser> userManager = serviceProvider.GetRequiredService<UserManager<IdentityUser>>();
+
+ string username = configuration["ADMIN_USERNAME"] ?? "admin";
+ string password = configuration["ADMIN_PASSWORD"] ?? "Password123$";
+
+ if (await userManager.FindByNameAsync(username) == null)
+ {
+ IdentityUser adminUser = new IdentityUser
+ {
+ UserName = username
+ };
+
+ IdentityResult result = await userManager.CreateAsync(adminUser, password);
+ }
+ }
+} \ No newline at end of file