-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathabstract_index_creation_task.go
146 lines (120 loc) · 4.81 KB
/
abstract_index_creation_task.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
package ravendb
// Note: IndexCreationTask combines functionality of Java's
// AbstractIndexCreationTask and AbstractMultiMapIndexCreationTask
// IndexCreationTask is for creating IndexDefinition
type IndexCreationTask struct {
// for a single map index, set Map
// for multiple map index, set Maps
Map string
Maps []string
Reduce string
Conventions *DocumentConventions
AdditionalSources map[string]string
Priority IndexPriority
LockMode IndexLockMode
StoresStrings map[string]FieldStorage
IndexesStrings map[string]FieldIndexing
AnalyzersStrings map[string]string
IndexSuggestions []string
TermVectorsStrings map[string]FieldTermVector
SpatialOptionsStrings map[string]*SpatialOptions
OutputReduceToCollection string
// Note: in Go IndexName must provided explicitly
// In Java it's dynamically calculated as getClass().getSimpleName()
IndexName string
}
// NewAbstractIndexCreationTask returns new IndexCreationTask
func NewIndexCreationTask(indexName string) *IndexCreationTask {
// Note: in Java we subclass IndexCreationTask and indexName is derived
// from derived class name. In Go we don't subclass and must provide index name
// manually
panicIf(indexName == "", "indexName cannot be empty")
return &IndexCreationTask{
StoresStrings: make(map[string]FieldStorage),
IndexesStrings: make(map[string]FieldIndexing),
AnalyzersStrings: make(map[string]string),
TermVectorsStrings: make(map[string]FieldTermVector),
SpatialOptionsStrings: make(map[string]*SpatialOptions),
IndexName: indexName,
}
}
// CreateIndexDefinition creates IndexDefinition
func (t *IndexCreationTask) CreateIndexDefinition() *IndexDefinition {
if t.Conventions == nil {
t.Conventions = NewDocumentConventions()
}
indexDefinitionBuilder := NewIndexDefinitionBuilder(t.IndexName)
indexDefinitionBuilder.indexesStrings = t.IndexesStrings
indexDefinitionBuilder.analyzersStrings = t.AnalyzersStrings
indexDefinitionBuilder.setMap(t.Map)
indexDefinitionBuilder.reduce = t.Reduce
indexDefinitionBuilder.storesStrings = t.StoresStrings
indexDefinitionBuilder.suggestionsOptions = t.IndexSuggestions
indexDefinitionBuilder.termVectorsStrings = t.TermVectorsStrings
indexDefinitionBuilder.spatialIndexesStrings = t.SpatialOptionsStrings
indexDefinitionBuilder.outputReduceToCollection = t.OutputReduceToCollection
indexDefinitionBuilder.additionalSources = t.AdditionalSources
// validate for single map (Map set), don't validate multiple map (Maps)
validate := len(t.Maps) == 0
def := indexDefinitionBuilder.toIndexDefinition(t.Conventions, validate)
def.Maps = append(def.Maps, t.Maps...)
return def
}
// IsMapReduce returns true if this is map-reduce index
func (t *IndexCreationTask) IsMapReduce() bool {
return t.Reduce != ""
}
// Execute executes index in specified document store
func (t *IndexCreationTask) Execute(store *DocumentStore, conventions *DocumentConventions, database string) error {
return t.putIndex(store, conventions, database)
}
func (t *IndexCreationTask) putIndex(store *DocumentStore, conventions *DocumentConventions, database string) error {
oldConventions := t.Conventions
defer func() { t.Conventions = oldConventions }()
conv := conventions
if conv == nil {
conv = t.Conventions
}
if conv == nil {
conv = store.GetConventions()
}
t.Conventions = conv
indexDefinition := t.CreateIndexDefinition()
indexDefinition.Name = t.IndexName
indexDefinition.LockMode = t.LockMode
indexDefinition.Priority = t.Priority
op := NewPutIndexesOperation(indexDefinition)
if database == "" {
database = store.GetDatabase()
}
return store.Maintenance().ForDatabase(database).Send(op)
}
// Index registers field to be indexed
func (t *IndexCreationTask) Index(field string, indexing FieldIndexing) {
t.IndexesStrings[field] = indexing
}
// Spatial registers field to be spatially indexed
func (t *IndexCreationTask) Spatial(field string, indexing func() *SpatialOptions) {
v := indexing()
t.SpatialOptionsStrings[field] = v
}
// StoreAllFields selects if we're storing all fields or not
func (t *IndexCreationTask) StoreAllFields(storage FieldStorage) {
t.StoresStrings[IndexingFieldAllFields] = storage
}
// Store registers field to be stored
func (t *IndexCreationTask) Store(field string, storage FieldStorage) {
t.StoresStrings[field] = storage
}
// Analyze registers field to be analyzed
func (t *IndexCreationTask) Analyze(field string, analyzer string) {
t.AnalyzersStrings[field] = analyzer
}
// TermVector registers field to have term vectors
func (t *IndexCreationTask) TermVector(field string, termVector FieldTermVector) {
t.TermVectorsStrings[field] = termVector
}
// Suggestion registers field to be indexed as suggestions
func (t *IndexCreationTask) Suggestion(field string) {
t.IndexSuggestions = append(t.IndexSuggestions, field)
}