You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
69 lines
2.3 KiB
69 lines
2.3 KiB
/**
|
|
* yacyChannel
|
|
* Copyright 2010 by Michael Peter Christen
|
|
* First released 29.6.2010 at https://yacy.net
|
|
*
|
|
* $LastChangedDate$
|
|
* $LastChangedRevision$
|
|
* $LastChangedBy$
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with this program in the file lgpl21.txt
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
package net.yacy.peers;
|
|
|
|
import java.util.EnumSet;
|
|
import java.util.Set;
|
|
import java.util.concurrent.ConcurrentHashMap;
|
|
import java.util.concurrent.ConcurrentMap;
|
|
|
|
import net.yacy.cora.document.feed.RSSFeed;
|
|
import net.yacy.cora.document.feed.RSSMessage;
|
|
|
|
public enum EventChannel {
|
|
TEST,
|
|
PEERNEWS,
|
|
REMOTESEARCH,
|
|
LOCALSEARCH,
|
|
REMOTEINDEXING,
|
|
LOCALINDEXING,
|
|
DHTRECEIVE,
|
|
DHTSEND,
|
|
PROXY;
|
|
|
|
|
|
// test:
|
|
// http://localhost:8090/xml/feed.rss?set=PEERNEWS,REMOTESEARCH,LOCALSEARCH,REMOTEINDEXING,LOCALINDEXING
|
|
|
|
/**
|
|
* the following private channels are declared to prevent that an access to the feed servlet
|
|
* gets results from news channels that are not for the public
|
|
*/
|
|
public static final Set<EventChannel> privateChannels = EnumSet.of(EventChannel.LOCALSEARCH, EventChannel.LOCALINDEXING, EventChannel.PROXY);
|
|
|
|
/**
|
|
* the following static channels object is used to organize a storage array for RSS feeds
|
|
*/
|
|
private static final ConcurrentMap<EventChannel, RSSFeed> channels = new ConcurrentHashMap<EventChannel, RSSFeed>();
|
|
|
|
public static RSSFeed channels(final EventChannel channel) {
|
|
RSSFeed feed = channels.get(channel);
|
|
if (feed != null) return feed;
|
|
feed = new RSSFeed(200);
|
|
feed.setChannel(new RSSMessage(channel.name(), "", ""));
|
|
channels.put(channel, feed);
|
|
return feed;
|
|
}
|
|
} |