Skip to content

Commit 99940f4

Browse files
committed
Merge pull request spring-projects#14 from javamachr/master
added format and pattern support for date fieldtype + fixed nullpointer...
2 parents 406ef06 + 21577aa commit 99940f4

File tree

6 files changed

+130
-3
lines changed

6 files changed

+130
-3
lines changed
Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
package org.springframework.data.elasticsearch.annotations;
2+
3+
/**
4+
* @author Jakub Vavrik
5+
*
6+
* Values based on reference doc - http://www.elasticsearch.org/guide/reference/mapping/date-format/
7+
*/
8+
public enum DateFormat {
9+
none, custom, basic_date, basic_date_time, basic_date_time_no_millis, basic_ordinal_date, basic_ordinal_date_time,
10+
basic_ordinal_date_time_no_millis, basic_time, basic_time_no_millis, basic_t_time, basic_t_time_no_millis,
11+
basic_week_date, basic_week_date_time, basic_week_date_time_no_millis, date, date_hour, date_hour_minute,
12+
date_hour_minute_second, date_hour_minute_second_fraction, date_hour_minute_second_millis, date_optional_time,
13+
date_time, date_time_no_millis, hour, hour_minute, hour_minute_second, hour_minute_second_fraction,
14+
hour_minute_second_millis, ordinal_date, ordinal_date_time, ordinal_date_time_no_millis, time, time_no_millis,
15+
t_time, t_time_no_millis, week_date, week_date_time, weekDateTimeNoMillis, week_year, weekyearWeek,
16+
weekyearWeekDay, year, year_month, year_month_day
17+
}

src/main/java/org/springframework/data/elasticsearch/annotations/Field.java

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,7 @@
2222
* @author Mohsin Husen
2323
* @author Artur Konczak
2424
* @author Jonathan Yan
25+
* @author Jakub Vavrik
2526
*/
2627
@Retention(RetentionPolicy.RUNTIME)
2728
@Target(ElementType.FIELD)
@@ -32,6 +33,10 @@
3233

3334
FieldIndex index() default FieldIndex.analyzed;
3435

36+
DateFormat format() default DateFormat.none;
37+
38+
String pattern() default "";
39+
3540
boolean store() default false;
3641

3742
String searchAnalyzer() default "";

src/main/java/org/springframework/data/elasticsearch/client/TransportClientFactoryBean.java

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -35,6 +35,7 @@
3535
*
3636
* @author Rizwan Idrees
3737
* @author Mohsin Husen
38+
* @author Jakub Vavrik
3839
*/
3940

4041
public class TransportClientFactoryBean implements FactoryBean<TransportClient>, InitializingBean, DisposableBean {
@@ -43,9 +44,9 @@ public class TransportClientFactoryBean implements FactoryBean<TransportClient>,
4344
private String clusterNodes;
4445
private String clusterName;
4546
private Boolean clientTransportSniff;
46-
private Boolean clientIgnoreClusterName;
47-
private String clientPingTimeout;
48-
private String clientNodesSamplerInterval;
47+
private Boolean clientIgnoreClusterName = Boolean.FALSE;
48+
private String clientPingTimeout = "5s";
49+
private String clientNodesSamplerInterval = "5s";
4950
private TransportClient client;
5051
private Properties properties;
5152
static final String COLON = ":";

src/main/java/org/springframework/data/elasticsearch/core/MappingBuilder.java

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -41,6 +41,7 @@ class MappingBuilder {
4141
public static final String FIELD_STORE = "store";
4242
public static final String FIELD_TYPE = "type";
4343
public static final String FIELD_INDEX = "index";
44+
public static final String FIELD_FORMAT = "format";
4445
public static final String FIELD_SEARCH_ANALYZER = "search_analyzer";
4546
public static final String FIELD_INDEX_ANALYZER = "index_analyzer";
4647
public static final String FIELD_PROPERTIES = "properties";
@@ -125,6 +126,10 @@ private static void addSingleFieldMapping(XContentBuilder xContentBuilder, java.
125126
xContentBuilder.field(FIELD_STORE, fieldAnnotation.store());
126127
if (FieldType.Auto != fieldAnnotation.type()) {
127128
xContentBuilder.field(FIELD_TYPE, fieldAnnotation.type().name().toLowerCase());
129+
if (FieldType.Date == fieldAnnotation.type() && DateFormat.none != fieldAnnotation.format()) {
130+
xContentBuilder.field(FIELD_FORMAT, DateFormat.custom == fieldAnnotation.format()
131+
? fieldAnnotation.pattern() : fieldAnnotation.format());
132+
}
128133
}
129134
if (FieldIndex.not_analyzed == fieldAnnotation.index()) {
130135
xContentBuilder.field(FIELD_INDEX, fieldAnnotation.index().name().toLowerCase());
Lines changed: 73 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,73 @@
1+
package org.springframework.data.elasticsearch;
2+
3+
import org.springframework.data.annotation.Id;
4+
import org.springframework.data.elasticsearch.annotations.DateFormat;
5+
import org.springframework.data.elasticsearch.annotations.Document;
6+
import org.springframework.data.elasticsearch.annotations.Field;
7+
8+
import java.util.Date;
9+
10+
import static org.springframework.data.elasticsearch.annotations.FieldIndex.not_analyzed;
11+
import static org.springframework.data.elasticsearch.annotations.FieldType.String;
12+
import static org.springframework.data.elasticsearch.annotations.FieldType.Date;
13+
14+
/**
15+
* @author Jakub Vavrik
16+
*/
17+
@Document(indexName = "test-datemapping", type = "mapping", indexStoreType = "memory", shards = 1, replicas = 0, refreshInterval = "-1")
18+
public class SampleDateMappingEntity {
19+
@Id
20+
private String id;
21+
22+
@Field(type = String, index = not_analyzed, store = true, searchAnalyzer = "standard", indexAnalyzer = "standard")
23+
private String message;
24+
25+
@Field(type = Date, format = DateFormat.custom, pattern = "dd.MM.yyyy hh:mm")
26+
private Date customFormatDate;
27+
28+
@Field(type = Date)
29+
private Date defaultFormatDate;
30+
31+
@Field(type = Date, format = DateFormat.basic_date)
32+
private Date basicFormatDate;
33+
34+
public String getId() {
35+
return id;
36+
}
37+
38+
public void setId(String id) {
39+
this.id = id;
40+
}
41+
42+
public String getMessage() {
43+
return message;
44+
}
45+
46+
public void setMessage(String message) {
47+
this.message = message;
48+
}
49+
50+
public Date getCustomFormatDate() {
51+
return customFormatDate;
52+
}
53+
54+
public void setCustomFormatDate(Date customFormatDate) {
55+
this.customFormatDate = customFormatDate;
56+
}
57+
58+
public Date getDefaultFormatDate() {
59+
return defaultFormatDate;
60+
}
61+
62+
public void setDefaultFormatDate(Date defaultFormatDate) {
63+
this.defaultFormatDate = defaultFormatDate;
64+
}
65+
66+
public Date getBasicFormatDate() {
67+
return basicFormatDate;
68+
}
69+
70+
public void setBasicFormatDate(Date basicFormatDate) {
71+
this.basicFormatDate = basicFormatDate;
72+
}
73+
}
Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
package org.springframework.data.elasticsearch.core;
2+
3+
import org.elasticsearch.common.xcontent.XContentBuilder;
4+
import org.junit.Assert;
5+
import org.junit.Test;
6+
import org.springframework.data.elasticsearch.SampleDateMappingEntity;
7+
8+
import java.beans.IntrospectionException;
9+
import java.io.IOException;
10+
11+
/**
12+
* @author Jakub Vavrik
13+
*/
14+
public class SimpleElasticsearchDateMappingTest {
15+
private static final String EXPECTED_MAPPING = "{\"mapping\":{\"properties\":{\"message\":{\"store\":true," +
16+
"\"type\":\"string\",\"index\":\"not_analyzed\",\"search_analyzer\":\"standard\",\"index_analyzer\"" +
17+
":\"standard\"},\"customFormatDate\":{\"store\":false,\"type\":\"date\",\"format\":\"dd.MM.yyyy hh:mm\"}," +
18+
"\"defaultFormatDate\":{\"store\":false,\"type\":\"date\"},\"basicFormatDate\":{\"store\":false,\"" +
19+
"type\":\"date\",\"format\":\"basic_date\"}}}}";
20+
21+
@Test
22+
public void testCorrectDateMappings() throws NoSuchFieldException, IntrospectionException, IOException {
23+
XContentBuilder xContentBuilder = MappingBuilder.buildMapping(SampleDateMappingEntity.class, "mapping", "id");
24+
Assert.assertEquals(EXPECTED_MAPPING, xContentBuilder.string());
25+
}
26+
}

0 commit comments

Comments
 (0)