ElasticsearchService 1.0.3

dotnet add package ElasticsearchService --version 1.0.3                
NuGet\Install-Package ElasticsearchService -Version 1.0.3                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="ElasticsearchService" Version="1.0.3" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ElasticsearchService --version 1.0.3                
#r "nuget: ElasticsearchService, 1.0.3"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install ElasticsearchService as a Cake Addin
#addin nuget:?package=ElasticsearchService&version=1.0.3

// Install ElasticsearchService as a Cake Tool
#tool nuget:?package=ElasticsearchService&version=1.0.3                

Documentation for ElasticsearchService NuGet Package (Version 1.0.2)

Overview

The ElasticsearchService class provides a simple and flexible way to interact with Elasticsearch in your .NET applications. It includes methods for indexing, searching, updating, and deleting documents.

Installation

To install the ElasticsearchService package, run the following command in the Package Manager Console:

Install-Package ElasticsearchService -Version 1.0.2

Usage

  1. Initialize the Service

First, you need to create an instance of ElasticsearchService. This requires an instance of IElasticClient and the name of the index you want to work with.

using atikapps;

var settings = new ConnectionSettings(new Uri("http://localhost:9200")) .DefaultIndex("your-index-name");

var client = new ElasticClient(settings);

var elasticsearchService = new ElasticsearchService(client, "your-index- name");

  1. Creating an Index (If Not Already Exists)

You can create an index if it doesn’t already exist by calling the CreateIndexIfNotExists method.

await elasticsearchService.CreateIndexIfNotExists("your-index-name");

  1. Indexing Documents

Index a Single Document

You can add or update a single document using the AddOrUpdate method.

var document = new { Id = Guid.NewGuid(), Name = "Sample Document" }; await elasticsearchService.AddOrUpdate(document, document.Id);

Index Multiple Documents

To index a bulk of documents, use the AddOrUpdateBulk method.

var documents = new List<object>

{

new { Id = Guid.NewGuid(), Name = "Document 1" }, new { Id = Guid.NewGuid(), Name = "Document 2" } };

await elasticsearchService.AddOrUpdateBulk(documents);

  1. Retrieving Documents

Get a Single Document by Key

Retrieve a document by its key using the Get method.

var document = await elasticsearchService.Get<object>("document-key");

Get All Documents

To retrieve all documents in the current index, use the GetAll method.

var documents = await elasticsearchService.GetAll<object>();

  1. Querying Documents

You can perform custom queries using the Query method. Pass a QueryContainer to define the query.

var predicate = new TermQuery { Field = "fieldName", Value = "value" }; var results = await elasticsearchService.Query<object>(predicate);

  1. Deleting Documents

Delete a Single Document by Key

You can remove a document using its key with the Remove method.

bool success = await elasticsearchService.Remove<object>("document-key");

Delete All Documents

To delete all documents in the current index, use the RemoveAll method.

long deletedCount = await elasticsearchService.RemoveAll<object>();

Delete Documents by Text Match

You can delete documents that match specific text in a field using RemoveByTextMatch.

long deletedCount = await elasticsearchService.RemoveByTextMatch<object>("fieldName", "text");

Method Summary

  • Index(string indexName): Sets the index name and returns the ElasticsearchService instance for method chaining.
  • SetIndex(string indexName): Sets the index name without returning the service instance.
  • CreateIndexIfNotExists(string indexName): Creates an index if it does not already exist.
  • AddOrUpdateBulk<T>(IEnumerable<T> documents): Adds or updates a bulk of documents in the current index.
  • AddOrUpdate<T>(T document, Guid id): Adds or updates a single document in the current index.
  • Get<T>(string key): Retrieves a single document by its key from the current index.
  • GetAll<T>(): Retrieves all documents from the current index.
  • Query<T>(QueryContainer predicate): Queries documents based on a custom predicate.
  • Remove<T>(string key): Removes a single document by its key from the current index.
  • RemoveAll<T>(): Removes all documents from the current index.
  • RemoveByTextMatch<T>(string fieldName, string text): Removes documents that match a specific text in a specific field.

Example

Here is a complete example of using the ElasticsearchService:

using atikapps;

var settings = new ConnectionSettings(new Uri("http://localhost:9200")) .DefaultIndex("your-index-name");

var client = new ElasticClient(settings);

var elasticsearchService = new ElasticsearchService(client, "your-index- name");

// Ensure index exists

await elasticsearchService.CreateIndexIfNotExists("your-index-name");

// Index a document

var document = new { Id = Guid.NewGuid(), Name = "Sample Document" }; await elasticsearchService.AddOrUpdate(document, document.Id);

// Retrieve the document

var retrievedDocument = await elasticsearchService.Get<object>(document.Id.ToString());

// Query documents

var predicate = new TermQuery { Field = "Name", Value = "Sample Document" }; var results = await elasticsearchService.Query<object>(predicate);

// Delete the document

await elasticsearchService.Remove<object>(document.Id.ToString());

This documentation should help you get started with the ElasticsearchService package. For any issues or further details, refer to the source code or contact the package author.

Product 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net8.0

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.3 138 8/26/2024
1.0.2 76 8/26/2024
1.0.1 72 8/26/2024
1.0.0 73 8/26/2024