com.mongodb.async.client.gridfs.GridFSIndexCheckImpl Maven / Gradle / Ivy
/*
* Copyright 2015 MongoDB, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.mongodb.async.client.gridfs;
import com.mongodb.async.SingleResultCallback;
import com.mongodb.async.client.MongoCollection;
import com.mongodb.client.gridfs.model.GridFSFile;
import com.mongodb.client.model.IndexOptions;
import org.bson.Document;
import java.util.ArrayList;
import static com.mongodb.ReadPreference.primary;
import static com.mongodb.assertions.Assertions.notNull;
final class GridFSIndexCheckImpl implements GridFSIndexCheck {
private static final Document PROJECTION = new Document("_id", 1);
private final MongoCollection filesCollection;
private final MongoCollection chunksCollection;
GridFSIndexCheckImpl(final MongoCollection filesCollection, final MongoCollection chunksCollection) {
this.filesCollection = notNull("files collection", filesCollection);
this.chunksCollection = notNull("chunks collection", chunksCollection);
}
@Override
public void checkAndCreateIndex(final SingleResultCallback callback) {
filesCollection.withDocumentClass(Document.class).withReadPreference(primary()).find().projection(PROJECTION).first(
new SingleResultCallback() {
@Override
public void onResult(final Document result, final Throwable t) {
if (t != null) {
callback.onResult(null, t);
} else if (result == null) {
checkFilesIndex(callback);
} else {
callback.onResult(null, null);
}
}
});
}
private void hasIndex(final MongoCollection collection, final Document index, final SingleResultCallback callback) {
collection.listIndexes().into(new ArrayList(), new SingleResultCallback>() {
@Override
public void onResult(final ArrayList indexes, final Throwable t) {
if (t != null) {
callback.onResult(null, t);
} else {
boolean hasIndex = false;
for (Document indexDoc : indexes) {
if (indexDoc.get("key", Document.class).equals(index)) {
hasIndex = true;
break;
}
}
callback.onResult(hasIndex, null);
}
}
});
}
private void checkFilesIndex(final SingleResultCallback callback) {
final Document filesIndex = new Document("filename", 1).append("uploadDate", 1);
hasIndex(filesCollection.withReadPreference(primary()), filesIndex,
new SingleResultCallback() {
@Override
public void onResult(final Boolean result, final Throwable t) {
if (t != null) {
callback.onResult(null, t);
} else if (!result) {
filesCollection.createIndex(filesIndex, new SingleResultCallback() {
@Override
public void onResult(final String result, final Throwable t) {
if (t != null) {
callback.onResult(null, t);
} else {
checkChunksIndex(callback);
}
}
});
} else {
checkChunksIndex(callback);
}
}
});
}
private void checkChunksIndex(final SingleResultCallback callback) {
final Document chunksIndex = new Document("files_id", 1).append("n", 1);
hasIndex(chunksCollection.withReadPreference(primary()), chunksIndex, new SingleResultCallback() {
@Override
public void onResult(final Boolean result, final Throwable t) {
if (t != null) {
callback.onResult(null, t);
} else if (!result) {
chunksCollection.createIndex(chunksIndex, new IndexOptions().unique(true), new SingleResultCallback() {
@Override
public void onResult(final String result, final Throwable t) {
if (t != null) {
callback.onResult(null, t);
} else {
callback.onResult(null, null);
}
}
});
} else {
callback.onResult(null, null);
}
}
});
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy