com.liferay.fragment.service.FragmentCompositionLocalService Maven / Gradle / Ivy
/**
* SPDX-FileCopyrightText: (c) 2000 Liferay, Inc. https://liferay.com
* SPDX-License-Identifier: LGPL-2.1-or-later OR LicenseRef-Liferay-DXP-EULA-2.0.0-2023-06
*/
package com.liferay.fragment.service;
import com.liferay.exportimport.kernel.lar.PortletDataContext;
import com.liferay.fragment.model.FragmentComposition;
import com.liferay.petra.function.UnsafeFunction;
import com.liferay.petra.sql.dsl.query.DSLQuery;
import com.liferay.portal.kernel.change.tracking.CTAware;
import com.liferay.portal.kernel.dao.orm.ActionableDynamicQuery;
import com.liferay.portal.kernel.dao.orm.DynamicQuery;
import com.liferay.portal.kernel.dao.orm.ExportActionableDynamicQuery;
import com.liferay.portal.kernel.dao.orm.IndexableActionableDynamicQuery;
import com.liferay.portal.kernel.dao.orm.Projection;
import com.liferay.portal.kernel.exception.PortalException;
import com.liferay.portal.kernel.exception.SystemException;
import com.liferay.portal.kernel.model.PersistedModel;
import com.liferay.portal.kernel.model.SystemEventConstants;
import com.liferay.portal.kernel.search.Indexable;
import com.liferay.portal.kernel.search.IndexableType;
import com.liferay.portal.kernel.service.BaseLocalService;
import com.liferay.portal.kernel.service.PersistedModelLocalService;
import com.liferay.portal.kernel.service.ServiceContext;
import com.liferay.portal.kernel.service.change.tracking.CTService;
import com.liferay.portal.kernel.service.persistence.change.tracking.CTPersistence;
import com.liferay.portal.kernel.systemevent.SystemEvent;
import com.liferay.portal.kernel.transaction.Isolation;
import com.liferay.portal.kernel.transaction.Propagation;
import com.liferay.portal.kernel.transaction.Transactional;
import com.liferay.portal.kernel.util.OrderByComparator;
import java.io.Serializable;
import java.util.List;
import org.osgi.annotation.versioning.ProviderType;
/**
* Provides the local service interface for FragmentComposition. Methods of this
* service will not have security checks based on the propagated JAAS
* credentials because this service can only be accessed from within the same
* VM.
*
* @author Brian Wing Shun Chan
* @see FragmentCompositionLocalServiceUtil
* @generated
*/
@CTAware
@ProviderType
@Transactional(
isolation = Isolation.PORTAL,
rollbackFor = {PortalException.class, SystemException.class}
)
public interface FragmentCompositionLocalService
extends BaseLocalService, CTService,
PersistedModelLocalService {
/*
* NOTE FOR DEVELOPERS:
*
* Never modify this interface directly. Add custom service methods to com.liferay.fragment.service.impl.FragmentCompositionLocalServiceImpl
and rerun ServiceBuilder to automatically copy the method declarations to this interface. Consume the fragment composition local service via injection or a org.osgi.util.tracker.ServiceTracker
. Use {@link FragmentCompositionLocalServiceUtil} if injection and service tracking are not available.
*/
/**
* Adds the fragment composition to the database. Also notifies the appropriate model listeners.
*
*
* Important: Inspect FragmentCompositionLocalServiceImpl for overloaded versions of the method. If provided, use these entry points to the API, as the implementation logic may require the additional parameters defined there.
*
*
* @param fragmentComposition the fragment composition
* @return the fragment composition that was added
*/
@Indexable(type = IndexableType.REINDEX)
public FragmentComposition addFragmentComposition(
FragmentComposition fragmentComposition);
public FragmentComposition addFragmentComposition(
String externalReferenceCode, long userId, long groupId,
long fragmentCollectionId, String fragmentCompositionKey,
String name, String description, String data,
long previewFileEntryId, int status, ServiceContext serviceContext)
throws PortalException;
/**
* Creates a new fragment composition with the primary key. Does not add the fragment composition to the database.
*
* @param fragmentCompositionId the primary key for the new fragment composition
* @return the new fragment composition
*/
@Transactional(enabled = false)
public FragmentComposition createFragmentComposition(
long fragmentCompositionId);
/**
* @throws PortalException
*/
public PersistedModel createPersistedModel(Serializable primaryKeyObj)
throws PortalException;
/**
* Deletes the fragment composition from the database. Also notifies the appropriate model listeners.
*
*
* Important: Inspect FragmentCompositionLocalServiceImpl for overloaded versions of the method. If provided, use these entry points to the API, as the implementation logic may require the additional parameters defined there.
*
*
* @param fragmentComposition the fragment composition
* @return the fragment composition that was removed
* @throws PortalException
*/
@Indexable(type = IndexableType.DELETE)
@SystemEvent(type = SystemEventConstants.TYPE_DELETE)
public FragmentComposition deleteFragmentComposition(
FragmentComposition fragmentComposition)
throws PortalException;
/**
* Deletes the fragment composition with the primary key from the database. Also notifies the appropriate model listeners.
*
*
* Important: Inspect FragmentCompositionLocalServiceImpl for overloaded versions of the method. If provided, use these entry points to the API, as the implementation logic may require the additional parameters defined there.
*
*
* @param fragmentCompositionId the primary key of the fragment composition
* @return the fragment composition that was removed
* @throws PortalException if a fragment composition with the primary key could not be found
*/
@Indexable(type = IndexableType.DELETE)
public FragmentComposition deleteFragmentComposition(
long fragmentCompositionId)
throws PortalException;
public FragmentComposition deleteFragmentComposition(
String externalReferenceCode, long groupId)
throws PortalException;
/**
* @throws PortalException
*/
@Override
public PersistedModel deletePersistedModel(PersistedModel persistedModel)
throws PortalException;
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public T dslQuery(DSLQuery dslQuery);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public int dslQueryCount(DSLQuery dslQuery);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public DynamicQuery dynamicQuery();
/**
* Performs a dynamic query on the database and returns the matching rows.
*
* @param dynamicQuery the dynamic query
* @return the matching rows
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List dynamicQuery(DynamicQuery dynamicQuery);
/**
* Performs a dynamic query on the database and returns a range of the matching rows.
*
*
* Useful when paginating results. Returns a maximum of end - start
instances. start
and end
are not primary keys, they are indexes in the result set. Thus, 0
refers to the first result in the set. Setting both start
and end
to com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS
will return the full result set. If orderByComparator
is specified, then the query will include the given ORDER BY logic. If orderByComparator
is absent, then the query will include the default ORDER BY logic from com.liferay.fragment.model.impl.FragmentCompositionModelImpl
.
*
*
* @param dynamicQuery the dynamic query
* @param start the lower bound of the range of model instances
* @param end the upper bound of the range of model instances (not inclusive)
* @return the range of matching rows
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List dynamicQuery(
DynamicQuery dynamicQuery, int start, int end);
/**
* Performs a dynamic query on the database and returns an ordered range of the matching rows.
*
*
* Useful when paginating results. Returns a maximum of end - start
instances. start
and end
are not primary keys, they are indexes in the result set. Thus, 0
refers to the first result in the set. Setting both start
and end
to com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS
will return the full result set. If orderByComparator
is specified, then the query will include the given ORDER BY logic. If orderByComparator
is absent, then the query will include the default ORDER BY logic from com.liferay.fragment.model.impl.FragmentCompositionModelImpl
.
*
*
* @param dynamicQuery the dynamic query
* @param start the lower bound of the range of model instances
* @param end the upper bound of the range of model instances (not inclusive)
* @param orderByComparator the comparator to order the results by (optionally null
)
* @return the ordered range of matching rows
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List dynamicQuery(
DynamicQuery dynamicQuery, int start, int end,
OrderByComparator orderByComparator);
/**
* Returns the number of rows matching the dynamic query.
*
* @param dynamicQuery the dynamic query
* @return the number of rows matching the dynamic query
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public long dynamicQueryCount(DynamicQuery dynamicQuery);
/**
* Returns the number of rows matching the dynamic query.
*
* @param dynamicQuery the dynamic query
* @param projection the projection to apply to the query
* @return the number of rows matching the dynamic query
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public long dynamicQueryCount(
DynamicQuery dynamicQuery, Projection projection);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public FragmentComposition fetchFragmentComposition(
long fragmentCompositionId);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public FragmentComposition fetchFragmentComposition(
long groupId, String fragmentCompositionKey);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public FragmentComposition fetchFragmentCompositionByExternalReferenceCode(
String externalReferenceCode, long groupId);
/**
* Returns the fragment composition matching the UUID and group.
*
* @param uuid the fragment composition's UUID
* @param groupId the primary key of the group
* @return the matching fragment composition, or null
if a matching fragment composition could not be found
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public FragmentComposition fetchFragmentCompositionByUuidAndGroupId(
String uuid, long groupId);
public String generateFragmentCompositionKey(long groupId, String name);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public ActionableDynamicQuery getActionableDynamicQuery();
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public ExportActionableDynamicQuery getExportActionableDynamicQuery(
PortletDataContext portletDataContext);
/**
* Returns the fragment composition with the primary key.
*
* @param fragmentCompositionId the primary key of the fragment composition
* @return the fragment composition
* @throws PortalException if a fragment composition with the primary key could not be found
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public FragmentComposition getFragmentComposition(
long fragmentCompositionId)
throws PortalException;
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public FragmentComposition getFragmentCompositionByExternalReferenceCode(
String externalReferenceCode, long groupId)
throws PortalException;
/**
* Returns the fragment composition matching the UUID and group.
*
* @param uuid the fragment composition's UUID
* @param groupId the primary key of the group
* @return the matching fragment composition
* @throws PortalException if a matching fragment composition could not be found
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public FragmentComposition getFragmentCompositionByUuidAndGroupId(
String uuid, long groupId)
throws PortalException;
/**
* Returns a range of all the fragment compositions.
*
*
* Useful when paginating results. Returns a maximum of end - start
instances. start
and end
are not primary keys, they are indexes in the result set. Thus, 0
refers to the first result in the set. Setting both start
and end
to com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS
will return the full result set. If orderByComparator
is specified, then the query will include the given ORDER BY logic. If orderByComparator
is absent, then the query will include the default ORDER BY logic from com.liferay.fragment.model.impl.FragmentCompositionModelImpl
.
*
*
* @param start the lower bound of the range of fragment compositions
* @param end the upper bound of the range of fragment compositions (not inclusive)
* @return the range of fragment compositions
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List getFragmentCompositions(
int start, int end);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List getFragmentCompositions(
long fragmentCollectionId);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List getFragmentCompositions(
long fragmentCollectionId, int start, int end);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List getFragmentCompositions(
long groupId, long fragmentCollectionId, int status);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List getFragmentCompositions(
long groupId, long fragmentCollectionId, int start, int end,
OrderByComparator orderByComparator);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List getFragmentCompositions(
long groupId, long fragmentCollectionId, String name, int start,
int end, OrderByComparator orderByComparator);
/**
* Returns all the fragment compositions matching the UUID and company.
*
* @param uuid the UUID of the fragment compositions
* @param companyId the primary key of the company
* @return the matching fragment compositions, or an empty list if no matches were found
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List getFragmentCompositionsByUuidAndCompanyId(
String uuid, long companyId);
/**
* Returns a range of fragment compositions matching the UUID and company.
*
* @param uuid the UUID of the fragment compositions
* @param companyId the primary key of the company
* @param start the lower bound of the range of fragment compositions
* @param end the upper bound of the range of fragment compositions (not inclusive)
* @param orderByComparator the comparator to order the results by (optionally null
)
* @return the range of matching fragment compositions, or an empty list if no matches were found
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List getFragmentCompositionsByUuidAndCompanyId(
String uuid, long companyId, int start, int end,
OrderByComparator orderByComparator);
/**
* Returns the number of fragment compositions.
*
* @return the number of fragment compositions
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public int getFragmentCompositionsCount();
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public int getFragmentCompositionsCount(long fragmentCollectionId);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public IndexableActionableDynamicQuery getIndexableActionableDynamicQuery();
/**
* Returns the OSGi service identifier.
*
* @return the OSGi service identifier
*/
public String getOSGiServiceIdentifier();
/**
* @throws PortalException
*/
@Override
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public PersistedModel getPersistedModel(Serializable primaryKeyObj)
throws PortalException;
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public String[] getTempFileNames(
long userId, long groupId, String folderName)
throws PortalException;
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public String getUniqueFragmentCompositionName(
long groupId, long fragmentCollectionId, String name);
public FragmentComposition moveFragmentComposition(
long fragmentCompositionId, long fragmentCollectionId)
throws PortalException;
/**
* Updates the fragment composition in the database or adds it if it does not yet exist. Also notifies the appropriate model listeners.
*
*
* Important: Inspect FragmentCompositionLocalServiceImpl for overloaded versions of the method. If provided, use these entry points to the API, as the implementation logic may require the additional parameters defined there.
*
*
* @param fragmentComposition the fragment composition
* @return the fragment composition that was updated
*/
@Indexable(type = IndexableType.REINDEX)
public FragmentComposition updateFragmentComposition(
FragmentComposition fragmentComposition);
public FragmentComposition updateFragmentComposition(
long fragmentCompositionId, long previewFileEntryId)
throws PortalException;
public FragmentComposition updateFragmentComposition(
long userId, long fragmentCompositionId, long fragmentCollectionId,
String name, String description, String data,
long previewFileEntryId, int status)
throws PortalException;
public FragmentComposition updateFragmentComposition(
long fragmentCompositionId, String name)
throws PortalException;
@Override
@Transactional(enabled = false)
public CTPersistence getCTPersistence();
@Override
@Transactional(enabled = false)
public Class getModelClass();
@Override
@Transactional(rollbackFor = Throwable.class)
public R updateWithUnsafeFunction(
UnsafeFunction, R, E>
updateUnsafeFunction)
throws E;
}