/** * 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.EmailAddress; 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 EmailAddress. 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 EmailAddressServiceUtil * @see com.liferay.portal.service.base.EmailAddressServiceBaseImpl * @see com.liferay.portal.service.impl.EmailAddressServiceImpl * @generated */ @AccessControlled @JSONWebService @ProviderType @Transactional(isolation = Isolation.PORTAL, rollbackFor = { PortalException.class, SystemException.class}) public interface EmailAddressService extends BaseService { /* * NOTE FOR DEVELOPERS: * * 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. */ public EmailAddress addEmailAddress(java.lang.String className, long classPK, java.lang.String address, long typeId, boolean primary, ServiceContext serviceContext) throws PortalException; /** * Returns the email address with the primary key. * * @param emailAddressId the primary key of the email address * @return the email address with the primary key, or <code>null</code> if an email address with the primary key could not be found or if the user did not have permission to view the email address */ @Transactional(propagation = Propagation.SUPPORTS, readOnly = true) public EmailAddress fetchEmailAddress(long emailAddressId) throws PortalException; @Transactional(propagation = Propagation.SUPPORTS, readOnly = true) public EmailAddress getEmailAddress(long emailAddressId) throws PortalException; public EmailAddress updateEmailAddress(long emailAddressId, java.lang.String address, long typeId, boolean primary) 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<EmailAddress> getEmailAddresses(java.lang.String className, long classPK) throws PortalException; public void deleteEmailAddress(long emailAddressId) throws PortalException; }