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

io.hawt.log.support.LogQueryBase Maven / Gradle / Ivy

There is a newer version: 4.2.0
Show newest version
package io.hawt.log.support;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.Set;

import io.hawt.log.LogEvent;
import io.hawt.log.LogFilter;

import static io.hawt.log.support.Objects.contains;

public abstract class LogQueryBase extends LogQuerySupport {

    protected Predicate createPredicate(LogFilter filter) {
        if (filter == null) {
            return null;
        }
        List> predicates = new ArrayList<>();

        Set levels = filter.getLevelsSet();
        if (levels.size() > 0) {
            predicates.add(e -> e.getLevel() != null && levels.contains(e.getLevel()));
        }
        Long before = filter.getBeforeTimestamp();
        if (before != null) {
            Date date = new Date(before);
            predicates.add(e -> e.getTimestamp() != null && e.getTimestamp().before(date));
        }
        Long after = filter.getAfterTimestamp();
        if (after != null) {
            Date date = new Date(after);
            predicates.add(e -> e.getTimestamp() != null && e.getTimestamp().after(date));
        }

        String matchesText = filter.getMatchesText();
        if (matchesText != null && matchesText.length() > 0) {
            predicates.add(e -> matches(e, matchesText));
        }

        if (predicates.isEmpty()) {
            return null;
        } else if (predicates.size() == 1) {
            return predicates.get(0);
        } else {
            return new Predicate() {
                @Override
                public String toString() {
                    return "AndPredicate" + predicates;
                }

                @Override
                public boolean matches(LogEvent event) {
                    return predicates.stream().allMatch(p -> p.matches(event));
                }
            };
        }
    }

    private boolean matches(LogEvent event, String text) {
        if (contains(text, event.getClassName(), event.getMessage(), event.getLogger(), event.getThread())) {
            return true;
        }
        String[] throwableStrRep = event.getException();
        if (throwableStrRep != null && contains(text, throwableStrRep)) {
            return true;
        }
        Map properties = event.getProperties();
        return properties != null && contains(text, properties.toString());
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy