001    /**
002     * Copyright (c) 2000-present Liferay, Inc. All rights reserved.
003     *
004     * This library is free software; you can redistribute it and/or modify it under
005     * the terms of the GNU Lesser General Public License as published by the Free
006     * Software Foundation; either version 2.1 of the License, or (at your option)
007     * any later version.
008     *
009     * This library is distributed in the hope that it will be useful, but WITHOUT
010     * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
011     * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
012     * details.
013     */
014    
015    package com.liferay.portal.service;
016    
017    import aQute.bnd.annotation.ProviderType;
018    
019    import com.liferay.portal.kernel.exception.PortalException;
020    import com.liferay.portal.kernel.exception.SystemException;
021    import com.liferay.portal.kernel.jsonwebservice.JSONWebService;
022    import com.liferay.portal.kernel.security.access.control.AccessControlled;
023    import com.liferay.portal.kernel.transaction.Isolation;
024    import com.liferay.portal.kernel.transaction.Propagation;
025    import com.liferay.portal.kernel.transaction.Transactional;
026    
027    /**
028     * Provides the remote service interface for Address. Methods of this
029     * service are expected to have security checks based on the propagated JAAS
030     * credentials because this service can be accessed remotely.
031     *
032     * @author Brian Wing Shun Chan
033     * @see AddressServiceUtil
034     * @see com.liferay.portal.service.base.AddressServiceBaseImpl
035     * @see com.liferay.portal.service.impl.AddressServiceImpl
036     * @generated
037     */
038    @AccessControlled
039    @JSONWebService
040    @ProviderType
041    @Transactional(isolation = Isolation.PORTAL, rollbackFor =  {
042            PortalException.class, SystemException.class})
043    public interface AddressService extends BaseService {
044            /*
045             * NOTE FOR DEVELOPERS:
046             *
047             * Never modify or reference this interface directly. Always use {@link AddressServiceUtil} to access the address remote service. Add custom service methods to {@link com.liferay.portal.service.impl.AddressServiceImpl} and rerun ServiceBuilder to automatically copy the method declarations to this interface.
048             */
049            public com.liferay.portal.model.Address addAddress(
050                    java.lang.String className, long classPK, java.lang.String street1,
051                    java.lang.String street2, java.lang.String street3,
052                    java.lang.String city, java.lang.String zip, long regionId,
053                    long countryId, long typeId, boolean mailing, boolean primary,
054                    com.liferay.portal.service.ServiceContext serviceContext)
055                    throws PortalException;
056    
057            public void deleteAddress(long addressId) throws PortalException;
058    
059            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
060            public com.liferay.portal.model.Address getAddress(long addressId)
061                    throws PortalException;
062    
063            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
064            public java.util.List<com.liferay.portal.model.Address> getAddresses(
065                    java.lang.String className, long classPK) throws PortalException;
066    
067            /**
068            * Returns the OSGi service identifier.
069            *
070            * @return the OSGi service identifier
071            */
072            public java.lang.String getOSGiServiceIdentifier();
073    
074            public com.liferay.portal.model.Address updateAddress(long addressId,
075                    java.lang.String street1, java.lang.String street2,
076                    java.lang.String street3, java.lang.String city, java.lang.String zip,
077                    long regionId, long countryId, long typeId, boolean mailing,
078                    boolean primary) throws PortalException;
079    }