Skip to content
This repository has been archived by the owner on Jul 18, 2018. It is now read-only.

Commit

Permalink
Merge pull request #1 from cinchcast/master
Browse files Browse the repository at this point in the history
Fixes issue where Boost property of the TermQuery was formatted with a , (comma) instead of a . (dot)
  • Loading branch information
medcl committed Oct 9, 2012
2 parents 5367c00 + 0b2dfdf commit 7ad73cb
Show file tree
Hide file tree
Showing 4 changed files with 205 additions and 124 deletions.
Original file line number Diff line number Diff line change
@@ -1,24 +1,32 @@
using Newtonsoft.Json;
using System;
namespace ElasticSearch.Client.QueryDSL
{
internal class TermFilterConverter : JsonConverter
{
public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
{
TermFilter term = (TermFilter)value;
if (term != null)
writer.WriteRawValue(string.Format("{{term: {{ \"{0}\" : \"{1}\"}} }}", term.Field, term.Value));
}

public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
{
throw new NotImplementedException();
}

public override bool CanConvert(Type objectType)
{
return typeof(TermFilter).IsAssignableFrom(objectType);
}
}
using Newtonsoft.Json;
using System;
namespace ElasticSearch.Client.QueryDSL
{
internal class TermFilterConverter : JsonConverter
{
public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
{
TermFilter term = (TermFilter)value;
if (term != null)
{
writer.WriteStartObject();
writer.WritePropertyName("term");
writer.WriteStartObject();
writer.WritePropertyName(term.Field);
writer.WriteValue(term.Value);
writer.WriteEndObject();
writer.WriteEndObject();
}
}

public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
{
throw new NotImplementedException();
}

public override bool CanConvert(Type objectType)
{
return typeof(TermFilter).IsAssignableFrom(objectType);
}
}
}
75 changes: 51 additions & 24 deletions ElasticSearch.Client/QueryDSL/Converters/Query/TermQueryConvert.cs
Original file line number Diff line number Diff line change
@@ -1,25 +1,52 @@
using System;
using Newtonsoft.Json;

namespace ElasticSearch.Client.QueryDSL
{
internal class TermQueryConverter:JsonConverter
{
public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
{
TermQuery term = (TermQuery)value;
if (term != null)
writer.WriteRawValue(string.Format("{{term: {{ \"{0}\" : {{ \"term\" : \"{1}\", \"boost\":{2} }}}} }}", term.Field, term.Value, term.Boost));
}

public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
{
throw new NotImplementedException();
}

public override bool CanConvert(Type objectType)
{
return typeof(TermQuery).IsAssignableFrom(objectType);
}
}
using System;
using Newtonsoft.Json;

namespace ElasticSearch.Client.QueryDSL
{
internal class TermQueryConverter:JsonConverter
{
public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
{
TermQuery term = (TermQuery)value;
if (term != null)
{
/* Writes the following json
* {
* "term":
* {
* "term.Field":
* {
* "term": "term.Value",
* "boost": term.Boost
* }
* }
* }
*/

writer.WriteStartObject();
writer.WritePropertyName("term");
writer.WriteStartObject();
writer.WritePropertyName(term.Field);
writer.WriteStartObject();
writer.WritePropertyName("term");
writer.WriteValue(term.Value);
writer.WritePropertyName("boost");
writer.WriteValue(term.Boost);
writer.WriteEndObject();
writer.WriteEndObject();
writer.WriteEndObject();
}
//writer.WriteRawValue(string.Format("{{term: {{ \"{0}\" : {{ \"term\" : \"{1}\", \"boost\":{2} }}}} }}", term.Field, term.Value, term.Boost));
}

public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
{
throw new NotImplementedException();
}

public override bool CanConvert(Type objectType)
{
return typeof(TermQuery).IsAssignableFrom(objectType);
}
}
}
95 changes: 65 additions & 30 deletions ElasticSearch.Client/QueryDSL/Query/CustomFiltersScoreQuery.cs
Original file line number Diff line number Diff line change
@@ -1,31 +1,66 @@
using System.Collections.Generic;
using Newtonsoft.Json;

namespace ElasticSearch.Client.QueryDSL
{
/// <summary>
/// A custom_filters_score query allows to execute a query, and if the hit matches a provided filter (ordered), use either a boost or a script associated with it to compute the score
/// </summary>
[JsonConverter(typeof(CustomFiltersScoreQueryConverterer))]
[JsonObject("custom_filters_score")]
public class CustomFiltersScoreQuery:IQuery
{
public IQuery Query;
public List<IFilter> Filters;
/// <summary>
/// A score_mode can be defined to control how multiple matching filters control the score. By default, it is set to first which means the first matching filter will control the score of the result. It can also be set to max/total/avg which will aggregate the result from all matching filters based on the aggregation type.
/// </summary>
public string ScoreMode;

/// <summary>
/// A script can be used instead of boost for more complex score calculations. With optional params and lang (on the same level as query and filters).
/// </summary>
public string Script;

public CustomFiltersScoreQuery(IQuery query,List<IFilter> filters)
{
Query = query;
Filters = filters;
}
}
using System.Collections.Generic;
using Newtonsoft.Json;

namespace ElasticSearch.Client.QueryDSL
{
/// <summary>
/// A custom_filters_score query allows to execute a query, and if the hit matches a provided filter (ordered), use either a boost or a script associated with it to compute the score
/// </summary>
[JsonConverter(typeof(CustomFiltersScoreQueryConverterer))]
[JsonObject("custom_filters_score")]
public class CustomFiltersScoreQuery: IQuery
{
public IQuery Query;
public IDictionary<IFilter, double> Filters = new Dictionary<IFilter, double>();
/// <summary>
/// A score_mode can be defined to control how multiple matching filters control the score. By default, it is set to first which means the first matching filter will control the score of the result. It can also be set to max/total/avg which will aggregate the result from all matching filters based on the aggregation type.
/// </summary>
public ScoreModeEnum ScoreMode = ScoreModeEnum.NotSet;

/// <summary>
/// A script can be used instead of boost for more complex score calculations. With optional params and lang (on the same level as query and filters).
/// </summary>
public string Script;

public CustomFiltersScoreQuery(IQuery query, List<IFilter> filters)
{
Query = query;
foreach (var filter in filters)
{
Filters.Add(filter, 1);
}
}

public CustomFiltersScoreQuery(IQuery query, IDictionary<IFilter, double> boostedFilters)
{
Query = query;
Filters = boostedFilters;
}

public CustomFiltersScoreQuery AddBoostedFilter(IFilter filter, double boost)
{
Filters.Add(filter, boost);
return this;
}

public CustomFiltersScoreQuery SetFilterBoost(IFilter filter, double boost)
{
if (Filters.ContainsKey(filter))
{
Filters[filter] = boost;
}
return this;
}

public enum ScoreModeEnum
{
First,
Min,
Max,
Total,
Avg,
Multiply,
NotSet
}
}
}
Original file line number Diff line number Diff line change
@@ -1,48 +1,59 @@
using System;
using Newtonsoft.Json;

namespace ElasticSearch.Client.QueryDSL
{
internal class CustomFiltersScoreQueryConverterer:JsonConverter
{
public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
{
CustomFiltersScoreQuery term = (CustomFiltersScoreQuery)value;
if (term != null)
{
writer.WriteStartObject();
writer.WritePropertyName("custom_filters_score");
writer.WriteStartObject();
writer.WritePropertyName("query");
serializer.Serialize(writer,term.Query);
writer.WritePropertyName("filters");

writer.WriteStartArray();
foreach (var filter in term.Filters)
{
serializer.Serialize(writer,filter);
}
writer.WriteEndArray();

writer.WritePropertyName("score_mode");
writer.WriteValue(term.ScoreMode);

writer.WritePropertyName("script");
writer.WriteValue(term.Script);

writer.WriteEndObject();
writer.WriteEndObject();
}
}

public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
{
throw new NotImplementedException();
}

public override bool CanConvert(Type objectType)
{
return typeof(CustomFiltersScoreQuery).IsAssignableFrom(objectType);
}
}
using System;
using Newtonsoft.Json;

namespace ElasticSearch.Client.QueryDSL
{
internal class CustomFiltersScoreQueryConverterer: JsonConverter
{
public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
{
CustomFiltersScoreQuery term = (CustomFiltersScoreQuery)value;
if (term != null)
{
writer.WriteStartObject();
writer.WritePropertyName("custom_filters_score");
writer.WriteStartObject();
writer.WritePropertyName("query");
serializer.Serialize(writer, term.Query);
writer.WritePropertyName("filters");

writer.WriteStartArray();
foreach (var filter in term.Filters)
{
writer.WriteStartObject();
writer.WritePropertyName("filter");
serializer.Serialize(writer, filter.Key);
writer.WritePropertyName("boost");
writer.WriteValue(filter.Value);
writer.WriteEndObject();
}
writer.WriteEndArray();

if (term.ScoreMode != CustomFiltersScoreQuery.ScoreModeEnum.NotSet)
{
writer.WritePropertyName("score_mode");
writer.WriteValue(term.ScoreMode.ToString());
}

if (!string.IsNullOrEmpty(term.Script))
{
writer.WritePropertyName("script");
writer.WriteValue(term.Script);
}

writer.WriteEndObject();
writer.WriteEndObject();
}
}

public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
{
throw new NotImplementedException();
}

public override bool CanConvert(Type objectType)
{
return typeof(CustomFiltersScoreQuery).IsAssignableFrom(objectType);
}
}
}

0 comments on commit 7ad73cb

Please sign in to comment.