Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/monstar-lab/elasticsearch-service
๐ Elasticsearch integration for your Vapor apps.
https://github.com/monstar-lab/elasticsearch-service
elasticsearch swift swift-4 vapor vapor-3
Last synced: 3 months ago
JSON representation
๐ Elasticsearch integration for your Vapor apps.
- Host: GitHub
- URL: https://github.com/monstar-lab/elasticsearch-service
- Owner: monstar-lab
- License: mit
- Created: 2018-05-24T02:15:35.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-06-08T01:01:40.000Z (over 6 years ago)
- Last Synced: 2024-09-30T00:22:12.709Z (3 months ago)
- Topics: elasticsearch, swift, swift-4, vapor, vapor-3
- Language: Swift
- Homepage:
- Size: 33.2 KB
- Stars: 10
- Watchers: 14
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Elasticsearch Service for Vapor
![Swift](https://img.shields.io/badge/swift-4.1-brightgreen.svg)
![Vapor](https://img.shields.io/badge/vapor-3.0-brightgreen.svg)This library allows you to connect to a Elasticsearch server from your Vapor application, perform searches and get back `Codable`/`Content` results. Currently only searching is supported, not indices nor data manipulation.
## Setup
Add Elasticsearch Service to your `Package.swift` file:
```swift
.package(url: "https://github.com/monstar-lab/elasticsearch-service.git", from: "0.9.0")
```Register the configuration object and the provider inside your `configure.swift` file:
```swift
let elasticURL = URL(string: "http://localhost:9200")if let elasticURL = elasticURL {
let elasticConfig = ElasticsearchConfig(serverURL: elasticURL)
services.register(elasticConfig)try services.register(ElasticsearchProvider())
}
```## Using the service
After importing `ElasticsearchService` and obtaining instance of `ElasticsearchClient` from your container, you can send your search request (either wrapped in `QueryContainer`, or a simple `[AnyHashable: Any]` in case of complicated queries) and receive search results (again either as custom `Codable` structure, or as an `[AnyHashable: Any]`).
`QueryContainer` and `struct`s that conform to the `Query` protocol allow you to model your queries in a type-safe, Swift-y way. However, not the entirety of Elasticsearchโs query language has been converted, only the most commonly used queries. In case a query you require is missing, feel free to submit a pull request.
```swift
func getSearchHandler(_ req: Request) throws -> Future<[Product]> {
let elasticClient = try req.make(ElasticsearchClient.self)
let query = QueryContainer(
Query(
Fuzzy(key: "name", value: "bolster", transpositions: true)
)
)return try elasticClient
.search(index: "product", query, decodeTo: Product.self)
.map(to: [Product].self) { result in
return result.hits.hits.map { $0.source }
}
}
```For more examples, please feel free to look into the test suite or comments.
## Known issues
- [ ] `BoolQuery`โs usefulness is significantly hampered by the fact that only one type of queries can be passed as an argument, for example if you pass type `[MatchPhrase]` as an `must` argument, other arguments (`filter`, `mustNot`, etc.) must also be of type `[MatchPhrase]`. If you know how to solve this (type erasure?), a pull request is most appreciated!
- [ ] Indices manipulation is not supported.
- [ ] Data manipulation is not supported.
- [ ] Aggregation is not supported.