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    
027    /**
028     * Provides the remote service interface for Repository. Methods of this
029     * service are expected to have security checks based on the propagated JAAS
030     * credentials because this service can be accessed remotely.
031     *
032     * @author Brian Wing Shun Chan
033     * @see RepositoryServiceUtil
034     * @see com.liferay.portal.service.base.RepositoryServiceBaseImpl
035     * @see com.liferay.portal.service.impl.RepositoryServiceImpl
036     * @generated
037     */
038    @AccessControlled
039    @JSONWebService
040    @ProviderType
041    @Transactional(isolation = Isolation.PORTAL, rollbackFor =  {
042            PortalException.class, SystemException.class})
043    public interface RepositoryService extends BaseService {
044            /*
045             * NOTE FOR DEVELOPERS:
046             *
047             * Never modify or reference this interface directly. Always use {@link RepositoryServiceUtil} to access the repository remote service. Add custom service methods to {@link com.liferay.portal.service.impl.RepositoryServiceImpl} and rerun ServiceBuilder to automatically copy the method declarations to this interface.
048             */
049            public com.liferay.portal.model.Repository addRepository(long groupId,
050                    long classNameId, long parentFolderId, java.lang.String name,
051                    java.lang.String description, java.lang.String portletId,
052                    com.liferay.portal.kernel.util.UnicodeProperties typeSettingsProperties,
053                    com.liferay.portal.service.ServiceContext serviceContext)
054                    throws PortalException;
055    
056            public void checkRepository(long repositoryId) throws PortalException;
057    
058            public void deleteRepository(long repositoryId) throws PortalException;
059    
060            /**
061            * Returns the Spring bean ID for this bean.
062            *
063            * @return the Spring bean ID for this bean
064            */
065            public java.lang.String getBeanIdentifier();
066    
067            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
068            public com.liferay.portal.model.Repository getRepository(long repositoryId)
069                    throws PortalException;
070    
071            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
072            public java.lang.String[] getSupportedConfigurations(long classNameId);
073    
074            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
075            public java.lang.String[] getSupportedParameters(
076                    java.lang.String className, java.lang.String configuration);
077    
078            /**
079            * @deprecated As of 7.0.0, replaced by {@link
080            #getSupportedParameters(String, String)}
081            */
082            @java.lang.Deprecated
083            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
084            public java.lang.String[] getSupportedParameters(long classNameId,
085                    java.lang.String configuration);
086    
087            @Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
088            public com.liferay.portal.kernel.util.UnicodeProperties getTypeSettingsProperties(
089                    long repositoryId) throws PortalException;
090    
091            /**
092            * Sets the Spring bean ID for this bean.
093            *
094            * @param beanIdentifier the Spring bean ID for this bean
095            */
096            public void setBeanIdentifier(java.lang.String beanIdentifier);
097    
098            public void updateRepository(long repositoryId, java.lang.String name,
099                    java.lang.String description) throws PortalException;
100    }