/**
* Copyright (c) 2000-present Liferay, Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation; either version 2.1 of the License, or (at your option)
* any later version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
* details.
*/
package com.liferay.portal.kernel.service;
import aQute.bnd.annotation.ProviderType;
import com.liferay.portal.kernel.exception.PortalException;
import com.liferay.portal.kernel.exception.SystemException;
import com.liferay.portal.kernel.jsonwebservice.JSONWebService;
import com.liferay.portal.kernel.model.Region;
import com.liferay.portal.kernel.security.access.control.AccessControlled;
import com.liferay.portal.kernel.transaction.Isolation;
import com.liferay.portal.kernel.transaction.Propagation;
import com.liferay.portal.kernel.transaction.Transactional;
import java.util.List;
/**
* Provides the remote service interface for Region. Methods of this
* service are expected to have security checks based on the propagated JAAS
* credentials because this service can be accessed remotely.
*
* @author Brian Wing Shun Chan
* @see RegionServiceUtil
* @see com.liferay.portal.service.base.RegionServiceBaseImpl
* @see com.liferay.portal.service.impl.RegionServiceImpl
* @generated
*/
@AccessControlled
@JSONWebService
@ProviderType
@Transactional(isolation = Isolation.PORTAL, rollbackFor = {
PortalException.class, SystemException.class})
public interface RegionService extends BaseService {
/*
* NOTE FOR DEVELOPERS:
*
* Never modify or reference this interface directly. Always use {@link RegionServiceUtil} to access the region remote service. Add custom service methods to {@link com.liferay.portal.service.impl.RegionServiceImpl} and rerun ServiceBuilder to automatically copy the method declarations to this interface.
*/
public Region addRegion(long countryId, java.lang.String regionCode,
java.lang.String name, boolean active) throws PortalException;
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public Region fetchRegion(long countryId, java.lang.String regionCode);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public Region fetchRegion(long regionId);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public Region getRegion(long countryId, java.lang.String regionCode)
throws PortalException;
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public Region getRegion(long regionId) throws PortalException;
/**
* Returns the OSGi service identifier.
*
* @return the OSGi service identifier
*/
public java.lang.String getOSGiServiceIdentifier();
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List<Region> getRegions();
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List<Region> getRegions(boolean active);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List<Region> getRegions(long countryId);
@AccessControlled(guestAccessEnabled = true)
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List<Region> getRegions(long countryId, boolean active);
}