]> source.dussan.org Git - archiva.git/blob
d95bfda0ee743ee7d1dc29d801c8c73a837dda52
[archiva.git] /
1 package org.apache.maven.archiva.consumers;
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.codehaus.plexus.PlexusConstants;
23 import org.codehaus.plexus.PlexusContainer;
24 import org.codehaus.plexus.context.Context;
25 import org.codehaus.plexus.context.ContextException;
26 import org.codehaus.plexus.logging.AbstractLogEnabled;
27 import org.codehaus.plexus.personality.plexus.lifecycle.phase.Contextualizable;
28
29 /**
30  * DiscovererConsumerFactory - factory for consumers.
31  *
32  * @author <a href="mailto:joakim@erdfelt.com">Joakim Erdfelt</a>
33  * @version $Id$
34  * @plexus.component role="org.apache.maven.archiva.common.consumers.ConsumerFactory"
35  */
36 public class ConsumerFactory
37     extends AbstractLogEnabled
38     implements Contextualizable
39 {
40     public static final String ROLE = ConsumerFactory.class.getName();
41
42     private PlexusContainer container;
43
44     public Consumer createConsumer( String name )
45         throws ConsumerException
46     {
47         getLogger().info( "Attempting to create consumer [" + name + "]" );
48
49         Consumer consumer;
50         try
51         {
52             consumer = (Consumer) container.lookup( Consumer.ROLE, name, container.getLookupRealm() );
53         }
54         catch ( Throwable t )
55         {
56             String emsg = "Unable to create consumer [" + name + "]: " + t.getMessage();
57             getLogger().warn( t.getMessage(), t );
58             throw new ConsumerException( null, emsg, t );
59         }
60
61         getLogger().info( "Created consumer [" + name + "|" + consumer.getName() + "]" );
62         return consumer;
63     }
64
65     public void contextualize( Context context )
66         throws ContextException
67     {
68         container = (PlexusContainer) context.get( PlexusConstants.PLEXUS_KEY );
69     }
70 }