Skip to content

Commit

Permalink
Cache retrieval of user permissions
Browse files Browse the repository at this point in the history
Because if we're going to inspect comments, it's going to be a lot of
inspected users.
  • Loading branch information
yrodiere committed Dec 12, 2024
1 parent 966bc1d commit 8ca2b73
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 6 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
import java.io.IOException;
import java.sql.Date;
import java.time.Clock;
import java.time.Duration;
import java.time.Instant;
import java.time.temporal.ChronoUnit;
import java.util.HashMap;
Expand All @@ -31,9 +32,11 @@
import org.kohsuke.github.GHIssueSearchBuilder;
import org.kohsuke.github.GHIssueState;
import org.kohsuke.github.GHRepository;
import org.kohsuke.github.GHUser;
import org.kohsuke.github.GitHub;

import com.github.benmanes.caffeine.cache.Caffeine;
import com.github.benmanes.caffeine.cache.LoadingCache;

import io.quarkiverse.githubapp.ConfigFile;
import io.quarkiverse.githubapp.GitHubClientProvider;
import io.quarkiverse.githubapp.GitHubConfigFileProvider;
Expand All @@ -54,6 +57,7 @@ public class GitHubRepository implements AutoCloseable {
private final GitHubConfigFileProvider configFileProvider;
private final MessageFormatter messageFormatter;
private final GitHubRepositoryRef ref;
private final LoadingCache<String, IssueActionSide> noContextIssueActionSideCache;

private GitHub client;
private GHRepository repository;
Expand All @@ -66,6 +70,10 @@ public GitHubRepository(Clock clock, GitHubClientProvider clientProvider, GitHub
this.configFileProvider = configFileProvider;
this.messageFormatter = messageFormatter;
this.ref = ref;
this.noContextIssueActionSideCache = Caffeine.newBuilder()
.maximumSize(100)
.expireAfterWrite(Duration.ofMinutes(1))
.build(this::computeNoContextIssueActionSide);
}

@Override
Expand Down Expand Up @@ -211,18 +219,23 @@ private IssueActionSide lastActionSide(GHIssue ghIssue, Set<String> initialActio
// No action since the label was assigned.
return IssueActionSide.TEAM;
}
return getIssueActionSide(ghIssue, lastComment.get().getUser());
return getIssueActionSide(ghIssue, lastComment.get().getUser().getLogin());
}

private IssueActionSide getIssueActionSide(GHIssue issue, GHUser user) throws IOException {
if (issue.getUser().getLogin().equals(user.getLogin())) {
private IssueActionSide getIssueActionSide(GHIssue issue, String login) throws IOException {
if (issue.getUser().getLogin().equals(login)) {
// This is the reporter; even if part of the team,
// we'll consider he's acting as an outsider here,
// because he's unlikely to ask for feedback from himself.
return IssueActionSide.OUTSIDER;
}

return switch (repository().getPermission(user)) {
// Caching in case a same user is encountered multiple times in the same run.
return noContextIssueActionSideCache.get(login);
}

private IssueActionSide computeNoContextIssueActionSide(String login) throws IOException {
return switch (repository().getPermission(login)) {
case ADMIN, WRITE, UNKNOWN -> IssueActionSide.TEAM; // "Unknown" includes "triage"
case READ, NONE -> IssueActionSide.OUTSIDER;
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -225,7 +225,7 @@ public static GHUser mockUserForInspectedComments(GitHubMockContext context, GHR
GHUser mock = context.ghObject(GHUser.class, id);
when(mock.getLogin()).thenReturn(login);
if (permissionType != null) {
when(repositoryMock.getPermission(mock)).thenReturn(permissionType);
when(repositoryMock.getPermission(login)).thenReturn(permissionType);
}
return mock;
}
Expand Down

0 comments on commit 8ca2b73

Please sign in to comment.