Skip to content

Kotlin/Java library for copying indexes from one MongoDB collection to another.

License

Notifications You must be signed in to change notification settings

pitagoras3/mongo-index-copy

Repository files navigation

mongo-index-copy

Kotlin/Java library for copying MongoDB collection indexes programmatically from one collection to another.

Installation (Gradle)

implementation("io.github.pitagoras3:mongo-index-copy:1.0.0")

In case when you already have MongoDB Java Driver on your classpath, you can get mongo-index-copy without transitive MongoDB Java driver dependency by excluding it:

implementation("io.github.pitagoras3:mongo-index-copy:1.0.0") {
  exclude("org.mongodb")
}

How to use it?

You have two options to copy indexes from one MongoDB collection to another with mongo-index-copy:

  1. You can use MongoIndexCopy.copyAllIndexes method to copy all indexes from source collection to destination collection,
  2. You can use MongoIndexCopy.copyIndexes method to copy only specified (by index name) indexes from source collection to destination collection.

How it works?

mongo-index-copy reads all indexes from source collection using listIndexes method from MongoDB Java driver. All indexes are Document objects - here are a few examples:

Document{{v=2, key=Document{{x=hashed}}, name=x_hashed}}
Document{{v=2, key=Document{{item=1}}, name=item_1, expireAfterSeconds=100}}
Document{{v=2, key=Document{{item=1}}, name=item_1, partialFilterExpression=Document{{rating=Document{{$gt=5}}}}}}

Having list of indexes as Document objects, mongo-index-copy maps them to IndexModel objects, and creates indexes on destination collection using createIndexes method from MongoDB Java driver.

How to build it and test it locally?

Build:

./gradlew build

Run unit tests:

./gradlew test

Run integration tests:

./gradlew integrationTest

Run all tests (unit + integration):

./gradlew check

License

mongo-index-copy is licensed under Apache License 2.0.

Copyright 2023 Szymon Marcinkiewicz

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.

About

Kotlin/Java library for copying indexes from one MongoDB collection to another.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages