All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.graylog2.streams.StreamRuleServiceImpl Maven / Gradle / Ivy

/*
 * Copyright (C) 2020 Graylog, Inc.
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the Server Side Public License, version 1,
 * as published by MongoDB, Inc.
 *
 * This program 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
 * Server Side Public License for more details.
 *
 * You should have received a copy of the Server Side Public License
 * along with this program. If not, see
 * .
 */
package org.graylog2.streams;

import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet;
import com.google.common.collect.Maps;
import com.mongodb.BasicDBObject;
import com.mongodb.DBCursor;
import com.mongodb.DBObject;
import org.bson.types.ObjectId;
import org.graylog2.database.MongoConnection;
import org.graylog2.database.NotFoundException;
import org.graylog2.database.PersistedServiceImpl;
import org.graylog2.events.ClusterEventBus;
import org.graylog2.plugin.database.ValidationException;
import org.graylog2.plugin.streams.Stream;
import org.graylog2.plugin.streams.StreamRule;
import org.graylog2.rest.resources.streams.rules.requests.CreateStreamRuleRequest;
import org.graylog2.streams.events.StreamsChangedEvent;

import javax.annotation.Nullable;
import javax.inject.Inject;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;

public class StreamRuleServiceImpl extends PersistedServiceImpl implements StreamRuleService {
    private final ClusterEventBus clusterEventBus;

    @Inject
    public StreamRuleServiceImpl(MongoConnection mongoConnection,
                                 ClusterEventBus clusterEventBus) {
        super(mongoConnection);
        collection(StreamRuleImpl.class).createIndex(StreamRuleImpl.FIELD_STREAM_ID);
        this.clusterEventBus = clusterEventBus;
    }

    @Override
    public StreamRule load(String id) throws NotFoundException {
        BasicDBObject o = (BasicDBObject) get(StreamRuleImpl.class, new ObjectId(id));

        if (o == null) {
            throw new NotFoundException("Couldn't find stream rule with ID" + id);
        }

        return new StreamRuleImpl((ObjectId) o.get("_id"), o.toMap());
    }

    @Override
    public List loadForStream(Stream stream) {
        return loadForStreamId(stream.getId());
    }

    @Override
    public StreamRule create(Map data) {
        return new StreamRuleImpl(data);
    }

    @Override
    public StreamRule create(@Nullable String streamId, CreateStreamRuleRequest cr) {
        Map streamRuleData = Maps.newHashMap();
        streamRuleData.put(StreamRuleImpl.FIELD_TYPE, cr.type());
        streamRuleData.put(StreamRuleImpl.FIELD_VALUE, cr.value());
        streamRuleData.put(StreamRuleImpl.FIELD_FIELD, cr.field());
        streamRuleData.put(StreamRuleImpl.FIELD_INVERTED, cr.inverted());
        streamRuleData.put(StreamRuleImpl.FIELD_DESCRIPTION, cr.description());

        if (streamId != null) {
            streamRuleData.put(StreamRuleImpl.FIELD_STREAM_ID, new ObjectId(streamId));
        }

        return new StreamRuleImpl(streamRuleData);
    }

    @Override
    public StreamRule copy(@Nullable String streamId, StreamRule streamRule) {
        Map streamRuleData = Maps.newHashMap();
        streamRuleData.put(StreamRuleImpl.FIELD_TYPE, streamRule.getType().toInteger());
        streamRuleData.put(StreamRuleImpl.FIELD_VALUE, streamRule.getValue());
        streamRuleData.put(StreamRuleImpl.FIELD_FIELD, streamRule.getField());
        streamRuleData.put(StreamRuleImpl.FIELD_INVERTED, streamRule.getInverted());
        streamRuleData.put(StreamRuleImpl.FIELD_DESCRIPTION, streamRule.getDescription());

        if (streamId != null) {
            streamRuleData.put(StreamRuleImpl.FIELD_STREAM_ID, new ObjectId(streamId));
        }

        return new StreamRuleImpl(streamRuleData);
    }

    @Override
    public String save(StreamRule streamRule) throws ValidationException {
        final String streamId = streamRule.getStreamId();
        final String savedStreamRuleId = super.save(streamRule);
        clusterEventBus.post(StreamsChangedEvent.create(streamId));

        return savedStreamRuleId;
    }

    @Override
    public Set save(Collection streamRules) throws ValidationException {
        final ImmutableSet.Builder streamIds = ImmutableSet.builder();
        final ImmutableSet.Builder streamRuleIds = ImmutableSet.builder();
        for (StreamRule streamRule : streamRules) {
            final String streamId = streamRule.getStreamId();
            final String savedStreamRuleId = super.save(streamRule);
            streamIds.add(streamId);
            streamRuleIds.add(savedStreamRuleId);
        }
        clusterEventBus.post(StreamsChangedEvent.create(streamIds.build()));

        return streamRuleIds.build();
    }

    @Override
    public int destroy(StreamRule streamRule) {
        final String streamId = streamRule.getStreamId();
        final int deletedStreamRules = super.destroy(streamRule);
        clusterEventBus.post(StreamsChangedEvent.create(streamId));

        return deletedStreamRules;
    }

    @Override
    public List loadForStreamId(String streamId) {
        ObjectId id = new ObjectId(streamId);
        final List streamRules = new ArrayList<>();
        final List respStreamRules = query(StreamRuleImpl.class,
                new BasicDBObject(StreamRuleImpl.FIELD_STREAM_ID, id)
        );

        for (DBObject streamRule : respStreamRules) {
            streamRules.add(toStreamRule(streamRule));
        }

        return streamRules;
    }

    @Override
    public Map> loadForStreamIds(Collection streamIds) {
        final List objectIds = streamIds.stream()
            .map(ObjectId::new)
            .collect(Collectors.toList());

        final List respStreamRules = query(StreamRuleImpl.class,
            new BasicDBObject(StreamRuleImpl.FIELD_STREAM_ID, new BasicDBObject("$in", objectIds))
        );

        return respStreamRules.stream()
            .map(this::toStreamRule)
            .collect(Collectors.groupingBy(StreamRule::getStreamId));
    }

    @Override
    public long totalStreamRuleCount() {
        return totalCount(StreamRuleImpl.class);
    }

    @Override
    public long streamRuleCount(String streamId) {
        return streamRuleCount(new ObjectId(streamId));
    }

    private long streamRuleCount(ObjectId streamId) {
        return count(StreamRuleImpl.class, new BasicDBObject(StreamRuleImpl.FIELD_STREAM_ID, streamId));
    }

    @Override
    public Map streamRuleCountByStream() {
        final ImmutableMap.Builder streamRules = ImmutableMap.builder();
        try(DBCursor streamIds = collection(StreamImpl.class).find(new BasicDBObject(), new BasicDBObject("_id", 1))) {
            for (DBObject keys : streamIds) {
                final ObjectId streamId = (ObjectId) keys.get("_id");
                streamRules.put(streamId.toHexString(), streamRuleCount(streamId));
            }
        }

        return streamRules.build();
    }

    @SuppressWarnings("unchecked")
    private StreamRule toStreamRule(DBObject dbObject) {
        final Map fields = dbObject.toMap();
        return new StreamRuleImpl((ObjectId) dbObject.get("_id"), fields);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy