From cd7ee6480b4d2acaf32dbb86ca7abeb0dfc5dcaf Mon Sep 17 00:00:00 2001 From: Shaun Ford Date: Thu, 13 Jul 2017 09:21:12 -0700 Subject: [PATCH] Immediately return from cleanup endpoint * Update the cleanup endpoint to immediately return 204 (No Content) status code, and run actual clean up process in the background --- .../CleanUpInactiveOrOrphanedRecords.java | 28 ++++++------------- .../nike/cerberus/service/CleanUpService.java | 15 ++++++++-- 2 files changed, 22 insertions(+), 21 deletions(-) diff --git a/src/main/java/com/nike/cerberus/endpoints/admin/CleanUpInactiveOrOrphanedRecords.java b/src/main/java/com/nike/cerberus/endpoints/admin/CleanUpInactiveOrOrphanedRecords.java index e08b72aac..94b742c44 100644 --- a/src/main/java/com/nike/cerberus/endpoints/admin/CleanUpInactiveOrOrphanedRecords.java +++ b/src/main/java/com/nike/cerberus/endpoints/admin/CleanUpInactiveOrOrphanedRecords.java @@ -23,7 +23,6 @@ import com.nike.cerberus.service.CleanUpService; import com.nike.riposte.server.http.RequestInfo; import com.nike.riposte.server.http.ResponseInfo; -import com.nike.riposte.server.http.impl.FullResponseInfo; import com.nike.riposte.util.AsyncNettyHelper; import com.nike.riposte.util.Matcher; import io.netty.channel.ChannelHandlerContext; @@ -50,8 +49,6 @@ public class CleanUpInactiveOrOrphanedRecords extends AdminStandardEndpoint> doExecute(final RequestInfo cleanUp(request, securityContext), ctx), - longRunningTaskExecutor - ); - } - - private FullResponseInfo cleanUp(final RequestInfo request, - final SecurityContext securityContext) { final VaultAuthPrincipal vaultAuthPrincipal = (VaultAuthPrincipal) securityContext.getUserPrincipal(); final String principal = vaultAuthPrincipal.getName(); log.info("Clean Up Event: the principal {} is attempting to clean up kms keys", principal); - Integer expirationPeriodInDays = request.getContent().getKmsExpirationPeriodInDays(); - int kmsKeysInactiveAfterNDays = (expirationPeriodInDays == null) ? DEFAULT_KMS_KEY_INACTIVE_AFTER_N_DAYS : expirationPeriodInDays; - - cleanUpService.cleanUpInactiveAndOrphanedKmsKeys(kmsKeysInactiveAfterNDays); - cleanUpService.cleanUpOrphanedIamRoles(); + longRunningTaskExecutor.execute(AsyncNettyHelper.runnableWithTracingAndMdc( + () -> cleanUpService.cleanUp(request.getContent()), + ctx + )); - return ResponseInfo.newBuilder() - .withHttpStatusCode(HttpResponseStatus.NO_CONTENT.code()) - .build(); + return CompletableFuture.completedFuture( + ResponseInfo.newBuilder() + .withHttpStatusCode(HttpResponseStatus.NO_CONTENT.code()) + .build() + ); } @Override diff --git a/src/main/java/com/nike/cerberus/service/CleanUpService.java b/src/main/java/com/nike/cerberus/service/CleanUpService.java index aa2f5e789..af97b83f7 100644 --- a/src/main/java/com/nike/cerberus/service/CleanUpService.java +++ b/src/main/java/com/nike/cerberus/service/CleanUpService.java @@ -20,6 +20,7 @@ import com.google.inject.Inject; import com.google.inject.Singleton; import com.nike.cerberus.dao.AwsIamRoleDao; +import com.nike.cerberus.domain.CleanUpRequest; import com.nike.cerberus.record.AwsIamRoleKmsKeyRecord; import com.nike.cerberus.record.AwsIamRoleRecord; import com.nike.cerberus.util.DateTimeSupplier; @@ -42,6 +43,8 @@ public class CleanUpService { private static final int DEFAULT_SLEEP_BETWEEN_KMS_CALLS = 10; // in seconds + private static final int DEFAULT_KMS_KEY_INACTIVE_AFTER_N_DAYS = 30; + private final KmsService kmsService; private final AwsIamRoleDao awsIamRoleDao; @@ -57,11 +60,19 @@ public CleanUpService(KmsService kmsService, this.dateTimeSupplier = dateTimeSupplier; } + public void cleanUp(final CleanUpRequest cleanUpRequest) { + Integer expirationPeriodInDays = cleanUpRequest.getKmsExpirationPeriodInDays(); + int kmsKeysInactiveAfterNDays = (expirationPeriodInDays == null) ? DEFAULT_KMS_KEY_INACTIVE_AFTER_N_DAYS : expirationPeriodInDays; + + cleanUpInactiveAndOrphanedKmsKeys(kmsKeysInactiveAfterNDays); + cleanUpOrphanedIamRoles(); + } + /** * Delete all AWS KMS keys and DB records for KMS keys that have not been used recently * or are no longer associated with an SDB. */ - public void cleanUpInactiveAndOrphanedKmsKeys(final int kmsKeysInactiveAfterNDays) { + protected void cleanUpInactiveAndOrphanedKmsKeys(final int kmsKeysInactiveAfterNDays) { cleanUpInactiveAndOrphanedKmsKeys(kmsKeysInactiveAfterNDays, DEFAULT_SLEEP_BETWEEN_KMS_CALLS); } @@ -109,7 +120,7 @@ protected void cleanUpInactiveAndOrphanedKmsKeys(final int kmsKeysInactiveAfterN /** * Delete all IAM role records that are no longer associated with an SDB. */ - public void cleanUpOrphanedIamRoles() { + protected void cleanUpOrphanedIamRoles() { // get orphaned iam role ids final List orphanedIamRoleIds = awsIamRoleDao.getOrphanedIamRoles();