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 EmailAddress. 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 EmailAddressServiceUtil
034     * @see com.liferay.portal.service.base.EmailAddressServiceBaseImpl
035     * @see com.liferay.portal.service.impl.EmailAddressServiceImpl
036     * @generated
037     */
038    @AccessControlled
039    @JSONWebService
040    @ProviderType
041    @Transactional(isolation = Isolation.PORTAL, rollbackFor =  {
042            PortalException.class, SystemException.class})
043    public interface EmailAddressService extends BaseService {
044            /*
045             * NOTE FOR DEVELOPERS:
046             *
047             * Never modify or reference this interface directly. Always use {@link EmailAddressServiceUtil} to access the email address remote service. Add custom service methods to {@link com.liferay.portal.service.impl.EmailAddressServiceImpl} and rerun ServiceBuilder to automatically copy the method declarations to this interface.
048             */
049    
050            /**
051            * @deprecated As of 6.2.0, replaced by {@link #addEmailAddress(String,
052            long, String, int, boolean, ServiceContext)}
053            */
054            @java.lang.Deprecated
055            public com.liferay.portal.model.EmailAddress addEmailAddress(
056                    java.lang.String className, long classPK, java.lang.String address,
057                    long typeId, boolean primary) throws PortalException;
058    
059            public com.liferay.portal.model.EmailAddress addEmailAddress(
060                    java.lang.String className, long classPK, java.lang.String address,
061                    long typeId, boolean primary,
062                    com.liferay.portal.service.ServiceContext serviceContext)
063                    throws PortalException;
064    
065            public void deleteEmailAddress(long emailAddressId)
066                    throws PortalException;
067    
068            /**
069            * Returns the email address with the primary key.
070            *
071            * @param emailAddressId the primary key of the email address
072            * @return the email address with the primary key, or <code>null</code> if
073            an email address with the primary key could not be found or if
074            the user did not have permission to view the email address
075            * @throws PortalException if a portal exception occurred
076            */
077            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
078            public com.liferay.portal.model.EmailAddress fetchEmailAddress(
079                    long emailAddressId) throws PortalException;
080    
081            /**
082            * Returns the Spring bean ID for this bean.
083            *
084            * @return the Spring bean ID for this bean
085            */
086            public java.lang.String getBeanIdentifier();
087    
088            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
089            public com.liferay.portal.model.EmailAddress getEmailAddress(
090                    long emailAddressId) throws PortalException;
091    
092            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
093            public java.util.List<com.liferay.portal.model.EmailAddress> getEmailAddresses(
094                    java.lang.String className, long classPK) throws PortalException;
095    
096            /**
097            * Sets the Spring bean ID for this bean.
098            *
099            * @param beanIdentifier the Spring bean ID for this bean
100            */
101            public void setBeanIdentifier(java.lang.String beanIdentifier);
102    
103            public com.liferay.portal.model.EmailAddress updateEmailAddress(
104                    long emailAddressId, java.lang.String address, long typeId,
105                    boolean primary) throws PortalException;
106    }