< Summary

Information
Class: Elsa.Identity.Endpoints.Users.Update.Update
Assembly: Elsa.Identity
File(s): /home/runner/work/elsa-core/elsa-core/src/modules/Elsa.Identity/Endpoints/Users/Update/Endpoint.cs
Line coverage
16%
Covered lines: 4
Uncovered lines: 20
Coverable lines: 24
Total lines: 54
Line coverage: 16.6%
Branch coverage
0%
Covered branches: 0
Total branches: 6
Branch coverage: 0%
Method coverage

Feature is only available for sponsors

Upgrade to PRO version

Metrics

MethodBranch coverage Crap Score Cyclomatic complexity Line coverage
.ctor(...)100%11100%
Configure()100%11100%
HandleAsync()0%4260%

File(s)

/home/runner/work/elsa-core/elsa-core/src/modules/Elsa.Identity/Endpoints/Users/Update/Endpoint.cs

#LineLine coverage
 1using Elsa.Abstractions;
 2using Elsa.Identity.Contracts;
 3using JetBrains.Annotations;
 4
 5namespace Elsa.Identity.Endpoints.Users.Update;
 6
 7/// <summary>
 8/// An endpoint that updates an existing user's password and roles.
 9/// </summary>
 10[PublicAPI]
 311internal class Update(IUserStore userStore, ISecretHasher secretHasher) : ElsaEndpoint<Request, Response>
 12{
 13    /// <inheritdoc />
 14    public override void Configure()
 15    {
 316        Put("/identity/users/{id}");
 317        ConfigurePermissions("update:user");
 318    }
 19
 20    /// <inheritdoc />
 21    public override async Task HandleAsync(Request request, CancellationToken cancellationToken)
 22    {
 023        var id = Route<string>("id")!;
 24
 025        var user = await userStore.FindAsync(new()
 026            { Id = id }, cancellationToken);
 27
 028        if (user == null)
 29        {
 030            await Send.NotFoundAsync(cancellationToken);
 031            return;
 32        }
 33
 034        if (request.Roles != null)
 035            user.Roles = request.Roles;
 36
 037        if (!string.IsNullOrWhiteSpace(request.Password))
 38        {
 039            var hashedPassword = secretHasher.HashSecret(request.Password.Trim());
 040            user.HashedPassword = hashedPassword.EncodeSecret();
 041            user.HashedPasswordSalt = hashedPassword.EncodeSalt();
 42        }
 43
 044        await userStore.SaveAsync(user, cancellationToken);
 45
 046        var response = new Response(
 047            user.Id,
 048            user.Name,
 049            user.Roles,
 050            user.TenantId);
 51
 052        await Send.OkAsync(response, cancellationToken);
 053    }
 54}