]> source.dussan.org Git - archiva.git/blob
fe420105674487beb3c0a3198d1ceb2cd6977b64
[archiva.git] /
1 package org.apache.archiva.reports;
2
3 /*
4  * Licensed to the Apache Software Foundation (ASF) under one
5  * or more contributor license agreements.  See the NOTICE file
6  * distributed with this work for additional information
7  * regarding copyright ownership.  The ASF licenses this file
8  * to you under the Apache License, Version 2.0 (the
9  * "License"); you may not use this file except in compliance
10  * with the License.  You may obtain a copy of the License at
11  *
12  *   http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing,
15  * software distributed under the License is distributed on an
16  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17  * KIND, either express or implied.  See the License for the
18  * specific language governing permissions and limitations
19  * under the License.
20  */
21
22 import org.apache.archiva.metadata.repository.MetadataRepository;
23 import org.apache.archiva.metadata.repository.MetadataRepositoryException;
24 import org.apache.archiva.repository.events.RepositoryListener;
25 import org.slf4j.Logger;
26 import org.slf4j.LoggerFactory;
27
28 /**
29  * Process repository management events and respond appropriately.
30  *
31  * @plexus.component role="org.apache.archiva.repository.events.RepositoryListener" role-hint="problem-reports"
32  */
33 public class RepositoryProblemEventListener
34     implements RepositoryListener
35 {
36     private Logger log = LoggerFactory.getLogger( RepositoryProblemEventListener.class );
37
38     /**
39      * @plexus.requirement
40      */
41     private MetadataRepository metadataRepository;
42
43     public void deleteArtifact( String repositoryId, String namespace, String project, String version, String id )
44     {
45         String name = RepositoryProblemFacet.createName( namespace, project, version, id );
46
47         try
48         {
49             metadataRepository.removeMetadataFacet( repositoryId, RepositoryProblemFacet.FACET_ID, name );
50         }
51         catch ( MetadataRepositoryException e )
52         {
53             log.warn( "Unable to remove metadata facet as part of delete event: " + e.getMessage(), e );
54         }
55     }
56 }