/** * 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.document.library.web.internal.messaging; import com.liferay.document.library.configuration.DLConfiguration; import com.liferay.portal.configuration.metatype.bnd.util.ConfigurableUtil; import com.liferay.portal.kernel.dao.orm.ActionableDynamicQuery; import com.liferay.portal.kernel.exception.PortalException; import com.liferay.portal.kernel.log.Log; import com.liferay.portal.kernel.log.LogFactoryUtil; import com.liferay.portal.kernel.messaging.BaseMessageListener; import com.liferay.portal.kernel.messaging.DestinationNames; import com.liferay.portal.kernel.messaging.Message; import com.liferay.portal.kernel.model.Repository; import com.liferay.portal.kernel.module.framework.ModuleServiceLifecycle; import com.liferay.portal.kernel.repository.LocalRepository; import com.liferay.portal.kernel.repository.RepositoryProvider; import com.liferay.portal.kernel.repository.UndeployedExternalRepositoryException; import com.liferay.portal.kernel.repository.capabilities.TemporaryFileEntriesCapability; import com.liferay.portal.kernel.scheduler.SchedulerEngineHelper; import com.liferay.portal.kernel.scheduler.SchedulerEntry; import com.liferay.portal.kernel.scheduler.SchedulerEntryImpl; import com.liferay.portal.kernel.scheduler.TimeUnit; import com.liferay.portal.kernel.scheduler.Trigger; import com.liferay.portal.kernel.scheduler.TriggerFactory; import com.liferay.portal.kernel.service.RepositoryLocalService; import java.util.Map; import org.osgi.service.component.annotations.Activate; import org.osgi.service.component.annotations.Component; import org.osgi.service.component.annotations.Deactivate; import org.osgi.service.component.annotations.Modified; import org.osgi.service.component.annotations.Reference; /** * @author Iván Zaera */ @Component( configurationPid = "com.liferay.document.library.configuration.DLConfiguration", immediate = true, service = TempFileEntriesMessageListener.class ) public class TempFileEntriesMessageListener extends BaseMessageListener { @Activate @Modified protected void activate(Map<String, Object> properties) { _dlConfiguration = ConfigurableUtil.createConfigurable( DLConfiguration.class, properties); Class<?> clazz = getClass(); String className = clazz.getName(); Trigger trigger = _triggerFactory.createTrigger( className, className, null, null, _dlConfiguration.temporaryFileEntriesCheckInterval(), TimeUnit.HOUR); SchedulerEntry schedulerEntry = new SchedulerEntryImpl( className, trigger); _schedulerEngineHelper.register( this, schedulerEntry, DestinationNames.SCHEDULER_DISPATCH); } @Deactivate protected void deactivate() { _schedulerEngineHelper.unregister(this); } protected void deleteExpiredTemporaryFileEntries(Repository repository) { LocalRepository localRepository = null; try { localRepository = _repositoryProvider.getLocalRepository( repository.getRepositoryId()); } catch (PortalException | UndeployedExternalRepositoryException e) { if (_log.isWarnEnabled()) { _log.warn( "Unable to get implementation for repository " + repository.getRepositoryId(), e); } return; } try { if (localRepository.isCapabilityProvided( TemporaryFileEntriesCapability.class)) { TemporaryFileEntriesCapability temporaryFileEntriesCapability = localRepository.getCapability( TemporaryFileEntriesCapability.class); temporaryFileEntriesCapability. deleteExpiredTemporaryFileEntries(); } } catch (Exception pe) { if (_log.isWarnEnabled()) { _log.warn( "Unable to delete expired temporary file entries in " + "repository " + repository.getRepositoryId(), pe); } } } @Override protected void doReceive(Message message) throws Exception { ActionableDynamicQuery actionableDynamicQuery = _repositoryLocalService.getActionableDynamicQuery(); actionableDynamicQuery.setPerformActionMethod( new ActionableDynamicQuery.PerformActionMethod<Repository>() { @Override public void performAction(Repository repository) { deleteExpiredTemporaryFileEntries(repository); } }); actionableDynamicQuery.performActions(); } @Reference(target = ModuleServiceLifecycle.PORTAL_INITIALIZED, unbind = "-") protected void setModuleServiceLifecycle( ModuleServiceLifecycle moduleServiceLifecycle) { } @Reference(unbind = "-") protected void setRepositoryLocalService( RepositoryLocalService repositoryLocalService) { _repositoryLocalService = repositoryLocalService; } @Reference(unbind = "-") protected void setRepositoryProvider( RepositoryProvider repositoryProvider) { _repositoryProvider = repositoryProvider; } @Reference(unbind = "-") protected void setSchedulerEngineHelper( SchedulerEngineHelper schedulerEngineHelper) { _schedulerEngineHelper = schedulerEngineHelper; } @Reference(unbind = "-") protected void setTriggerFactory(TriggerFactory triggerFactory) { } private static final Log _log = LogFactoryUtil.getLog( TempFileEntriesMessageListener.class); private volatile DLConfiguration _dlConfiguration; private RepositoryLocalService _repositoryLocalService; private RepositoryProvider _repositoryProvider; private SchedulerEngineHelper _schedulerEngineHelper; @Reference private TriggerFactory _triggerFactory; }