]> source.dussan.org Git - archiva.git/blob
0845db6b1afc9aa8f461509672f19363069a72b2
[archiva.git] /
1 package org.apache.archiva.indexer.merger;
2 /*
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  */
20
21 import org.apache.archiva.common.plexusbridge.PlexusSisuBridge;
22 import org.apache.archiva.common.plexusbridge.PlexusSisuBridgeException;
23 import org.apache.maven.index.NexusIndexer;
24 import org.apache.maven.index.context.IndexingContext;
25 import org.slf4j.Logger;
26 import org.slf4j.LoggerFactory;
27 import org.springframework.scheduling.annotation.Scheduled;
28 import org.springframework.stereotype.Service;
29
30 import javax.inject.Inject;
31 import java.io.IOException;
32 import java.util.Date;
33
34 /**
35  * @author Olivier Lamy
36  * @since 1.4-M2
37  */
38 @Service
39 public class TemporaryGroupIndexCleaner
40 {
41     private Logger log = LoggerFactory.getLogger( getClass() );
42
43     @Inject
44     private IndexMerger indexMerger;
45
46     private NexusIndexer indexer;
47
48     @Inject
49     public TemporaryGroupIndexCleaner( PlexusSisuBridge plexusSisuBridge )
50         throws PlexusSisuBridgeException
51     {
52         indexer = plexusSisuBridge.lookup( NexusIndexer.class );
53     }
54
55     // 900000
56     @Scheduled( fixedDelay = 900000 )
57     public void cleanTemporaryIndex()
58     {
59         for ( TemporaryGroupIndex temporaryGroupIndex : indexMerger.getTemporaryGroupIndexes() )
60         {
61             // cleanup files older than 60 minutes 3600000
62             if ( new Date().getTime() - temporaryGroupIndex.getCreationTime() > 3600000 )
63             {
64                 try
65                 {
66                     IndexingContext context = indexer.getIndexingContexts().get( temporaryGroupIndex.getIndexId() );
67                     if ( context != null )
68                     {
69                         indexer.removeIndexingContext( context, true );
70                     }
71                     else
72                     {
73                         indexMerger.cleanTemporaryGroupIndex( temporaryGroupIndex );
74                     }
75                     indexMerger.getTemporaryGroupIndexes().remove( temporaryGroupIndex );
76                     log.debug( "remove directory {}", temporaryGroupIndex.getDirectory() );
77                 }
78                 catch ( IOException e )
79                 {
80                     log.warn( "failed to remove directory:" + temporaryGroupIndex.getDirectory(), e );
81                 }
82             }
83         }
84     }
85 }