sunspot 0.9.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/History.txt +83 -0
- data/LICENSE +18 -0
- data/README.rdoc +154 -0
- data/Rakefile +9 -0
- data/TODO +9 -0
- data/VERSION.yml +4 -0
- data/bin/sunspot-configure-solr +46 -0
- data/bin/sunspot-solr +62 -0
- data/lib/light_config.rb +40 -0
- data/lib/sunspot.rb +469 -0
- data/lib/sunspot/adapters.rb +265 -0
- data/lib/sunspot/composite_setup.rb +186 -0
- data/lib/sunspot/configuration.rb +38 -0
- data/lib/sunspot/data_extractor.rb +47 -0
- data/lib/sunspot/dsl.rb +3 -0
- data/lib/sunspot/dsl/field_query.rb +72 -0
- data/lib/sunspot/dsl/fields.rb +86 -0
- data/lib/sunspot/dsl/query.rb +59 -0
- data/lib/sunspot/dsl/query_facet.rb +31 -0
- data/lib/sunspot/dsl/restriction.rb +25 -0
- data/lib/sunspot/dsl/scope.rb +193 -0
- data/lib/sunspot/dsl/search.rb +30 -0
- data/lib/sunspot/facet.rb +16 -0
- data/lib/sunspot/facet_data.rb +120 -0
- data/lib/sunspot/facet_row.rb +10 -0
- data/lib/sunspot/field.rb +157 -0
- data/lib/sunspot/field_factory.rb +126 -0
- data/lib/sunspot/indexer.rb +123 -0
- data/lib/sunspot/instantiated_facet.rb +42 -0
- data/lib/sunspot/instantiated_facet_row.rb +22 -0
- data/lib/sunspot/query.rb +191 -0
- data/lib/sunspot/query/base_query.rb +90 -0
- data/lib/sunspot/query/connective.rb +126 -0
- data/lib/sunspot/query/dynamic_query.rb +69 -0
- data/lib/sunspot/query/field_facet.rb +151 -0
- data/lib/sunspot/query/field_query.rb +63 -0
- data/lib/sunspot/query/pagination.rb +39 -0
- data/lib/sunspot/query/query_facet.rb +73 -0
- data/lib/sunspot/query/query_facet_row.rb +19 -0
- data/lib/sunspot/query/query_field_facet.rb +13 -0
- data/lib/sunspot/query/restriction.rb +233 -0
- data/lib/sunspot/query/scope.rb +165 -0
- data/lib/sunspot/query/sort.rb +36 -0
- data/lib/sunspot/query/sort_composite.rb +33 -0
- data/lib/sunspot/schema.rb +165 -0
- data/lib/sunspot/search.rb +219 -0
- data/lib/sunspot/search/hit.rb +66 -0
- data/lib/sunspot/session.rb +201 -0
- data/lib/sunspot/setup.rb +271 -0
- data/lib/sunspot/type.rb +200 -0
- data/lib/sunspot/util.rb +164 -0
- data/solr/etc/jetty.xml +212 -0
- data/solr/etc/webdefault.xml +379 -0
- data/solr/lib/jetty-6.1.3.jar +0 -0
- data/solr/lib/jetty-util-6.1.3.jar +0 -0
- data/solr/lib/jsp-2.1/ant-1.6.5.jar +0 -0
- data/solr/lib/jsp-2.1/core-3.1.1.jar +0 -0
- data/solr/lib/jsp-2.1/jsp-2.1.jar +0 -0
- data/solr/lib/jsp-2.1/jsp-api-2.1.jar +0 -0
- data/solr/lib/servlet-api-2.5-6.1.3.jar +0 -0
- data/solr/solr/conf/elevate.xml +36 -0
- data/solr/solr/conf/protwords.txt +21 -0
- data/solr/solr/conf/schema.xml +50 -0
- data/solr/solr/conf/solrconfig.xml +696 -0
- data/solr/solr/conf/stopwords.txt +57 -0
- data/solr/solr/conf/synonyms.txt +31 -0
- data/solr/start.jar +0 -0
- data/solr/webapps/solr.war +0 -0
- data/spec/api/adapters_spec.rb +33 -0
- data/spec/api/build_search_spec.rb +1039 -0
- data/spec/api/indexer_spec.rb +311 -0
- data/spec/api/query_spec.rb +153 -0
- data/spec/api/search_retrieval_spec.rb +362 -0
- data/spec/api/session_spec.rb +157 -0
- data/spec/api/spec_helper.rb +1 -0
- data/spec/api/sunspot_spec.rb +18 -0
- data/spec/integration/dynamic_fields_spec.rb +55 -0
- data/spec/integration/faceting_spec.rb +169 -0
- data/spec/integration/keyword_search_spec.rb +83 -0
- data/spec/integration/scoped_search_spec.rb +289 -0
- data/spec/integration/spec_helper.rb +1 -0
- data/spec/integration/stored_fields_spec.rb +10 -0
- data/spec/integration/test_pagination.rb +32 -0
- data/spec/mocks/adapters.rb +32 -0
- data/spec/mocks/blog.rb +3 -0
- data/spec/mocks/comment.rb +19 -0
- data/spec/mocks/connection.rb +84 -0
- data/spec/mocks/mock_adapter.rb +30 -0
- data/spec/mocks/mock_record.rb +48 -0
- data/spec/mocks/photo.rb +8 -0
- data/spec/mocks/post.rb +73 -0
- data/spec/mocks/user.rb +8 -0
- data/spec/spec_helper.rb +47 -0
- data/tasks/gemspec.rake +25 -0
- data/tasks/rcov.rake +28 -0
- data/tasks/rdoc.rake +22 -0
- data/tasks/schema.rake +19 -0
- data/tasks/spec.rake +24 -0
- data/tasks/todo.rake +4 -0
- data/templates/schema.xml.haml +24 -0
- metadata +246 -0
data/lib/sunspot/type.rb
ADDED
@@ -0,0 +1,200 @@
|
|
1
|
+
module Sunspot
|
2
|
+
#
|
3
|
+
# This module contains singleton objects that represent the types that can be
|
4
|
+
# indexed and searched using Sunspot. Plugin developers should be able to
|
5
|
+
# add new constants to the Type module; as long as they implement the
|
6
|
+
# appropriate methods, Sunspot should be able to integrate them (note that
|
7
|
+
# this capability is untested at the moment). The required methods are:
|
8
|
+
#
|
9
|
+
# +indexed_name+::
|
10
|
+
# Convert a given field name into its form as stored in Solr. This
|
11
|
+
# generally means adding a suffix to match a Solr dynamicField definition.
|
12
|
+
# +to_indexed+::
|
13
|
+
# Convert a value of this type into the appropriate Solr string
|
14
|
+
# representation.
|
15
|
+
# +cast+::
|
16
|
+
# Convert a Solr string representation of a value into the appropriate
|
17
|
+
# Ruby type.
|
18
|
+
#
|
19
|
+
module Type
|
20
|
+
#
|
21
|
+
# Text is a special type that stores data for fulltext search. Unlike other
|
22
|
+
# types, Text fields are tokenized and are made available to the keyword
|
23
|
+
# search phrase. Text fields cannot be faceted, ordered upon, or used in
|
24
|
+
# restrictions. Similarly, text fields are the only fields that are made
|
25
|
+
# available to keyword search.
|
26
|
+
#
|
27
|
+
module TextType
|
28
|
+
class <<self
|
29
|
+
def indexed_name(name) #:nodoc:
|
30
|
+
"#{name}_text"
|
31
|
+
end
|
32
|
+
|
33
|
+
def to_indexed(value) #:nodoc:
|
34
|
+
value.to_s if value
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
#
|
40
|
+
# The String type represents string data.
|
41
|
+
#
|
42
|
+
module StringType
|
43
|
+
class <<self
|
44
|
+
def indexed_name(name) #:nodoc:
|
45
|
+
"#{name}_s"
|
46
|
+
end
|
47
|
+
|
48
|
+
def to_indexed(value) #:nodoc:
|
49
|
+
value.to_s if value
|
50
|
+
end
|
51
|
+
|
52
|
+
def cast(string) #:nodoc:
|
53
|
+
string
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
#
|
59
|
+
# The Integer type represents integers.
|
60
|
+
#
|
61
|
+
module IntegerType
|
62
|
+
class <<self
|
63
|
+
def indexed_name(name) #:nodoc:
|
64
|
+
"#{name}_i"
|
65
|
+
end
|
66
|
+
|
67
|
+
def to_indexed(value) #:nodoc:
|
68
|
+
value.to_i.to_s if value
|
69
|
+
end
|
70
|
+
|
71
|
+
def cast(string) #:nodoc:
|
72
|
+
string.to_i
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
|
77
|
+
#
|
78
|
+
# The Float type represents floating-point numbers.
|
79
|
+
#
|
80
|
+
module FloatType
|
81
|
+
class <<self
|
82
|
+
def indexed_name(name) #:nodoc:
|
83
|
+
"#{name}_f"
|
84
|
+
end
|
85
|
+
|
86
|
+
def to_indexed(value) #:nodoc:
|
87
|
+
value.to_f.to_s if value
|
88
|
+
end
|
89
|
+
|
90
|
+
def cast(string) #:nodoc:
|
91
|
+
string.to_f
|
92
|
+
end
|
93
|
+
end
|
94
|
+
end
|
95
|
+
|
96
|
+
#
|
97
|
+
# The time type represents times. Note that times are always converted to
|
98
|
+
# UTC before indexing, and facets of Time fields always return times in UTC.
|
99
|
+
#
|
100
|
+
module TimeType
|
101
|
+
|
102
|
+
class <<self
|
103
|
+
def indexed_name(name) #:nodoc:
|
104
|
+
"#{name}_d"
|
105
|
+
end
|
106
|
+
|
107
|
+
def to_indexed(value) #:nodoc:
|
108
|
+
if value
|
109
|
+
time =
|
110
|
+
if value.respond_to?(:utc)
|
111
|
+
value
|
112
|
+
else
|
113
|
+
Time.parse(value.to_s)
|
114
|
+
end
|
115
|
+
time.utc.xmlschema
|
116
|
+
end
|
117
|
+
end
|
118
|
+
|
119
|
+
def cast(string) #:nodoc:
|
120
|
+
Time.xmlschema(string)
|
121
|
+
end
|
122
|
+
end
|
123
|
+
end
|
124
|
+
|
125
|
+
#
|
126
|
+
# The DateType encapsulates dates (without time information). Internally,
|
127
|
+
# Solr does not have a date-only type, so this type indexes data using
|
128
|
+
# Solr's DateField type (which is actually date/time), midnight UTC of the
|
129
|
+
# indexed date.
|
130
|
+
#
|
131
|
+
module DateType
|
132
|
+
class <<self
|
133
|
+
def indexed_name(name) #:nodoc:
|
134
|
+
"#{name}_d"
|
135
|
+
end
|
136
|
+
|
137
|
+
def to_indexed(value) #:nodoc:
|
138
|
+
if value
|
139
|
+
time =
|
140
|
+
if %w(year mon mday).all? { |method| value.respond_to?(method) }
|
141
|
+
Time.utc(value.year, value.mon, value.mday)
|
142
|
+
else
|
143
|
+
date = Date.parse(value.to_s)
|
144
|
+
Time.utc(date.year, date.mon, date.mday)
|
145
|
+
end
|
146
|
+
time.utc.xmlschema
|
147
|
+
end
|
148
|
+
end
|
149
|
+
|
150
|
+
def cast(string)
|
151
|
+
time = Time.xmlschema(string)
|
152
|
+
Date.civil(time.year, time.mon, time.mday)
|
153
|
+
end
|
154
|
+
end
|
155
|
+
end
|
156
|
+
|
157
|
+
#
|
158
|
+
# The boolean type represents true/false values. Note that +nil+ will not be
|
159
|
+
# indexed at all; only +false+ will be indexed with a false value.
|
160
|
+
#
|
161
|
+
module BooleanType
|
162
|
+
class <<self
|
163
|
+
def indexed_name(name) #:nodoc:
|
164
|
+
"#{name}_b"
|
165
|
+
end
|
166
|
+
|
167
|
+
def to_indexed(value) #:nodoc:
|
168
|
+
unless value.nil?
|
169
|
+
value ? 'true' : 'false'
|
170
|
+
end
|
171
|
+
end
|
172
|
+
|
173
|
+
def cast(string) #:nodoc:
|
174
|
+
case string
|
175
|
+
when 'true'
|
176
|
+
true
|
177
|
+
when 'false'
|
178
|
+
false
|
179
|
+
end
|
180
|
+
end
|
181
|
+
end
|
182
|
+
end
|
183
|
+
|
184
|
+
module ClassType
|
185
|
+
class <<self
|
186
|
+
def indexed_name(name)
|
187
|
+
'class_name'
|
188
|
+
end
|
189
|
+
|
190
|
+
def to_indexed(value)
|
191
|
+
value.name
|
192
|
+
end
|
193
|
+
|
194
|
+
def cast(string)
|
195
|
+
Sunspot::Util.full_const_get(string)
|
196
|
+
end
|
197
|
+
end
|
198
|
+
end
|
199
|
+
end
|
200
|
+
end
|
data/lib/sunspot/util.rb
ADDED
@@ -0,0 +1,164 @@
|
|
1
|
+
module Sunspot
|
2
|
+
#
|
3
|
+
# The Sunspot::Util module provides utility methods used elsewhere in the
|
4
|
+
# library.
|
5
|
+
#
|
6
|
+
module Util #:nodoc:
|
7
|
+
class <<self
|
8
|
+
#
|
9
|
+
# Get all of the superclasses for a given class, including the class
|
10
|
+
# itself.
|
11
|
+
#
|
12
|
+
# ==== Parameters
|
13
|
+
#
|
14
|
+
# clazz<Class>:: class for which to get superclasses
|
15
|
+
#
|
16
|
+
# ==== Returns
|
17
|
+
#
|
18
|
+
# Array:: Collection containing class and its superclasses
|
19
|
+
#
|
20
|
+
def superclasses_for(clazz)
|
21
|
+
superclasses = [clazz]
|
22
|
+
superclasses << (clazz = clazz.superclass) while clazz.superclass != Object
|
23
|
+
superclasses
|
24
|
+
end
|
25
|
+
|
26
|
+
#
|
27
|
+
# Convert a string to snake case
|
28
|
+
#
|
29
|
+
# ==== Parameters
|
30
|
+
#
|
31
|
+
# string<String>:: String to convert to snake case
|
32
|
+
#
|
33
|
+
# ==== Returns
|
34
|
+
#
|
35
|
+
# String:: String in snake case
|
36
|
+
#
|
37
|
+
def snake_case(string)
|
38
|
+
string.scan(/(^|[A-Z])([^A-Z]+)/).map! { |word| word.join.downcase }.join('_')
|
39
|
+
end
|
40
|
+
|
41
|
+
#
|
42
|
+
# Convert a string to camel case
|
43
|
+
#
|
44
|
+
# ==== Parameters
|
45
|
+
#
|
46
|
+
# string<String>:: String to convert to camel case
|
47
|
+
#
|
48
|
+
# ==== Returns
|
49
|
+
#
|
50
|
+
# String:: String in camel case
|
51
|
+
#
|
52
|
+
def camel_case(string)
|
53
|
+
string.split('_').map! { |word| word.capitalize }.join
|
54
|
+
end
|
55
|
+
|
56
|
+
#
|
57
|
+
# Get a constant from a fully qualified name
|
58
|
+
#
|
59
|
+
# ==== Parameters
|
60
|
+
#
|
61
|
+
# string<String>:: The fully qualified name of a constant
|
62
|
+
#
|
63
|
+
# ==== Returns
|
64
|
+
#
|
65
|
+
# Object:: Value of constant named
|
66
|
+
#
|
67
|
+
def full_const_get(string)
|
68
|
+
string.split('::').inject(Object) do |context, const_name|
|
69
|
+
context.const_get(const_name)
|
70
|
+
end
|
71
|
+
end
|
72
|
+
|
73
|
+
#
|
74
|
+
# Evaluate the given proc in the context of the given object if the
|
75
|
+
# block's arity is non-positive, or by passing the given object as an
|
76
|
+
# argument if it is negative.
|
77
|
+
#
|
78
|
+
# ==== Parameters
|
79
|
+
#
|
80
|
+
# object<Object>:: Object to pass to the proc
|
81
|
+
#
|
82
|
+
def instance_eval_or_call(object, &block)
|
83
|
+
if block.arity > 0
|
84
|
+
block.call(object)
|
85
|
+
else
|
86
|
+
object.instance_eval(&block)
|
87
|
+
end
|
88
|
+
end
|
89
|
+
|
90
|
+
#
|
91
|
+
# Perform a deep merge of hashes, returning the result as a new hash.
|
92
|
+
# See #deep_merge_into for rules used to merge the hashes
|
93
|
+
#
|
94
|
+
# ==== Parameters
|
95
|
+
#
|
96
|
+
# left<Hash>:: Hash to merge
|
97
|
+
# right<Hash>:: The other hash to merge
|
98
|
+
#
|
99
|
+
# ==== Returns
|
100
|
+
#
|
101
|
+
# Hash:: New hash containing the given hashes deep-merged.
|
102
|
+
#
|
103
|
+
def deep_merge(left, right)
|
104
|
+
deep_merge_into({}, left, right)
|
105
|
+
end
|
106
|
+
|
107
|
+
#
|
108
|
+
# Perform a deep merge of the right hash into the left hash
|
109
|
+
#
|
110
|
+
# ==== Parameters
|
111
|
+
#
|
112
|
+
# left:: Hash to receive merge
|
113
|
+
# right:: Hash to merge into left
|
114
|
+
#
|
115
|
+
# ==== Returns
|
116
|
+
#
|
117
|
+
# Hash:: left
|
118
|
+
#
|
119
|
+
def deep_merge!(left, right)
|
120
|
+
deep_merge_into(left, left, right)
|
121
|
+
end
|
122
|
+
|
123
|
+
private
|
124
|
+
|
125
|
+
#
|
126
|
+
# Deep merge two hashes into a third hash, using rules that produce nice
|
127
|
+
# merged parameter hashes. The rules are as follows, for a given key:
|
128
|
+
#
|
129
|
+
# * If only one hash has a value, or if both hashes have the same value,
|
130
|
+
# just use the value.
|
131
|
+
# * If either of the values is not a hash, create arrays out of both
|
132
|
+
# values and concatenate them.
|
133
|
+
# * Otherwise, deep merge the two values (which are both hashes)
|
134
|
+
#
|
135
|
+
# ==== Parameters
|
136
|
+
#
|
137
|
+
# destination<Hash>:: Hash into which to perform the merge
|
138
|
+
# left<Hash>:: One hash to merge
|
139
|
+
# right<Hash>:: The other hash to merge
|
140
|
+
#
|
141
|
+
# ==== Returns
|
142
|
+
#
|
143
|
+
# Hash:: destination
|
144
|
+
#
|
145
|
+
def deep_merge_into(destination, left, right)
|
146
|
+
left.each_pair do |name, left_value|
|
147
|
+
right_value = right[name]
|
148
|
+
destination[name] =
|
149
|
+
if right_value.nil? || left_value == right_value
|
150
|
+
left_value
|
151
|
+
elsif !left_value.respond_to?(:each_pair) || !right_value.respond_to?(:each_pair)
|
152
|
+
Array(left_value) + Array(right_value)
|
153
|
+
else
|
154
|
+
merged_value = {}
|
155
|
+
deep_merge_into(merged_value, left_value, right_value)
|
156
|
+
end
|
157
|
+
end
|
158
|
+
left_keys = Set.new(left.keys)
|
159
|
+
destination.merge!(right.reject { |k, v| left_keys.include?(k) })
|
160
|
+
destination
|
161
|
+
end
|
162
|
+
end
|
163
|
+
end
|
164
|
+
end
|
data/solr/etc/jetty.xml
ADDED
@@ -0,0 +1,212 @@
|
|
1
|
+
<?xml version="1.0"?>
|
2
|
+
<!DOCTYPE Configure PUBLIC "-//Mort Bay Consulting//DTD Configure//EN" "http://jetty.mortbay.org/configure.dtd">
|
3
|
+
|
4
|
+
<!-- =============================================================== -->
|
5
|
+
<!-- Configure the Jetty Server -->
|
6
|
+
<!-- -->
|
7
|
+
<!-- Documentation of this file format can be found at: -->
|
8
|
+
<!-- http://docs.codehaus.org/display/JETTY/jetty.xml -->
|
9
|
+
<!-- -->
|
10
|
+
<!-- =============================================================== -->
|
11
|
+
|
12
|
+
|
13
|
+
<Configure id="Server" class="org.mortbay.jetty.Server">
|
14
|
+
|
15
|
+
<!-- Increase the maximum POST size to 1 MB to be able to handle large shard requests -->
|
16
|
+
<Call class="java.lang.System" name="setProperty">
|
17
|
+
<Arg>org.mortbay.jetty.Request.maxFormContentSize</Arg>
|
18
|
+
<Arg>1000000</Arg>
|
19
|
+
</Call>
|
20
|
+
|
21
|
+
<!-- =========================================================== -->
|
22
|
+
<!-- Server Thread Pool -->
|
23
|
+
<!-- =========================================================== -->
|
24
|
+
<Set name="ThreadPool">
|
25
|
+
<!-- Default bounded blocking threadpool
|
26
|
+
-->
|
27
|
+
<New class="org.mortbay.thread.BoundedThreadPool">
|
28
|
+
<Set name="minThreads">10</Set>
|
29
|
+
<Set name="lowThreads">50</Set>
|
30
|
+
<Set name="maxThreads">10000</Set>
|
31
|
+
</New>
|
32
|
+
|
33
|
+
<!-- Optional Java 5 bounded threadpool with job queue
|
34
|
+
<New class="org.mortbay.thread.concurrent.ThreadPool">
|
35
|
+
<Arg type="int">0</Arg>
|
36
|
+
<Set name="corePoolSize">10</Set>
|
37
|
+
<Set name="maximumPoolSize">250</Set>
|
38
|
+
</New>
|
39
|
+
-->
|
40
|
+
</Set>
|
41
|
+
|
42
|
+
|
43
|
+
|
44
|
+
<!-- =========================================================== -->
|
45
|
+
<!-- Set connectors -->
|
46
|
+
<!-- =========================================================== -->
|
47
|
+
<!-- One of each type! -->
|
48
|
+
<!-- =========================================================== -->
|
49
|
+
|
50
|
+
<!-- Use this connector for many frequently idle connections
|
51
|
+
and for threadless continuations.
|
52
|
+
<Call name="addConnector">
|
53
|
+
<Arg>
|
54
|
+
<New class="org.mortbay.jetty.nio.SelectChannelConnector">
|
55
|
+
<Set name="port"><SystemProperty name="jetty.port" default="8983"/></Set>
|
56
|
+
<Set name="maxIdleTime">30000</Set>
|
57
|
+
<Set name="Acceptors">2</Set>
|
58
|
+
<Set name="confidentialPort">8443</Set>
|
59
|
+
</New>
|
60
|
+
</Arg>
|
61
|
+
</Call>
|
62
|
+
-->
|
63
|
+
|
64
|
+
<!-- Use this connector if NIO is not available. -->
|
65
|
+
<!-- This connector is currently being used for Solr because the
|
66
|
+
nio.SelectChannelConnector showed poor performance under WindowsXP
|
67
|
+
from a single client with non-persistent connections (35s vs ~3min)
|
68
|
+
to complete 10,000 requests)
|
69
|
+
-->
|
70
|
+
<Call name="addConnector">
|
71
|
+
<Arg>
|
72
|
+
<New class="org.mortbay.jetty.bio.SocketConnector">
|
73
|
+
<Set name="port"><SystemProperty name="jetty.port" default="8983"/></Set>
|
74
|
+
<Set name="maxIdleTime">50000</Set>
|
75
|
+
<Set name="lowResourceMaxIdleTime">1500</Set>
|
76
|
+
</New>
|
77
|
+
</Arg>
|
78
|
+
</Call>
|
79
|
+
|
80
|
+
<!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
|
81
|
+
<!-- To add a HTTPS SSL listener -->
|
82
|
+
<!-- see jetty-ssl.xml to add an ssl connector. use -->
|
83
|
+
<!-- java -jar start.jar etc/jetty.xml etc/jetty-ssl.xml -->
|
84
|
+
<!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
|
85
|
+
|
86
|
+
<!-- =========================================================== -->
|
87
|
+
<!-- Set up global session ID manager -->
|
88
|
+
<!-- =========================================================== -->
|
89
|
+
<!--
|
90
|
+
<Set name="sessionIdManager">
|
91
|
+
<New class="org.mortbay.jetty.servlet.HashSessionIdManager">
|
92
|
+
<Set name="workerName">node1</Set>
|
93
|
+
</New>
|
94
|
+
</Set>
|
95
|
+
-->
|
96
|
+
|
97
|
+
<!-- =========================================================== -->
|
98
|
+
<!-- Set handler Collection Structure -->
|
99
|
+
<!-- =========================================================== -->
|
100
|
+
<Set name="handler">
|
101
|
+
<New id="Handlers" class="org.mortbay.jetty.handler.HandlerCollection">
|
102
|
+
<Set name="handlers">
|
103
|
+
<Array type="org.mortbay.jetty.Handler">
|
104
|
+
<Item>
|
105
|
+
<New id="Contexts" class="org.mortbay.jetty.handler.ContextHandlerCollection"/>
|
106
|
+
</Item>
|
107
|
+
<Item>
|
108
|
+
<New id="DefaultHandler" class="org.mortbay.jetty.handler.DefaultHandler"/>
|
109
|
+
</Item>
|
110
|
+
<Item>
|
111
|
+
<New id="RequestLog" class="org.mortbay.jetty.handler.RequestLogHandler"/>
|
112
|
+
</Item>
|
113
|
+
</Array>
|
114
|
+
</Set>
|
115
|
+
</New>
|
116
|
+
</Set>
|
117
|
+
|
118
|
+
<!-- =========================================================== -->
|
119
|
+
<!-- Configure the context deployer -->
|
120
|
+
<!-- A context deployer will deploy contexts described in -->
|
121
|
+
<!-- configuration files discovered in a directory. -->
|
122
|
+
<!-- The configuration directory can be scanned for hot -->
|
123
|
+
<!-- deployments at the configured scanInterval. -->
|
124
|
+
<!-- -->
|
125
|
+
<!-- This deployer is configured to deploy contexts configured -->
|
126
|
+
<!-- in the $JETTY_HOME/contexts directory -->
|
127
|
+
<!-- -->
|
128
|
+
<!-- =========================================================== -->
|
129
|
+
<Call name="addLifeCycle">
|
130
|
+
<Arg>
|
131
|
+
<New class="org.mortbay.jetty.deployer.ContextDeployer">
|
132
|
+
<Set name="contexts"><Ref id="Contexts"/></Set>
|
133
|
+
<Set name="configurationDir"><SystemProperty name="jetty.home" default="."/>/contexts</Set>
|
134
|
+
<Set name="scanInterval">1</Set>
|
135
|
+
</New>
|
136
|
+
</Arg>
|
137
|
+
</Call>
|
138
|
+
|
139
|
+
<!-- =========================================================== -->
|
140
|
+
<!-- Configure the webapp deployer. -->
|
141
|
+
<!-- A webapp deployer will deploy standard webapps discovered -->
|
142
|
+
<!-- in a directory at startup, without the need for additional -->
|
143
|
+
<!-- configuration files. It does not support hot deploy or -->
|
144
|
+
<!-- non standard contexts (see ContextDeployer above). -->
|
145
|
+
<!-- -->
|
146
|
+
<!-- This deployer is configured to deploy webapps from the -->
|
147
|
+
<!-- $JETTY_HOME/webapps directory -->
|
148
|
+
<!-- -->
|
149
|
+
<!-- Normally only one type of deployer need be used. -->
|
150
|
+
<!-- -->
|
151
|
+
<!-- =========================================================== -->
|
152
|
+
<Call name="addLifeCycle">
|
153
|
+
<Arg>
|
154
|
+
<New class="org.mortbay.jetty.deployer.WebAppDeployer">
|
155
|
+
<Set name="contexts"><Ref id="Contexts"/></Set>
|
156
|
+
<Set name="webAppDir"><SystemProperty name="jetty.home" default="."/>/webapps</Set>
|
157
|
+
<Set name="parentLoaderPriority">false</Set>
|
158
|
+
<Set name="extract">true</Set>
|
159
|
+
<Set name="allowDuplicates">false</Set>
|
160
|
+
<Set name="defaultsDescriptor"><SystemProperty name="jetty.home" default="."/>/etc/webdefault.xml</Set>
|
161
|
+
</New>
|
162
|
+
</Arg>
|
163
|
+
</Call>
|
164
|
+
|
165
|
+
<!-- =========================================================== -->
|
166
|
+
<!-- Configure Authentication Realms -->
|
167
|
+
<!-- Realms may be configured for the entire server here, or -->
|
168
|
+
<!-- they can be configured for a specific web app in a context -->
|
169
|
+
<!-- configuration (see $(jetty.home)/contexts/test.xml for an -->
|
170
|
+
<!-- example). -->
|
171
|
+
<!-- =========================================================== -->
|
172
|
+
<Set name="UserRealms">
|
173
|
+
<Array type="org.mortbay.jetty.security.UserRealm">
|
174
|
+
<!--
|
175
|
+
<Item>
|
176
|
+
<New class="org.mortbay.jetty.security.HashUserRealm">
|
177
|
+
<Set name="name">Test Realm</Set>
|
178
|
+
<Set name="config"><SystemProperty name="jetty.home" default="."/>/etc/realm.properties</Set>
|
179
|
+
</New>
|
180
|
+
</Item>
|
181
|
+
-->
|
182
|
+
</Array>
|
183
|
+
</Set>
|
184
|
+
|
185
|
+
<!-- =========================================================== -->
|
186
|
+
<!-- Configure Request Log -->
|
187
|
+
<!-- Request logs may be configured for the entire server here, -->
|
188
|
+
<!-- or they can be configured for a specific web app in a -->
|
189
|
+
<!-- contexts configuration (see $(jetty.home)/contexts/test.xml -->
|
190
|
+
<!-- for an example). -->
|
191
|
+
<!-- =========================================================== -->
|
192
|
+
<Ref id="RequestLog">
|
193
|
+
<Set name="requestLog">
|
194
|
+
<!-- New id="RequestLogImpl" class="org.mortbay.jetty.NCSARequestLog">
|
195
|
+
<Arg><SystemProperty name="jetty.logs" default="./logs"/>/yyyy_mm_dd.request.log</Arg>
|
196
|
+
<Set name="retainDays">90</Set>
|
197
|
+
<Set name="append">true</Set>
|
198
|
+
<Set name="extended">false</Set>
|
199
|
+
<Set name="LogTimeZone">GMT</Set>
|
200
|
+
</New -->
|
201
|
+
</Set>
|
202
|
+
</Ref>
|
203
|
+
|
204
|
+
<!-- =========================================================== -->
|
205
|
+
<!-- extra options -->
|
206
|
+
<!-- =========================================================== -->
|
207
|
+
<Set name="stopAtShutdown">true</Set>
|
208
|
+
<!-- ensure/prevent Server: header being sent to browsers -->
|
209
|
+
<Set name="sendServerVersion">true</Set>
|
210
|
+
|
211
|
+
</Configure>
|
212
|
+
|