org.broadleafcommerce.core.inventory.service.AvailabilityServiceImpl Maven / Gradle / Ivy
/*
* Copyright 2008-2013 the original author or authors.
*
* Licensed 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.broadleafcommerce.core.inventory.service;
import org.apache.commons.collections.CollectionUtils;
import org.broadleafcommerce.common.util.TransactionUtils;
import org.broadleafcommerce.core.inventory.dao.AvailabilityDao;
import org.broadleafcommerce.core.inventory.domain.SkuAvailability;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.ArrayList;
import java.util.List;
import javax.annotation.Resource;
/**
*
* @deprecated This is no longer required and is instead implemented as a third-party inventory module
*
*/
@Deprecated
@Service("blAvailabilityService")
public class AvailabilityServiceImpl implements AvailabilityService {
@Resource(name="blAvailabilityDao")
protected AvailabilityDao availabilityDao;
/**
* Returns the availability status for this passed in skuId. Implementations may choose
* to cache the status based upon the passed in realTime indicator.
*
* @param skuId
* @param realTime
* @return String indicating the availabilityStatus (statuses are implementation specific)
*/
@Override
public SkuAvailability lookupSKUAvailability(Long skuId, boolean realTime) {
List skuIds = new ArrayList();
skuIds.add(skuId);
List skuAvailbilityList = availabilityDao.readSKUAvailability(skuIds, realTime);
if (skuAvailbilityList != null && skuAvailbilityList.size() >=1) {
return skuAvailbilityList.get(0);
}
return null;
}
/**
* Returns the availability status for a specific skuId and location. Implementations may choose
* to cache the status based upon the passed in realTime indicator.
*
* @param skuId
* @param locationId
* @param realTime
* @return String indicating the availabilityStatus (statuses are implementation specific)
*/
@Override
public SkuAvailability lookupSKUAvailabilityForLocation(Long skuId, Long locationId, boolean realTime) {
List skuIds = new ArrayList();
skuIds.add(skuId);
List skuAvailbilityList = availabilityDao.readSKUAvailabilityForLocation(skuIds, locationId, realTime);
if (skuAvailbilityList != null && skuAvailbilityList.size() >=1) {
return skuAvailbilityList.get(0);
}
return null;
}
/**
* Returns the availability status for this passed in skuId. Implementations may choose
* to cache the status based upon the passed in realTime indicator.
*
* @param skuId
* @param realTime
* @return String indicating the availabilityStatus (statuses are implementation specific)
*/
@Override
public List lookupSKUAvailability(List skuIds, boolean realTime) {
return availabilityDao.readSKUAvailability(skuIds, realTime);
}
/**
* Returns the availability status for a specific skuId and location. Implementations may choose
* to cache the status based upon the passed in realTime indicator.
*
* @param skuId
* @param locationId
* @param realTime
* @return String indicating the availabilityStatus (statuses are implementation specific)
*/
@Override
public List lookupSKUAvailabilityForLocation(List skuIds, Long locationId, boolean realTime) {
if (CollectionUtils.isEmpty(skuIds)) {
return new ArrayList();
}
return availabilityDao.readSKUAvailabilityForLocation(skuIds, locationId, realTime);
}
@Override
@Transactional(TransactionUtils.DEFAULT_TRANSACTION_MANAGER)
public void save(SkuAvailability skuAvailability) {
availabilityDao.save(skuAvailability);
}
}