001package org.apache.archiva.indexer.merger; 002/* 003 * Licensed to the Apache Software Foundation (ASF) under one 004 * or more contributor license agreements. See the NOTICE file 005 * distributed with this work for additional information 006 * regarding copyright ownership. The ASF licenses this file 007 * to you under the Apache License, Version 2.0 (the 008 * "License"); you may not use this file except in compliance 009 * with the License. You may obtain a copy of the License at 010 * 011 * http://www.apache.org/licenses/LICENSE-2.0 012 * 013 * Unless required by applicable law or agreed to in writing, 014 * software distributed under the License is distributed on an 015 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 016 * KIND, either express or implied. See the License for the 017 * specific language governing permissions and limitations 018 * under the License. 019 */ 020 021import org.apache.archiva.common.plexusbridge.PlexusSisuBridge; 022import org.apache.archiva.common.plexusbridge.PlexusSisuBridgeException; 023import org.apache.maven.index.NexusIndexer; 024import org.slf4j.Logger; 025import org.slf4j.LoggerFactory; 026import org.springframework.scheduling.annotation.Scheduled; 027import org.springframework.stereotype.Service; 028 029import javax.inject.Inject; 030import java.util.Date; 031 032/** 033 * @author Olivier Lamy 034 * @since 1.4-M2 035 */ 036@Service 037public class TemporaryGroupIndexCleaner 038{ 039 private Logger log = LoggerFactory.getLogger( getClass() ); 040 041 @Inject 042 private IndexMerger indexMerger; 043 044 private NexusIndexer indexer; 045 046 @Inject 047 public TemporaryGroupIndexCleaner( PlexusSisuBridge plexusSisuBridge ) 048 throws PlexusSisuBridgeException 049 { 050 indexer = plexusSisuBridge.lookup( NexusIndexer.class ); 051 } 052 053 // 900000 054 @Scheduled(fixedDelay = 900000) 055 public void cleanTemporaryIndex() 056 { 057 058 for ( TemporaryGroupIndex temporaryGroupIndex : indexMerger.getTemporaryGroupIndexes() ) 059 { 060 // cleanup files older than the ttl 061 if ( new Date().getTime() - temporaryGroupIndex.getCreationTime() > temporaryGroupIndex.getMergedIndexTtl() ) 062 { 063 log.info( "cleanTemporaryIndex for groupId {}", temporaryGroupIndex.getGroupId() ); 064 indexMerger.cleanTemporaryGroupIndex( temporaryGroupIndex ); 065 066 } 067 } 068 } 069}