/** * 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.LayoutSet; import com.liferay.portal.kernel.security.access.control.AccessControlled; import com.liferay.portal.kernel.transaction.Isolation; import com.liferay.portal.kernel.transaction.Transactional; import java.io.File; import java.io.InputStream; /** * Provides the remote service interface for LayoutSet. 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 LayoutSetServiceUtil * @see com.liferay.portal.service.base.LayoutSetServiceBaseImpl * @see com.liferay.portal.service.impl.LayoutSetServiceImpl * @generated */ @AccessControlled @JSONWebService @ProviderType @Transactional(isolation = Isolation.PORTAL, rollbackFor = { PortalException.class, SystemException.class}) public interface LayoutSetService extends BaseService { /* * NOTE FOR DEVELOPERS: * * Never modify or reference this interface directly. Always use {@link LayoutSetServiceUtil} to access the layout set remote service. Add custom service methods to {@link com.liferay.portal.service.impl.LayoutSetServiceImpl} and rerun ServiceBuilder to automatically copy the method declarations to this interface. */ public LayoutSet updateLookAndFeel(long groupId, boolean privateLayout, java.lang.String themeId, java.lang.String colorSchemeId, java.lang.String css) throws PortalException; public LayoutSet updateSettings(long groupId, boolean privateLayout, java.lang.String settings) throws PortalException; public LayoutSet updateVirtualHost(long groupId, boolean privateLayout, java.lang.String virtualHost) throws PortalException; /** * Returns the OSGi service identifier. * * @return the OSGi service identifier */ public java.lang.String getOSGiServiceIdentifier(); /** * Updates the state of the layout set prototype link. * * <p> * <strong>Important:</strong> Setting * <code>layoutSetPrototypeLinkEnabled</code> to <code>true</code> and * <code>layoutSetPrototypeUuid</code> to <code>null</code> when the layout * set prototype's current uuid is <code>null</code> will result in an * <code>IllegalStateException</code>. * </p> * * @param groupId the primary key of the group * @param privateLayout whether the layout set is private to the group * @param layoutSetPrototypeLinkEnabled whether the layout set prototype is link enabled * @param layoutSetPrototypeUuid the uuid of the layout set prototype to link with */ public void updateLayoutSetPrototypeLinkEnabled(long groupId, boolean privateLayout, boolean layoutSetPrototypeLinkEnabled, java.lang.String layoutSetPrototypeUuid) throws PortalException; public void updateLogo(long groupId, boolean privateLayout, boolean logo, byte[] bytes) throws PortalException; public void updateLogo(long groupId, boolean privateLayout, boolean logo, File file) throws PortalException; public void updateLogo(long groupId, boolean privateLayout, boolean logo, InputStream inputStream) throws PortalException; public void updateLogo(long groupId, boolean privateLayout, boolean logo, InputStream inputStream, boolean cleanUpStream) throws PortalException; }