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    import com.liferay.portal.model.Website;
027    
028    import java.util.List;
029    
030    /**
031     * Provides the remote service interface for Website. Methods of this
032     * service are expected to have security checks based on the propagated JAAS
033     * credentials because this service can be accessed remotely.
034     *
035     * @author Brian Wing Shun Chan
036     * @see WebsiteServiceUtil
037     * @see com.liferay.portal.service.base.WebsiteServiceBaseImpl
038     * @see com.liferay.portal.service.impl.WebsiteServiceImpl
039     * @generated
040     */
041    @AccessControlled
042    @JSONWebService
043    @ProviderType
044    @Transactional(isolation = Isolation.PORTAL, rollbackFor =  {
045            PortalException.class, SystemException.class})
046    public interface WebsiteService extends BaseService {
047            /*
048             * NOTE FOR DEVELOPERS:
049             *
050             * Never modify or reference this interface directly. Always use {@link WebsiteServiceUtil} to access the website remote service. Add custom service methods to {@link com.liferay.portal.service.impl.WebsiteServiceImpl} and rerun ServiceBuilder to automatically copy the method declarations to this interface.
051             */
052            public Website addWebsite(java.lang.String className, long classPK,
053                    java.lang.String url, long typeId, boolean primary,
054                    com.liferay.portal.service.ServiceContext serviceContext)
055                    throws PortalException;
056    
057            public void deleteWebsite(long websiteId) throws PortalException;
058    
059            /**
060            * Returns the OSGi service identifier.
061            *
062            * @return the OSGi service identifier
063            */
064            public java.lang.String getOSGiServiceIdentifier();
065    
066            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
067            public Website getWebsite(long websiteId) throws PortalException;
068    
069            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
070            public List<Website> getWebsites(java.lang.String className, long classPK)
071                    throws PortalException;
072    
073            public Website updateWebsite(long websiteId, java.lang.String url,
074                    long typeId, boolean primary) throws PortalException;
075    }