001/*- 002 * #%L 003 * HAPI FHIR - Core Library 004 * %% 005 * Copyright (C) 2014 - 2025 Smile CDR, Inc. 006 * %% 007 * Licensed under the Apache License, Version 2.0 (the "License"); 008 * you may not use this file except in compliance with the License. 009 * You may obtain a copy of the License at 010 * 011 * http://www.apache.org/licenses/LICENSE-2.0 012 * 013 * Unless required by applicable law or agreed to in writing, software 014 * distributed under the License is distributed on an "AS IS" BASIS, 015 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 016 * See the License for the specific language governing permissions and 017 * limitations under the License. 018 * #L% 019 */ 020package ca.uhn.fhir.util; 021 022import ca.uhn.fhir.i18n.Msg; 023import ca.uhn.fhir.rest.server.exceptions.InternalErrorException; 024import org.slf4j.Logger; 025import org.slf4j.LoggerFactory; 026 027import java.util.concurrent.CountDownLatch; 028import java.util.concurrent.TimeUnit; 029 030public class AsyncUtil { 031 private static final Logger ourLog = LoggerFactory.getLogger(AsyncUtil.class); 032 033 /** 034 * Non instantiable 035 */ 036 private AsyncUtil() {} 037 038 /** 039 * Calls Thread.sleep and if an InterruptedException occurs, logs a warning but otherwise continues 040 * 041 * @param theMillis The number of millis to sleep 042 * @return Did we sleep the whole amount 043 */ 044 public static boolean sleep(long theMillis) { 045 try { 046 Thread.sleep(theMillis); 047 return true; 048 } catch (InterruptedException theE) { 049 Thread.currentThread().interrupt(); 050 ourLog.warn("Sleep for {}ms was interrupted", theMillis); 051 return false; 052 } 053 } 054 055 public static boolean awaitLatchAndThrowInternalErrorExceptionOnInterrupt( 056 CountDownLatch theInitialCollectionLatch, long theTime, TimeUnit theTimeUnit) { 057 try { 058 return theInitialCollectionLatch.await(theTime, theTimeUnit); 059 } catch (InterruptedException e) { 060 Thread.currentThread().interrupt(); 061 throw new InternalErrorException(Msg.code(1805) + e); 062 } 063 } 064 065 public static boolean awaitLatchAndIgnoreInterrupt( 066 CountDownLatch theInitialCollectionLatch, long theTime, TimeUnit theTimeUnit) { 067 try { 068 return theInitialCollectionLatch.await(theTime, theTimeUnit); 069 } catch (InterruptedException e) { 070 Thread.currentThread().interrupt(); 071 ourLog.warn("Interrupted while waiting for latch"); 072 return false; 073 } 074 } 075}