/* * Copyright 2014-2017 Groupon, Inc * Copyright 2014-2017 The Billing Project, LLC * * The Billing Project licenses this file to you under the Apache License, version 2.0 * (the "License"); you may not use this file except in compliance with the * License. You may obtain a copy of the License at: * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations * under the License. */ package org.killbill.billing.util.cache; import javax.inject.Inject; import javax.inject.Singleton; import org.killbill.billing.callcontext.InternalTenantContext; import org.killbill.billing.overdue.api.OverdueApiException; import org.killbill.billing.overdue.api.OverdueConfig; import org.killbill.billing.tenant.api.TenantInternalApi; import org.killbill.billing.util.cache.Cachable.CacheType; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @Singleton public class TenantOverdueConfigCacheLoader extends BaseCacheLoader<Long, Object> { private static final Logger log = LoggerFactory.getLogger(TenantOverdueConfigCacheLoader.class); private final TenantInternalApi tenantApi; @Inject public TenantOverdueConfigCacheLoader(final TenantInternalApi tenantApi) { super(); this.tenantApi = tenantApi; } @Override public CacheType getCacheType() { return CacheType.TENANT_OVERDUE_CONFIG; } @Override public Object compute(final Long key, final CacheLoaderArgument cacheLoaderArgument) { final Long tenantRecordId = key; final InternalTenantContext internalTenantContext = new InternalTenantContext(tenantRecordId); if (cacheLoaderArgument.getArgs() == null || !(cacheLoaderArgument.getArgs()[0] instanceof LoaderCallback)) { throw new IllegalArgumentException("Missing LoaderCallback from the arguments"); } final LoaderCallback callback = (LoaderCallback) cacheLoaderArgument.getArgs()[0]; final String overdueXML = tenantApi.getTenantOverdueConfig(internalTenantContext); if (overdueXML == null) { return EMPTY_VALUE_PLACEHOLDER; } try { log.info("Loading overdue cache for tenant " + internalTenantContext.getTenantRecordId()); return callback.loadOverdueConfig(overdueXML); } catch (final OverdueApiException e) { throw new IllegalStateException(String.format("Failed to de-serialize overdue config for tenant %s : %s", internalTenantContext.getTenantRecordId(), e.getMessage()), e); } } public interface LoaderCallback { public OverdueConfig loadOverdueConfig(final String overdueConfigXML) throws OverdueApiException; } }