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.transaction.Isolation;
022    import com.liferay.portal.kernel.transaction.Propagation;
023    import com.liferay.portal.kernel.transaction.Transactional;
024    
025    /**
026     * Provides the local service interface for Theme. Methods of this
027     * service will not have security checks based on the propagated JAAS
028     * credentials because this service can only be accessed from within the same
029     * VM.
030     *
031     * @author Brian Wing Shun Chan
032     * @see ThemeLocalServiceUtil
033     * @see com.liferay.portal.service.base.ThemeLocalServiceBaseImpl
034     * @see com.liferay.portal.service.impl.ThemeLocalServiceImpl
035     * @generated
036     */
037    @ProviderType
038    @Transactional(isolation = Isolation.PORTAL, rollbackFor =  {
039            PortalException.class, SystemException.class})
040    public interface ThemeLocalService extends BaseLocalService {
041            /*
042             * NOTE FOR DEVELOPERS:
043             *
044             * Never modify or reference this interface directly. Always use {@link ThemeLocalServiceUtil} to access the theme local service. Add custom service methods to {@link com.liferay.portal.service.impl.ThemeLocalServiceImpl} and rerun ServiceBuilder to automatically copy the method declarations to this interface.
045             */
046            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
047            public com.liferay.portal.model.ColorScheme fetchColorScheme(
048                    long companyId, java.lang.String themeId, java.lang.String colorSchemeId);
049    
050            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
051            public com.liferay.portal.model.Theme fetchTheme(long companyId,
052                    java.lang.String themeId);
053    
054            /**
055            * Returns the Spring bean ID for this bean.
056            *
057            * @return the Spring bean ID for this bean
058            */
059            public java.lang.String getBeanIdentifier();
060    
061            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
062            public com.liferay.portal.model.ColorScheme getColorScheme(long companyId,
063                    java.lang.String themeId, java.lang.String colorSchemeId,
064                    boolean wapTheme);
065    
066            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
067            public java.util.List<com.liferay.portal.model.Theme> getControlPanelThemes(
068                    long companyId, long userId, boolean wapTheme);
069    
070            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
071            public java.util.List<com.liferay.portal.model.Theme> getPageThemes(
072                    long companyId, long groupId, long userId, boolean wapTheme);
073    
074            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
075            public com.liferay.portal.model.Theme getTheme(long companyId,
076                    java.lang.String themeId, boolean wapTheme);
077    
078            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
079            public java.util.List<com.liferay.portal.model.Theme> getThemes(
080                    long companyId);
081    
082            /**
083            * @deprecated As of 7.0.0, replaced by {@link #getPageThemes}
084            */
085            @java.lang.Deprecated
086            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
087            public java.util.List<com.liferay.portal.model.Theme> getThemes(
088                    long companyId, long groupId, long userId, boolean wapTheme);
089    
090            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
091            public java.util.List<com.liferay.portal.model.Theme> getWARThemes();
092    
093            public java.util.List<com.liferay.portal.model.Theme> init(
094                    javax.servlet.ServletContext servletContext,
095                    java.lang.String themesPath, boolean loadFromServletContext,
096                    java.lang.String[] xmls,
097                    com.liferay.portal.kernel.plugin.PluginPackage pluginPackage);
098    
099            public java.util.List<com.liferay.portal.model.Theme> init(
100                    java.lang.String servletContextName,
101                    javax.servlet.ServletContext servletContext,
102                    java.lang.String themesPath, boolean loadFromServletContext,
103                    java.lang.String[] xmls,
104                    com.liferay.portal.kernel.plugin.PluginPackage pluginPackage);
105    
106            /**
107            * Sets the Spring bean ID for this bean.
108            *
109            * @param beanIdentifier the Spring bean ID for this bean
110            */
111            public void setBeanIdentifier(java.lang.String beanIdentifier);
112    
113            public void uninstallThemes(
114                    java.util.List<com.liferay.portal.model.Theme> themes);
115    }