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

org.graylog.events.notifications.DBNotificationGracePeriodService Maven / Gradle / Ivy

There is a newer version: 6.0.2
Show newest version
/*
 * 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.graylog.events.notifications;

import org.bson.types.ObjectId;
import org.graylog.events.event.EventDto;
import org.graylog.scheduler.clock.JobSchedulerClock;
import org.graylog2.bindings.providers.MongoJackObjectMapperProvider;
import org.graylog2.database.MongoConnection;
import org.graylog2.database.NotFoundException;
import org.graylog2.database.PaginatedDbService;
import org.joda.time.DateTime;
import org.mongojack.DBCursor;
import org.mongojack.DBQuery;

import javax.inject.Inject;
import java.util.ArrayList;
import java.util.List;
import java.util.Optional;

public class DBNotificationGracePeriodService extends PaginatedDbService {
    private static final String NOTIFICATION_STATUS_COLLECTION_NAME = "event_notification_status";

    private JobSchedulerClock clock;

    @Inject
    public DBNotificationGracePeriodService(MongoConnection mongoConnection,
                                            MongoJackObjectMapperProvider mapper,
                                            JobSchedulerClock clock) {
        super(mongoConnection, mapper, EventNotificationStatus.class, NOTIFICATION_STATUS_COLLECTION_NAME);
        this.clock = clock;

    }

    public boolean inGracePeriod(EventDto event, String notificationId, long grace) throws NotFoundException {
        EventNotificationStatus status = getNotificationStatus(notificationId, event.eventDefinitionId(), event.key()).orElseThrow(NotFoundException::new);
        Optional lastNotification = status.notifiedAt();

        return lastNotification.map(dateTime -> dateTime.isAfter(event.eventTimestamp().minus(grace))).orElse(false);
    }

    public List getAllStatuses() {
        List result = new ArrayList<>();
        try (DBCursor eventNotificationStatuses = db.find()) {
            for (EventNotificationStatus status : eventNotificationStatuses) {
                result.add(status);
            }
        }
        return result;
    }

    public int deleteStatus(String statusId) {
        final ObjectId id = new ObjectId(statusId);
        return db.removeById(id).getN();
    }

    private Optional getNotificationStatus(String notificationId, String definitionId, String key) {
        if (notificationId == null || definitionId == null || key == null) {
            return Optional.empty();
        }
        return Optional.ofNullable(db.findOne(DBQuery.and(
                DBQuery.is(EventNotificationStatus.FIELD_NOTIFICATION_ID, notificationId),
                DBQuery.is(EventNotificationStatus.FIELD_EVENT_DEFINITION_ID, definitionId),
                DBQuery.is(EventNotificationStatus.FIELD_EVENT_KEY, key))));
    }

    public void updateTriggerStatus(String notificationId, EventDto eventDto, long grace) {
        updateStatus(eventDto, notificationId, "triggered", grace);
    }

    public void updateNotifiedStatus(String notificationId, EventDto eventDto, long grace) {
        updateStatus(eventDto, notificationId, "notified", grace);
    }

    private void updateStatus(EventDto eventDto, String notificationId, String type, long grace) {
        EventNotificationStatus.Builder statusBuilder;
        Optional optionalStatus = getNotificationStatus(notificationId, eventDto.eventDefinitionId(), eventDto.key());
        if (optionalStatus.isPresent()) {
            statusBuilder = optionalStatus.get().toBuilder();
        } else {
            statusBuilder = EventNotificationStatus.Builder.create();
        }

        switch (type) {
            case "triggered":
                statusBuilder.triggeredAt(Optional.of(clock.nowUTC()));
                break;
            case "notified":
                statusBuilder.notifiedAt(Optional.of(eventDto.eventTimestamp()));
                break;
        }

        EventNotificationStatus status = statusBuilder
                .notificationId(notificationId)
                .eventKey(eventDto.key())
                .gracePeriodMs(grace)
                .eventDefinitionId(eventDto.eventDefinitionId())
                .build();

        db.save(status);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy