1
0
mirror of https://github.com/bitwarden/server synced 2026-02-20 11:23:37 +00:00
Files
server/util/Seeder/Steps/CreateOwnerStep.cs

35 lines
1.3 KiB
C#

using Bit.Core.Enums;
using Bit.RustSDK;
using Bit.Seeder.Factories;
using Bit.Seeder.Pipeline;
namespace Bit.Seeder.Steps;
/// <summary>
/// Creates the owner user and links them to the current organization.
/// </summary>
internal sealed class CreateOwnerStep : IStep
{
public void Execute(SeederContext context)
{
var org = context.RequireOrganization();
var password = context.GetPassword();
var ownerEmail = context.GetMangler().Mangle($"owner@{context.RequireDomain()}");
var userKeys = RustSdkService.GenerateUserKeys(ownerEmail, password);
var owner = UserSeeder.Create(ownerEmail, context.GetPasswordHasher(), context.GetMangler(), keys: userKeys, password: password);
var ownerOrgKey = RustSdkService.GenerateUserOrganizationKey(owner.PublicKey!, context.RequireOrgKey());
var ownerOrgUser = org.CreateOrganizationUserWithKey(
owner, OrganizationUserType.Owner, OrganizationUserStatusType.Confirmed, ownerOrgKey);
context.Owner = owner;
context.OwnerOrgUser = ownerOrgUser;
context.Users.Add(owner);
context.OrganizationUsers.Add(ownerOrgUser);
context.Registry.HardenedOrgUserIds.Add(ownerOrgUser.Id);
context.Registry.UserDigests.Add(new EntityRegistry.UserDigest(owner.Id, ownerOrgUser.Id, userKeys.Key));
}
}