blob: bb608973e4c5c14316a22be0183c0e2652d2dc87 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.nutch.publisher;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.conf.Configured;
import org.apache.nutch.plugin.PluginRepository;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.lang.invoke.MethodHandles;
public class NutchPublishers extends Configured implements NutchPublisher{
private static final Logger LOG = LoggerFactory
.getLogger(MethodHandles.lookup().lookupClass());
private NutchPublisher[] publishers;
private Configuration conf;
public NutchPublishers(Configuration conf) {
this.conf = conf;
this.publishers = (NutchPublisher[])PluginRepository.get(conf).
getOrderedPlugins(NutchPublisher.class,
NutchPublisher.X_POINT_ID, "publisher.order");
}
@Override
public boolean setConfig(Configuration conf) {
boolean success = false;
try {
for(int i=0; i<this.publishers.length; i++) {
success |= this.publishers[i].setConfig(conf);
if(success)
LOG.info("Successfully loaded {} publisher",
this.publishers[i].getClass().getName());
}
}catch(Exception e) {
LOG.warn("Error while loading publishers : {}", e.getMessage());
}
if(!success) {
LOG.warn("Could not load any publishers out of {} publishers",
this.publishers.length);
}
return success;
}
@Override
public void publish(Object event, Configuration conf) {
for(int i=0; i<this.publishers.length; i++) {
try{
this.publishers[i].publish(event, conf);
}catch(Exception e){
LOG.warn("Could not post event to {}",
this.publishers[i].getClass().getName());
}
}
}
@Override
public Configuration getConf() {
return conf;
}
@Override
public void setConf(Configuration arg0) {
}
}