EasyMongoNet 1.0.1
dotnet add package EasyMongoNet --version 1.0.1
NuGet\Install-Package EasyMongoNet -Version 1.0.1
<PackageReference Include="EasyMongoNet" Version="1.0.1" />
paket add EasyMongoNet --version 1.0.1
#r "nuget: EasyMongoNet, 1.0.1"
// Install EasyMongoNet as a Cake Addin #addin nuget:?package=EasyMongoNet&version=1.0.1 // Install EasyMongoNet as a Cake Tool #tool nuget:?package=EasyMongoNet&version=1.0.1
📦 RepoMongoNet - A MongoDb Repository for .NET
A generic repository with complete implementations for MongoDB using .NET.
✨ Description
This package provides a complete implementation of a generic repository for .NET applications with MongoDB, simplifying Create, Read, Update, and Delete (CRUD) operations for entities in the database.
With it, you can streamline data access using best practices, abstracting the repository layer and making your application cleaner and more decoupled.
🚀 Installation
You can install the package via NuGet Package Manager or the CLI:
Using NuGet Package Manager: <pre> Install-Package RepoMongoNet </pre>
🛠️ Configuration
Create a class called MongoDbSettings.cs:
appsettings.json:
```json
{
"MongoDbSettings": {
"ConnectionString": "mongodb://userdb:password@localhost:27017/?authMechanism=SCRAM-SHA-256",
"DatabaseName": "MyStore"
}
}
In your Program.cs:
using YourNamespace;
var builder = WebApplication.CreateBuilder(args);
// Configure MongoDB options
builder.Services.AddMongoRepoNet(builder.Configuration!);
var app = builder.Build();
🎯 Usage
Creating an Entity
Define an entity in your project:
public class Product
{
public int Id { get; set; }
public string Name { get; set; }
public decimal Price { get; set; }
}
Using the Repository
Example of using the generic repository in a Controller:
public class ProductsController : ControllerBase
{
private readonly IMongoRepository<Product> _repository;
public ProductsController(IMongoRepository<Product> repository)
{
_repository = repository;
}
[HttpPost]
public async Task<IActionResult> Create(Product product)
{
await _repository.InsertAsync(product);
return Ok("Product successfully created!");
}
[HttpGet]
public async Task<IActionResult> GetAll()
{
var products = await _repository.GetAllAsync();
return Ok(products);
}
}
⚙️ Features
Full CRUD:
- InsertAsync(TEntity obj) - Adds a new entity.
- GetById(string field, Guid id) - Retrieves an entity by ID.
- GetAllAsync(int page = 1, int pageSize = 10, string sort = "asc") - Retrieves all entities with pagination.
- UpdateAsync(string field, TEntity obj, string collectionName) - Updates an existing entity.
- Delete(string field, Guid id, string collectionName) - Removes an entity by ID.
- And much more..
Performance:
Efficient use of MongoDB database connections.
Generic:
Can be used with any entity class that has an identifier.
🧩 Requirements
- .NET 6+
- MongoDB.Driver 2.29.0+
🗂️ Package Structure
Interfaces:
IMongoRepository<T>: Generic repository interface.
Implementations:
MongoRepository<T>: Concrete implementation.
🤝 Contribution
Contributions are welcome!
- Fork the repository.
- Create a branch for your feature (git checkout -b feature/NewFeature).
- Commit your changes (git commit -m "Added a new feature X").
- Push to the branch (git push origin feature/NewFeature).
- Open a Pull Request.
⭐ Give it a Star!
If you find this package useful, don't forget to give it a ⭐ on GitHub!
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net8.0
- Microsoft.Extensions.Configuration.Abstractions (>= 9.0.1)
- Microsoft.Extensions.Configuration.Binder (>= 8.0.2)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.1)
- Microsoft.Extensions.Options (>= 9.0.1)
- MongoDB.Bson (>= 3.1.0)
- MongoDB.Driver (>= 3.1.0)
- MongoDB.Driver.Core (>= 2.30.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.