/**
* 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;
}