/*
* 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;
// }
// }