From 972bbe2fc006ee6546c86db6831d4b7c21c85b4d Mon Sep 17 00:00:00 2001 From: aleklundeq <138589813+aleklundeq@users.noreply.github.com> Date: Wed, 20 Sep 2023 15:17:09 +0200 Subject: [PATCH] feat/chunkGettingPersonProfiles (#591) * Chunking 500 at the time when getting PersonProfile from PeopleAPI * Fixed variablename --- .../Queries/GetPersonProfiles.cs | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/src/backend/api/Fusion.Resources.Domain/Queries/GetPersonProfiles.cs b/src/backend/api/Fusion.Resources.Domain/Queries/GetPersonProfiles.cs index 87758b322..86f7590f2 100644 --- a/src/backend/api/Fusion.Resources.Domain/Queries/GetPersonProfiles.cs +++ b/src/backend/api/Fusion.Resources.Domain/Queries/GetPersonProfiles.cs @@ -19,7 +19,7 @@ public GetPersonProfiles(IEnumerable azureObjectIds) .ToList(); } - public List Identifiers { get; } + public List Identifiers { get; } public class Handler : IRequestHandler> { @@ -29,9 +29,20 @@ public Handler(IFusionProfileResolver profileResolver) { this.profileResolver = profileResolver; } - public async Task> Handle(GetPersonProfiles request, CancellationToken cancellationToken) + public async Task> Handle(GetPersonProfiles request, CancellationToken cancellationToken) { - var profiles = await profileResolver.ResolvePersonsAsync(request.Identifiers); + var tasks = new List>>(); + + // Max number of identifiers is 500, so we chunk the requests + foreach (var req in request.Identifiers.Chunk(500)) + { + tasks.Add(profileResolver.ResolvePersonsAsync(request.Identifiers)); + } + + var results = await Task.WhenAll(tasks); + + var profiles = results.Select(p => p).SelectMany(p => p); + return profiles .Where(p => p.Success && p.Profile?.AzureUniqueId != null) .ToDictionary(