org.graylog2.indexer.IndexFailureServiceImpl 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.indexer;
import com.mongodb.BasicDBObject;
import com.mongodb.BasicDBObjectBuilder;
import com.mongodb.DBCollection;
import com.mongodb.DBObject;
import org.bson.types.ObjectId;
import org.graylog2.database.DbEntity;
import org.graylog2.database.MongoConnection;
import org.graylog2.database.PersistedServiceImpl;
import org.joda.time.DateTime;
import javax.inject.Inject;
import javax.inject.Singleton;
import java.util.ArrayList;
import java.util.List;
@Singleton
public class IndexFailureServiceImpl extends PersistedServiceImpl implements IndexFailureService {
@Inject
public IndexFailureServiceImpl(MongoConnection mongoConnection) {
super(mongoConnection);
// Make sure that the index failures collection is always created capped.
final String collectionName = IndexFailureImpl.class.getAnnotation(DbEntity.class).collection();
if (!mongoConnection.getDatabase().collectionExists(collectionName)) {
final DBObject options = BasicDBObjectBuilder.start()
.add("capped", true)
.add("size", 52428800) // 50MB max size.
.get();
final DBCollection collection = mongoConnection.getDatabase().createCollection(collectionName, options);
collection.createIndex(new BasicDBObject("timestamp", 1));
collection.createIndex(new BasicDBObject("letter_id", 1));
}
}
@Override
public List all(int limit, int offset) {
final DBObject sort = new BasicDBObject("$natural", -1);
final List results = query(IndexFailureImpl.class, new BasicDBObject(), sort, limit, offset);
final List failures = new ArrayList<>(results.size());
for (DBObject o : results) {
failures.add(new IndexFailureImpl((ObjectId) o.get("_id"), o.toMap()));
}
return failures;
}
@Override
public long countSince(DateTime since) {
final BasicDBObject query = new BasicDBObject("timestamp", new BasicDBObject("$gte", since.toDate()));
return count(IndexFailureImpl.class, query);
}
@Override
public long totalCount() {
return collection(IndexFailureImpl.class).count();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy