Compare commits
6 Commits
master
...
lukas/pick
Author | SHA1 | Date |
---|---|---|
iCross | 11e9f5d7cd | |
iCross | 2eaa44c279 | |
iCross | fe7393b9e2 | |
iCross | f12e5b8768 | |
iCross | 57e1ef7bae | |
iCross | 642d0ed239 |
|
@ -11,16 +11,13 @@ public/assets
|
||||||
public/index.html
|
public/index.html
|
||||||
public/panel/**/*
|
public/panel/**/*
|
||||||
public/uploads/**/*
|
public/uploads/**/*
|
||||||
solr/data
|
solr
|
||||||
tmp/**/*
|
tmp/**/*
|
||||||
uploads/**/*
|
uploads/**/*
|
||||||
config/*.god
|
|
||||||
log/*.gz
|
|
||||||
tmp/restart.txt
|
|
||||||
*.swp
|
*.swp
|
||||||
*.pid
|
*.pid
|
||||||
*.lck
|
*.lck
|
||||||
|
|
||||||
.sass-cache/*
|
.sass-cache/*
|
||||||
*.supported
|
*.supported
|
||||||
mongoid.yml
|
|
||||||
|
|
13
Gemfile
13
Gemfile
|
@ -14,11 +14,7 @@ gem 'execjs'
|
||||||
gem 'jquery-rails', '2.1.4'
|
gem 'jquery-rails', '2.1.4'
|
||||||
gem 'jquery-ui-rails'
|
gem 'jquery-ui-rails'
|
||||||
gem "select2-rails", '3.3.1'
|
gem "select2-rails", '3.3.1'
|
||||||
gem 'kaminari'
|
gem 'kaminari', :git => 'git://github.com/amatsuda/kaminari.git'
|
||||||
gem "acts_as_unvlogable"
|
|
||||||
gem 'youtube_it'
|
|
||||||
gem 'gotcha'
|
|
||||||
|
|
||||||
|
|
||||||
# gem "memcached", "~> 1.4.3"
|
# gem "memcached", "~> 1.4.3"
|
||||||
# gem "memcache-client"
|
# gem "memcache-client"
|
||||||
|
@ -39,7 +35,7 @@ gem 'resque-scheduler' # job scheduling
|
||||||
gem 'resque-restriction'
|
gem 'resque-restriction'
|
||||||
#gem 'rb-readline'
|
#gem 'rb-readline'
|
||||||
# gem 'ruby-debug19'
|
# gem 'ruby-debug19'
|
||||||
gem 'rubyzip','0.9.9'
|
gem 'rubyzip'
|
||||||
|
|
||||||
gem 'sunspot_mongo'
|
gem 'sunspot_mongo'
|
||||||
gem 'sunspot_solr'
|
gem 'sunspot_solr'
|
||||||
|
@ -50,14 +46,14 @@ gem 'sinatra'
|
||||||
gem 'sprockets'
|
gem 'sprockets'
|
||||||
gem 'social-share-button'
|
gem 'social-share-button'
|
||||||
|
|
||||||
gem 'tinymce-rails', '3.5.8.3'
|
gem 'tinymce-rails'
|
||||||
gem 'therubyracer' if RUBY_PLATFORM.downcase.include?("linux")
|
gem 'therubyracer' if RUBY_PLATFORM.downcase.include?("linux")
|
||||||
gem 'libv8', '~> 3.11.8' if RUBY_PLATFORM.downcase.include?("linux")
|
gem 'libv8', '~> 3.11.8' if RUBY_PLATFORM.downcase.include?("linux")
|
||||||
gem 'mongoid-encryptor', :require => 'mongoid/encryptor'
|
gem 'mongoid-encryptor', :require => 'mongoid/encryptor'
|
||||||
gem 'rb-readline','~> 0.4.2' if RUBY_PLATFORM.downcase.include?("linux")
|
gem 'rb-readline','~> 0.4.2' if RUBY_PLATFORM.downcase.include?("linux")
|
||||||
|
|
||||||
|
|
||||||
gem "impressionist",'1.2.0'
|
gem "impressionist", :git => 'git://github.com/charlotte-ruby/impressionist.git'
|
||||||
#gem 'contacts'
|
#gem 'contacts'
|
||||||
#gem 'event-calendar', :require => 'event_calendar'#, :git => 'git://github.com/elevation/event_calendar.git'
|
#gem 'event-calendar', :require => 'event_calendar'#, :git => 'git://github.com/elevation/event_calendar.git'
|
||||||
|
|
||||||
|
@ -69,6 +65,7 @@ gem 'redis-namespace'
|
||||||
gem 'redis-search'
|
gem 'redis-search'
|
||||||
gem 'syslog-logger'
|
gem 'syslog-logger'
|
||||||
gem "recaptcha", :require => "recaptcha/rails"
|
gem "recaptcha", :require => "recaptcha/rails"
|
||||||
|
gem 'mongoid-versioning'
|
||||||
|
|
||||||
# Gems used only for assets and not required
|
# Gems used only for assets and not required
|
||||||
# in production environments by default.
|
# in production environments by default.
|
||||||
|
|
|
@ -0,0 +1,409 @@
|
||||||
|
GIT
|
||||||
|
remote: git://github.com/amatsuda/kaminari.git
|
||||||
|
revision: 2e09b5374fec33b57c6387ca7bac89ecaa60c9eb
|
||||||
|
specs:
|
||||||
|
kaminari (0.14.1)
|
||||||
|
actionpack (>= 3.0.0)
|
||||||
|
activesupport (>= 3.0.0)
|
||||||
|
|
||||||
|
GIT
|
||||||
|
remote: git://github.com/charlotte-ruby/impressionist.git
|
||||||
|
revision: 0894f6a550a33f83f4937d655e9f0774521781e4
|
||||||
|
specs:
|
||||||
|
impressionist (1.2.0)
|
||||||
|
httpclient (~> 2.2)
|
||||||
|
nokogiri (~> 1.5)
|
||||||
|
|
||||||
|
GEM
|
||||||
|
remote: http://rubygems.org/
|
||||||
|
specs:
|
||||||
|
actionmailer (3.2.12)
|
||||||
|
actionpack (= 3.2.12)
|
||||||
|
mail (~> 2.4.4)
|
||||||
|
actionpack (3.2.12)
|
||||||
|
activemodel (= 3.2.12)
|
||||||
|
activesupport (= 3.2.12)
|
||||||
|
builder (~> 3.0.0)
|
||||||
|
erubis (~> 2.7.0)
|
||||||
|
journey (~> 1.0.4)
|
||||||
|
rack (~> 1.4.5)
|
||||||
|
rack-cache (~> 1.2)
|
||||||
|
rack-test (~> 0.6.1)
|
||||||
|
sprockets (~> 2.2.1)
|
||||||
|
activemodel (3.2.12)
|
||||||
|
activesupport (= 3.2.12)
|
||||||
|
builder (~> 3.0.0)
|
||||||
|
activerecord (3.2.12)
|
||||||
|
activemodel (= 3.2.12)
|
||||||
|
activesupport (= 3.2.12)
|
||||||
|
arel (~> 3.0.2)
|
||||||
|
tzinfo (~> 0.3.29)
|
||||||
|
activeresource (3.2.12)
|
||||||
|
activemodel (= 3.2.12)
|
||||||
|
activesupport (= 3.2.12)
|
||||||
|
activesupport (3.2.12)
|
||||||
|
i18n (~> 0.6)
|
||||||
|
multi_json (~> 1.0)
|
||||||
|
arel (3.0.2)
|
||||||
|
attr_required (0.0.5)
|
||||||
|
bcrypt-ruby (3.0.0)
|
||||||
|
binding_of_caller (0.7.1)
|
||||||
|
debug_inspector (>= 0.0.1)
|
||||||
|
bourne (1.1.2)
|
||||||
|
mocha (= 0.10.5)
|
||||||
|
brakeman (1.9.2)
|
||||||
|
erubis (~> 2.6)
|
||||||
|
fastercsv (~> 1.5)
|
||||||
|
haml (~> 3.0)
|
||||||
|
highline (~> 1.6)
|
||||||
|
multi_json (~> 1.2)
|
||||||
|
ruby2ruby (~> 2.0)
|
||||||
|
ruby_parser (~> 3.1.1)
|
||||||
|
sass (~> 3.0)
|
||||||
|
terminal-table (~> 1.4)
|
||||||
|
bson (1.8.2)
|
||||||
|
bson_ext (1.8.2)
|
||||||
|
bson (~> 1.8.2)
|
||||||
|
builder (3.0.4)
|
||||||
|
capybara (2.0.2)
|
||||||
|
mime-types (>= 1.16)
|
||||||
|
nokogiri (>= 1.3.3)
|
||||||
|
rack (>= 1.0.0)
|
||||||
|
rack-test (>= 0.5.4)
|
||||||
|
selenium-webdriver (~> 2.0)
|
||||||
|
xpath (~> 1.0.0)
|
||||||
|
carrierwave (0.6.2)
|
||||||
|
activemodel (>= 3.2.0)
|
||||||
|
activesupport (>= 3.2.0)
|
||||||
|
carrierwave-mongoid (0.2.2)
|
||||||
|
carrierwave (~> 0.6.1)
|
||||||
|
mongoid (~> 2.1)
|
||||||
|
childprocess (0.3.8)
|
||||||
|
ffi (~> 1.0, >= 1.0.11)
|
||||||
|
chinese_pinyin (0.4.1)
|
||||||
|
chronic (0.9.0)
|
||||||
|
coderay (1.0.9)
|
||||||
|
coffee-rails (3.2.2)
|
||||||
|
coffee-script (>= 2.2.0)
|
||||||
|
railties (~> 3.2.0)
|
||||||
|
coffee-script (2.2.0)
|
||||||
|
coffee-script-source
|
||||||
|
execjs
|
||||||
|
coffee-script-source (1.4.0)
|
||||||
|
columnize (0.3.6)
|
||||||
|
database_cleaner (0.9.1)
|
||||||
|
debug_inspector (0.0.2)
|
||||||
|
debugger (1.2.4)
|
||||||
|
columnize (>= 0.3.1)
|
||||||
|
debugger-linecache (~> 1.1.1)
|
||||||
|
debugger-ruby_core_source (~> 1.1.7)
|
||||||
|
debugger-linecache (1.1.2)
|
||||||
|
debugger-ruby_core_source (>= 1.1.1)
|
||||||
|
debugger-ruby_core_source (1.1.8)
|
||||||
|
delorean (2.1.0)
|
||||||
|
chronic
|
||||||
|
devise (1.5.3)
|
||||||
|
bcrypt-ruby (~> 3.0)
|
||||||
|
orm_adapter (~> 0.0.3)
|
||||||
|
warden (~> 1.1)
|
||||||
|
diff-lcs (1.1.3)
|
||||||
|
encrypted_strings (0.3.3)
|
||||||
|
erubis (2.7.0)
|
||||||
|
exception_notification (3.0.1)
|
||||||
|
actionmailer (>= 3.0.4)
|
||||||
|
execjs (1.4.0)
|
||||||
|
multi_json (~> 1.0)
|
||||||
|
factory_girl (4.2.0)
|
||||||
|
activesupport (>= 3.0.0)
|
||||||
|
factory_girl_rails (4.2.1)
|
||||||
|
factory_girl (~> 4.2.0)
|
||||||
|
railties (>= 3.0.0)
|
||||||
|
faker (1.1.2)
|
||||||
|
i18n (~> 0.5)
|
||||||
|
fastercsv (1.5.5)
|
||||||
|
fattr (2.2.1)
|
||||||
|
fb_graph (2.6.4)
|
||||||
|
httpclient (>= 2.2.0.2)
|
||||||
|
multi_json (>= 1.3)
|
||||||
|
rack-oauth2 (>= 0.14.4)
|
||||||
|
tzinfo
|
||||||
|
ffi (1.4.0)
|
||||||
|
haml (3.1.8)
|
||||||
|
highline (1.6.15)
|
||||||
|
hike (1.2.1)
|
||||||
|
httpclient (2.3.2)
|
||||||
|
i18n (0.6.1)
|
||||||
|
journey (1.0.4)
|
||||||
|
jquery-rails (2.1.4)
|
||||||
|
railties (>= 3.0, < 5.0)
|
||||||
|
thor (>= 0.14, < 2.0)
|
||||||
|
jquery-ui-rails (4.0.1)
|
||||||
|
jquery-rails
|
||||||
|
railties (>= 3.1.0)
|
||||||
|
json (1.7.7)
|
||||||
|
mail (2.4.4)
|
||||||
|
i18n (>= 0.4.0)
|
||||||
|
mime-types (~> 1.16)
|
||||||
|
treetop (~> 1.4.8)
|
||||||
|
metaclass (0.0.1)
|
||||||
|
method_source (0.8.1)
|
||||||
|
mime-types (1.21)
|
||||||
|
mini_magick (3.5.0)
|
||||||
|
subexec (~> 0.2.1)
|
||||||
|
mocha (0.10.5)
|
||||||
|
metaclass (~> 0.0.1)
|
||||||
|
mongo (1.8.2)
|
||||||
|
bson (~> 1.8.2)
|
||||||
|
mongo_session_store-rails3 (3.0.6)
|
||||||
|
actionpack (>= 3.0)
|
||||||
|
mongo
|
||||||
|
mongoid (2.6.0)
|
||||||
|
activemodel (~> 3.1)
|
||||||
|
mongo (~> 1.7)
|
||||||
|
tzinfo (~> 0.3.22)
|
||||||
|
mongoid-encryptor (0.0.5)
|
||||||
|
activesupport (~> 3.0)
|
||||||
|
encrypted_strings (~> 0.3.3)
|
||||||
|
mongoid (~> 2)
|
||||||
|
mongoid-tree (0.7.0)
|
||||||
|
mongoid (~> 2.0)
|
||||||
|
multi_json (1.6.1)
|
||||||
|
net-ldap (0.3.1)
|
||||||
|
nokogiri (1.5.6)
|
||||||
|
options (2.3.0)
|
||||||
|
fattr
|
||||||
|
orm_adapter (0.0.7)
|
||||||
|
polyglot (0.3.3)
|
||||||
|
pr_geohash (1.0.0)
|
||||||
|
progress_bar (0.4.0)
|
||||||
|
highline (~> 1.6.1)
|
||||||
|
options (~> 2.3.0)
|
||||||
|
pry (0.9.12)
|
||||||
|
coderay (~> 1.0.5)
|
||||||
|
method_source (~> 0.8)
|
||||||
|
slop (~> 3.4)
|
||||||
|
pry-debugger (0.2.1)
|
||||||
|
debugger (~> 1.2.0)
|
||||||
|
pry (~> 0.9.10)
|
||||||
|
pry-remote (0.1.6)
|
||||||
|
pry (~> 0.9)
|
||||||
|
slop (~> 3.0)
|
||||||
|
pry-stack_explorer (0.4.9)
|
||||||
|
binding_of_caller (>= 0.7)
|
||||||
|
pry (~> 0.9.11)
|
||||||
|
rack (1.4.5)
|
||||||
|
rack-cache (1.2)
|
||||||
|
rack (>= 0.4)
|
||||||
|
rack-gridfs (0.4.1)
|
||||||
|
mime-types
|
||||||
|
mongo (~> 1.2)
|
||||||
|
rack
|
||||||
|
rack-oauth2 (1.0.0)
|
||||||
|
activesupport (>= 2.3)
|
||||||
|
attr_required (>= 0.0.5)
|
||||||
|
httpclient (>= 2.2.0.2)
|
||||||
|
i18n
|
||||||
|
multi_json (>= 1.3.6)
|
||||||
|
rack (>= 1.1)
|
||||||
|
rack-protection (1.3.2)
|
||||||
|
rack
|
||||||
|
rack-ssl (1.3.3)
|
||||||
|
rack
|
||||||
|
rack-test (0.6.2)
|
||||||
|
rack (>= 1.0)
|
||||||
|
radius (0.7.3)
|
||||||
|
rails (3.2.12)
|
||||||
|
actionmailer (= 3.2.12)
|
||||||
|
actionpack (= 3.2.12)
|
||||||
|
activerecord (= 3.2.12)
|
||||||
|
activeresource (= 3.2.12)
|
||||||
|
activesupport (= 3.2.12)
|
||||||
|
bundler (~> 1.0)
|
||||||
|
railties (= 3.2.12)
|
||||||
|
railties (3.2.12)
|
||||||
|
actionpack (= 3.2.12)
|
||||||
|
activesupport (= 3.2.12)
|
||||||
|
rack-ssl (~> 1.3.2)
|
||||||
|
rake (>= 0.8.7)
|
||||||
|
rdoc (~> 3.4)
|
||||||
|
thor (>= 0.14.6, < 2.0)
|
||||||
|
rake (10.0.3)
|
||||||
|
rdoc (3.12.1)
|
||||||
|
json (~> 1.4)
|
||||||
|
redis (3.0.2)
|
||||||
|
redis-namespace (1.2.1)
|
||||||
|
redis (~> 3.0.0)
|
||||||
|
redis-search (0.9.0)
|
||||||
|
chinese_pinyin (>= 0.3.0)
|
||||||
|
redis (>= 2.1.1)
|
||||||
|
redis-namespace (>= 1.0.2)
|
||||||
|
resque (1.23.0)
|
||||||
|
multi_json (~> 1.0)
|
||||||
|
redis-namespace (~> 1.0)
|
||||||
|
sinatra (>= 0.9.2)
|
||||||
|
vegas (~> 0.1.2)
|
||||||
|
resque-restriction (0.3.0)
|
||||||
|
resque (>= 1.7.0)
|
||||||
|
resque-scheduler (2.0.0)
|
||||||
|
redis (>= 2.0.1)
|
||||||
|
resque (>= 1.20.0)
|
||||||
|
rufus-scheduler
|
||||||
|
rmmseg-cpp-huacnlee (0.2.9)
|
||||||
|
rsolr (1.0.8)
|
||||||
|
builder (>= 2.1.2)
|
||||||
|
rspec (2.12.0)
|
||||||
|
rspec-core (~> 2.12.0)
|
||||||
|
rspec-expectations (~> 2.12.0)
|
||||||
|
rspec-mocks (~> 2.12.0)
|
||||||
|
rspec-core (2.12.2)
|
||||||
|
rspec-expectations (2.12.1)
|
||||||
|
diff-lcs (~> 1.1.3)
|
||||||
|
rspec-mocks (2.12.2)
|
||||||
|
rspec-rails (2.12.2)
|
||||||
|
actionpack (>= 3.0)
|
||||||
|
activesupport (>= 3.0)
|
||||||
|
railties (>= 3.0)
|
||||||
|
rspec-core (~> 2.12.0)
|
||||||
|
rspec-expectations (~> 2.12.0)
|
||||||
|
rspec-mocks (~> 2.12.0)
|
||||||
|
ruby2ruby (2.0.3)
|
||||||
|
ruby_parser (~> 3.1)
|
||||||
|
sexp_processor (~> 4.0)
|
||||||
|
ruby_parser (3.1.1)
|
||||||
|
sexp_processor (~> 4.1)
|
||||||
|
rubyzip (0.9.9)
|
||||||
|
rufus-scheduler (2.0.17)
|
||||||
|
tzinfo (>= 0.3.23)
|
||||||
|
sass (3.2.5)
|
||||||
|
sass-rails (3.2.6)
|
||||||
|
railties (~> 3.2.0)
|
||||||
|
sass (>= 3.1.10)
|
||||||
|
tilt (~> 1.3)
|
||||||
|
select2-rails (3.3.1)
|
||||||
|
sass-rails (>= 3.2)
|
||||||
|
thor (~> 0.14)
|
||||||
|
selenium-webdriver (2.30.0)
|
||||||
|
childprocess (>= 0.2.5)
|
||||||
|
multi_json (~> 1.0)
|
||||||
|
rubyzip
|
||||||
|
websocket (~> 1.0.4)
|
||||||
|
sexp_processor (4.1.5)
|
||||||
|
shoulda-matchers (1.4.2)
|
||||||
|
activesupport (>= 3.0.0)
|
||||||
|
bourne (~> 1.1.2)
|
||||||
|
simplecov (0.7.1)
|
||||||
|
multi_json (~> 1.0)
|
||||||
|
simplecov-html (~> 0.7.1)
|
||||||
|
simplecov-html (0.7.1)
|
||||||
|
sinatra (1.3.4)
|
||||||
|
rack (~> 1.4)
|
||||||
|
rack-protection (~> 1.3)
|
||||||
|
tilt (~> 1.3, >= 1.3.3)
|
||||||
|
slop (3.4.3)
|
||||||
|
social-share-button (0.1.1)
|
||||||
|
spork (0.9.2)
|
||||||
|
sprockets (2.2.2)
|
||||||
|
hike (~> 1.2)
|
||||||
|
multi_json (~> 1.0)
|
||||||
|
rack (~> 1.0)
|
||||||
|
tilt (~> 1.1, != 1.3.0)
|
||||||
|
subexec (0.2.2)
|
||||||
|
sunspot (1.3.3)
|
||||||
|
pr_geohash (~> 1.0)
|
||||||
|
rsolr (~> 1.0.7)
|
||||||
|
sunspot-rails-tester (0.0.4)
|
||||||
|
sunspot_rails (~> 1.2)
|
||||||
|
sunspot_mongo (1.0.1)
|
||||||
|
sunspot_rails
|
||||||
|
sunspot_rails (1.3.3)
|
||||||
|
nokogiri
|
||||||
|
sunspot (= 1.3.3)
|
||||||
|
sunspot_solr (1.3.3)
|
||||||
|
syslog-logger (1.6.8)
|
||||||
|
terminal-table (1.4.5)
|
||||||
|
thor (0.17.0)
|
||||||
|
tilt (1.3.3)
|
||||||
|
tinymce-rails (3.5.8)
|
||||||
|
railties (>= 3.1.1)
|
||||||
|
treetop (1.4.12)
|
||||||
|
polyglot
|
||||||
|
polyglot (>= 0.3.1)
|
||||||
|
tzinfo (0.3.35)
|
||||||
|
uglifier (1.3.0)
|
||||||
|
execjs (>= 0.3.0)
|
||||||
|
multi_json (~> 1.0, >= 1.0.2)
|
||||||
|
vegas (0.1.11)
|
||||||
|
rack (>= 1.0.0)
|
||||||
|
warden (1.2.1)
|
||||||
|
rack (>= 1.0)
|
||||||
|
watchr (0.7)
|
||||||
|
websocket (1.0.7)
|
||||||
|
xpath (1.0.0)
|
||||||
|
nokogiri (~> 1.3)
|
||||||
|
|
||||||
|
PLATFORMS
|
||||||
|
ruby
|
||||||
|
|
||||||
|
DEPENDENCIES
|
||||||
|
brakeman
|
||||||
|
bson_ext
|
||||||
|
capybara
|
||||||
|
carrierwave
|
||||||
|
carrierwave-mongoid
|
||||||
|
chinese_pinyin (= 0.4.1)
|
||||||
|
coffee-rails
|
||||||
|
database_cleaner
|
||||||
|
debugger
|
||||||
|
delorean
|
||||||
|
devise (= 1.5.3)
|
||||||
|
exception_notification
|
||||||
|
execjs
|
||||||
|
factory_girl_rails
|
||||||
|
faker
|
||||||
|
fb_graph
|
||||||
|
impressionist!
|
||||||
|
jquery-rails (= 2.1.4)
|
||||||
|
jquery-ui-rails
|
||||||
|
kaminari!
|
||||||
|
mime-types
|
||||||
|
mini_magick
|
||||||
|
mongo_session_store-rails3 (= 3.0.6)
|
||||||
|
mongoid (> 2.1, < 3.0.0)
|
||||||
|
mongoid-encryptor
|
||||||
|
mongoid-tree
|
||||||
|
net-ldap (~> 0.3.1)
|
||||||
|
nokogiri
|
||||||
|
progress_bar
|
||||||
|
pry
|
||||||
|
pry-debugger
|
||||||
|
pry-remote
|
||||||
|
pry-stack_explorer
|
||||||
|
rack-gridfs
|
||||||
|
radius
|
||||||
|
rails (~> 3.2.9)
|
||||||
|
rake
|
||||||
|
redis (>= 2.1.1)
|
||||||
|
redis-namespace
|
||||||
|
redis-search
|
||||||
|
resque
|
||||||
|
resque-restriction
|
||||||
|
resque-scheduler
|
||||||
|
rmmseg-cpp-huacnlee (= 0.2.9)
|
||||||
|
rspec (~> 2.0)
|
||||||
|
rspec-rails (~> 2.0)
|
||||||
|
rubyzip
|
||||||
|
sass-rails
|
||||||
|
select2-rails (= 3.3.1)
|
||||||
|
shoulda-matchers
|
||||||
|
simplecov
|
||||||
|
sinatra
|
||||||
|
social-share-button
|
||||||
|
spork
|
||||||
|
sprockets
|
||||||
|
sunspot-rails-tester
|
||||||
|
sunspot_mongo
|
||||||
|
sunspot_solr
|
||||||
|
syslog-logger
|
||||||
|
tinymce-rails
|
||||||
|
uglifier
|
||||||
|
watchr
|
Binary file not shown.
Before Width: | Height: | Size: 11 KiB |
|
@ -15,11 +15,6 @@ function load_tinymce() {
|
||||||
theme_advanced_statusbar_location : "bottom",
|
theme_advanced_statusbar_location : "bottom",
|
||||||
theme_advanced_resizing : true,
|
theme_advanced_resizing : true,
|
||||||
|
|
||||||
// Domain Absolute URLs
|
|
||||||
relative_urls : false,
|
|
||||||
remove_script_host : false,
|
|
||||||
document_base_url: window.location.protocol + '//' + window.location.host,
|
|
||||||
|
|
||||||
// Skin options
|
// Skin options
|
||||||
skin : "o2k7",
|
skin : "o2k7",
|
||||||
skin_variant : "silver",
|
skin_variant : "silver",
|
||||||
|
|
|
@ -5,4 +5,3 @@
|
||||||
*= require_self
|
*= require_self
|
||||||
*= require social-share-button
|
*= require social-share-button
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -1,40 +0,0 @@
|
||||||
#acknowledgement {
|
|
||||||
display: none;
|
|
||||||
padding: 20px;
|
|
||||||
margin: -20px 0 30px 0;
|
|
||||||
background-color: #fff;
|
|
||||||
font-weight: bold;
|
|
||||||
font-size: 15px;
|
|
||||||
border: solid 2px #f0f0f0;
|
|
||||||
}
|
|
||||||
#aclnowledgement:after {
|
|
||||||
content: '';
|
|
||||||
display: table;
|
|
||||||
width: table;
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
|
|
||||||
.ask-question {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/* AQ form */
|
|
||||||
#new-ask-question {
|
|
||||||
background-color: #f8f8f8;
|
|
||||||
padding: 20px 0;
|
|
||||||
}
|
|
||||||
#new-ask-question .form-horizontal .control-label {
|
|
||||||
width: 100px;
|
|
||||||
}
|
|
||||||
#new-ask-question .form-horizontal .controls {
|
|
||||||
margin-left: 120px;
|
|
||||||
}
|
|
||||||
#new-ask-question .form-horizontal .controls textarea {
|
|
||||||
width: 80%;
|
|
||||||
resize: vertical;
|
|
||||||
}
|
|
||||||
#new-ask-question .form-horizontal .form-actions {
|
|
||||||
padding-left: 120px;
|
|
||||||
background-color: transparent;
|
|
||||||
border: none;
|
|
||||||
}
|
|
|
@ -1,38 +0,0 @@
|
||||||
class Admin::MailCronLogsController < OrbitBackendController
|
|
||||||
|
|
||||||
layout "new_admin"
|
|
||||||
before_filter :authenticate_user!
|
|
||||||
before_filter :is_admin?
|
|
||||||
|
|
||||||
def index
|
|
||||||
|
|
||||||
# @mail_cron_logs = MailCronLog.all.desc(:created_at).page(params[:page_main] ).per('20')
|
|
||||||
@mail_cron_logs = (params[:sort]) ? get_sorted_and_filtered("mail_cron_log") : get_viewable("mail_cron_log")
|
|
||||||
|
|
||||||
respond_to do |format|
|
|
||||||
format.html # index.html.erb
|
|
||||||
format.xml { render :xml => @mail_crons }
|
|
||||||
format.js
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
def destroy
|
|
||||||
@mail_cron_log = MailCronLog.find(params[:id])
|
|
||||||
@mail_cron_log.destroy
|
|
||||||
|
|
||||||
respond_to do |format|
|
|
||||||
format.html { redirect_to(admin_mail_cron_logs_url) }
|
|
||||||
# format.xml { head :ok }
|
|
||||||
format.js
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def delete
|
|
||||||
if params[:ids]
|
|
||||||
mail_cron_logs = MailCronLog.any_in(:_id => params[:ids]).destroy_all
|
|
||||||
end
|
|
||||||
redirect_to admin_mail_cron_logs_url(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options])
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
|
@ -1,126 +0,0 @@
|
||||||
class Admin::MailCronsController < OrbitBackendController
|
|
||||||
|
|
||||||
layout "new_admin"
|
|
||||||
before_filter :authenticate_user!
|
|
||||||
before_filter :is_admin?
|
|
||||||
|
|
||||||
def index
|
|
||||||
|
|
||||||
# @mail_crons = MailCron.all.asc(:mail_sentdate).page(params[:page_main] ).per('20')
|
|
||||||
@mail_crons = (params[:sort]) ? get_sorted_and_filtered("mail_cron") : get_viewable("mail_cron")
|
|
||||||
|
|
||||||
respond_to do |format|
|
|
||||||
format.html # index.html.erb
|
|
||||||
format.xml { render :xml => @mail_crons }
|
|
||||||
format.js
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
def show
|
|
||||||
end
|
|
||||||
|
|
||||||
def new
|
|
||||||
@mail_cron = MailCron.new
|
|
||||||
|
|
||||||
respond_to do |format|
|
|
||||||
format.html # new.html.erb
|
|
||||||
format.xml { render :xml => @mail_cron }
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def create
|
|
||||||
@mail_cron = MailCron.new(params[:mail_cron])
|
|
||||||
|
|
||||||
@mail_cron.create_user_id = current_user.id
|
|
||||||
@mail_cron.update_user_id = current_user.id
|
|
||||||
|
|
||||||
respond_to do |format|
|
|
||||||
if @mail_cron.save
|
|
||||||
format.html { redirect_to(admin_mail_crons_url) }
|
|
||||||
format.xml { render :xml => @mail_cron, :status => :created, :location => @mail_cron }
|
|
||||||
else
|
|
||||||
format.html { render :action => "new" }
|
|
||||||
format.xml { render :xml => @mail_cron.errors, :status => :unprocessable_entity }
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def edit
|
|
||||||
@mail_cron = MailCron.find(params[:id])
|
|
||||||
end
|
|
||||||
|
|
||||||
def update
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@datas = MailCron.where(:mail_sentdate.lte => Time.now, :mail_sent => false)
|
|
||||||
|
|
||||||
@datas.each do |mail_data|
|
|
||||||
|
|
||||||
@mail_j = 0
|
|
||||||
@read_mails = Array.new
|
|
||||||
|
|
||||||
@mails = mail_data.mail_to.split(",")
|
|
||||||
|
|
||||||
@mails.each do |send_mail|
|
|
||||||
|
|
||||||
@read_mails << send_mail
|
|
||||||
|
|
||||||
@mail_j += 1
|
|
||||||
|
|
||||||
if 0 == @mail_j % 30
|
|
||||||
MailCronMailer.cron_mail( mail_data.id, @read_mails.join(',') ).deliver
|
|
||||||
@read_mails = Array.new
|
|
||||||
|
|
||||||
sleep 10
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
if !@read_mails.join(',').blank?
|
|
||||||
MailCronMailer.cron_mail( mail_data.id, @read_mails.join(',') ).deliver
|
|
||||||
@read_mails = Array.new
|
|
||||||
|
|
||||||
sleep 10
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
@mail_cron = MailCron.find(params[:id])
|
|
||||||
|
|
||||||
@mail_cron.update_user_id = current_user.id
|
|
||||||
|
|
||||||
respond_to do |format|
|
|
||||||
if @mail_cron.update_attributes(params[:mail_cron])
|
|
||||||
format.html { redirect_to(admin_mail_crons_url) }
|
|
||||||
format.js { render 'toggle_enable' }
|
|
||||||
format.xml { head :ok }
|
|
||||||
else
|
|
||||||
format.html { render :action => "edit" }
|
|
||||||
format.xml { render :xml => @mail_cron.errors, :status => :unprocessable_entity }
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def destroy
|
|
||||||
@mail_cron = MailCron.find(params[:id])
|
|
||||||
@mail_cron.destroy
|
|
||||||
|
|
||||||
respond_to do |format|
|
|
||||||
format.html { redirect_to(admin_mail_crons_url) }
|
|
||||||
# format.xml { head :ok }
|
|
||||||
format.js
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def delete
|
|
||||||
if params[:ids]
|
|
||||||
mail_crons = MailCron.any_in(:_id => params[:ids]).destroy_all
|
|
||||||
end
|
|
||||||
redirect_to admin_mail_crons_url(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options])
|
|
||||||
end
|
|
||||||
|
|
||||||
protected
|
|
||||||
|
|
||||||
end
|
|
|
@ -1,7 +1,5 @@
|
||||||
class Admin::UserActionsController < OrbitBackendController
|
class Admin::UserActionsController < OrbitBackendController
|
||||||
layout "new_admin"
|
|
||||||
before_filter :authenticate_user!
|
|
||||||
before_filter :is_admin?
|
|
||||||
def index
|
def index
|
||||||
@user_actions = UserAction.all
|
@user_actions = UserAction.all
|
||||||
end
|
end
|
||||||
|
|
|
@ -11,21 +11,23 @@ class DefaultWidgetController< OrbitWidgetController
|
||||||
end
|
end
|
||||||
|
|
||||||
def query_for_default_widget
|
def query_for_default_widget
|
||||||
|
|
||||||
@ori_class_name = @default_widget["query"].split('.')[0]
|
@ori_class_name = @default_widget["query"].split('.')[0]
|
||||||
@result = eval(@default_widget["query"])
|
result = nil
|
||||||
|
result_objects = nil
|
||||||
|
|
||||||
if !params["tag_id"].blank?
|
if !params["tag_id"].blank?
|
||||||
if params["category_id"].blank? #has tag no cate
|
if params["category_id"].blank? #has tag no cate
|
||||||
@result.selector[:tagged_ids] = { "$in" => params['tag_id'] }
|
result = @ori_class_name.constantize.where(:tagged_ids.in => params["tag_id"])
|
||||||
else #has tag and cate
|
else #has tag and cate
|
||||||
@result.selector[get_category_field_name] = { "$in" => params['category_id'].collect{|t| BSON::ObjectId(t)}}
|
result = eval("#{@ori_class_name}.where(:#{get_category_field_name(@ori_class_name)}.in=>params['category_id'], :tagged_ids.in => params['tag_id'])")
|
||||||
@result.selector[:tagged_ids] = { "$in" => params['tag_id'] }
|
|
||||||
end
|
end
|
||||||
elsif params["category_id"].blank? #no tag no cate
|
elsif params["category_id"].blank? #no tag no cate
|
||||||
|
result = eval(@default_widget["query"])
|
||||||
else #no tag has cate
|
else #no tag has cate
|
||||||
|
result = eval("#{@ori_class_name}.where(:#{get_category_field_name(@ori_class_name)}.in=>params['category_id'])")
|
||||||
@result.selector[get_category_field_name] = { "$in" => params['category_id'].collect{|t| BSON::ObjectId(t)}}
|
|
||||||
end
|
end
|
||||||
eval("@result.#{@default_widget[:sorting_query]}")
|
result.available_for_lang(I18n.locale).can_display.desc(:is_top, :postdate)
|
||||||
end
|
end
|
||||||
|
|
||||||
def search_result
|
def search_result
|
||||||
|
@ -38,13 +40,9 @@ class DefaultWidgetController< OrbitWidgetController
|
||||||
|
|
||||||
def default_widget
|
def default_widget
|
||||||
@search = params["search_query"].blank? ? false : true
|
@search = params["search_query"].blank? ? false : true
|
||||||
if !params[:id].blank? and !params["clicked_field_name"].blank?
|
if !params[:id].blank?
|
||||||
clicked_field_name = params["clicked_field_name"].to_sym
|
clicked_field_name = params["clicked_field_name"].to_sym
|
||||||
redirect_to eval("#{@page_part.module_app.widget_fields_link_method[clicked_field_name][:method]}('#{params[:id]}', {inner: #{params[:inner] || true}})")
|
redirect_to eval("#{@page_part.module_app.widget_fields_link_method[clicked_field_name][:method]}('#{params[:id]}', {inner: #{params[:inner] || true}})")
|
||||||
elsif !params[:id].blank? and params["preview"]
|
|
||||||
clicked_field_name = :title
|
|
||||||
@preview_pages = @page_part.module_app.widget_fields_link_method.find_all{|t| t[1].has_key?(:preview)}.collect{|t| t[0]}
|
|
||||||
redirect_to eval("#{@page_part.module_app.widget_fields_link_method[clicked_field_name][:method]}('#{params[:id]}', {preview: true,inner: #{params[:inner] || true},clicked_field_name: '#{@preview_pages.first.to_s}'})")
|
|
||||||
else
|
else
|
||||||
@tag_class = nil
|
@tag_class = nil
|
||||||
@default_widget = @page_part.module_app.get_default_widget
|
@default_widget = @page_part.module_app.get_default_widget
|
||||||
|
@ -92,10 +90,10 @@ class DefaultWidgetController< OrbitWidgetController
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def get_category_field_name
|
def get_category_field_name()
|
||||||
@ori_class_name = @ori_class_name.constantize unless @ori_class_name.is_a? Class
|
@ori_class_name = @ori_class_name.constantize
|
||||||
@ori_class_name.fields.each_key do |key|
|
@ori_class_name.fields.each_key do |key|
|
||||||
return key.to_s if key.include?('category_id')
|
return key if key.include?('category_id')
|
||||||
end
|
end
|
||||||
nil
|
nil
|
||||||
end
|
end
|
||||||
|
|
|
@ -43,7 +43,7 @@ class MobileController < ApplicationController
|
||||||
|
|
||||||
def page
|
def page
|
||||||
@page_title = t('mobile.page')
|
@page_title = t('mobile.page')
|
||||||
@page_contexts = get_sorted_page_from_structure
|
@page_contexts = PageContext.where(:archived => false).page(params[:page_main]).per(15)
|
||||||
end
|
end
|
||||||
|
|
||||||
def page_content
|
def page_content
|
||||||
|
@ -57,12 +57,4 @@ class MobileController < ApplicationController
|
||||||
@no_footer = true if request.path =~ /app/
|
@no_footer = true if request.path =~ /app/
|
||||||
end
|
end
|
||||||
|
|
||||||
def get_sorted_page_from_structure
|
|
||||||
page_contexts = Item.structure_ordered_items.inject([]){ |pages, page|
|
|
||||||
pages << page.page_contexts.where(archived: false).limit(1)[0] if page.is_a?(Page) && !page.page_contexts.blank?
|
|
||||||
pages
|
|
||||||
}
|
|
||||||
Kaminari.paginate_array(page_contexts).page(params[:page]).per(15)
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -7,10 +7,4 @@ class OrbitFrontendComponentController< ApplicationController
|
||||||
@app_title = request.fullpath.split('/')[2]
|
@app_title = request.fullpath.split('/')[2]
|
||||||
end
|
end
|
||||||
|
|
||||||
def delay_impressionist(item)
|
|
||||||
user_id = current_user.nil? ? nil : current_user.id
|
|
||||||
Resque.enqueue(DelayedImpressionist,:request=>DelayImpressionistRequest.new(request),:obj=>item,:class=>item.class.to_s,:controller_name=>controller_name,:action_name=>action_name,:user=>user_id)
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
end
|
end
|
|
@ -45,12 +45,28 @@ class PagesController < ApplicationController
|
||||||
#end
|
#end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def convert_array_param(key,array)
|
||||||
|
array.collect{|t| "#{key}[]=#{t}"}.join("&")
|
||||||
|
end
|
||||||
|
|
||||||
def index_from_link
|
def index_from_link
|
||||||
url = "/#{@item.path}"
|
url = "/#{@item.path}"
|
||||||
options = ''
|
options = ''
|
||||||
options << "#{options.blank? ? '?' : '&'}page_main=#{params[:page_main]}" unless params[:page_main].blank?
|
options << "#{options.blank? ? '?' : '&'}page_main=#{params[:page_main]}" unless params[:page_main].blank?
|
||||||
|
|
||||||
|
if params[:category_id].is_a? Array
|
||||||
options << "#{options.blank? ? '?' : '&'}#{convert_array_param('category_id',params[:category_id])}" unless params[:category_id].blank?
|
options << "#{options.blank? ? '?' : '&'}#{convert_array_param('category_id',params[:category_id])}" unless params[:category_id].blank?
|
||||||
|
elsif params[:category_id].is_a? String
|
||||||
|
options << "#{options.blank? ? '?' : '&'}category_id=#{params[:category_id]}" unless params[:category_id].blank?
|
||||||
|
end
|
||||||
|
|
||||||
|
if params[:tag_id].is_a? Array
|
||||||
options << "#{options.blank? ? '?' : '&'}#{convert_array_param('tag_id',params[:tag_id])}" unless params[:tag_id].blank?
|
options << "#{options.blank? ? '?' : '&'}#{convert_array_param('tag_id',params[:tag_id])}" unless params[:tag_id].blank?
|
||||||
|
elsif params[:category_id].is_a? String
|
||||||
|
options << "#{options.blank? ? '?' : '&'}tag_id=#{params[:tag_id]}" unless params[:tag_id].blank?
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
options << "#{options.blank? ? '?' : '&'}search_query=#{params[:search_query]}" unless params[:search_query].blank?
|
options << "#{options.blank? ? '?' : '&'}search_query=#{params[:search_query]}" unless params[:search_query].blank?
|
||||||
options << "#{options.blank? ? '?' : '&'}name=#{params[:name]}" unless params[:name].blank?
|
options << "#{options.blank? ? '?' : '&'}name=#{params[:name]}" unless params[:name].blank?
|
||||||
uri = URI::escape(url + options)
|
uri = URI::escape(url + options)
|
||||||
|
@ -62,8 +78,8 @@ class PagesController < ApplicationController
|
||||||
url = "/#{@item.path}"
|
url = "/#{@item.path}"
|
||||||
options = ''
|
options = ''
|
||||||
options << "#{options.blank? ? '?' : '&'}id=#{params[:id]}" unless params[:id].blank?
|
options << "#{options.blank? ? '?' : '&'}id=#{params[:id]}" unless params[:id].blank?
|
||||||
options << "#{options.blank? ? '?' : '&'}#{convert_array_param('category_id', params[:category_id])}" unless params[:category_id].blank?
|
options << "#{options.blank? ? '?' : '&'}category_id=#{params[:category_id]}" unless params[:category_id].blank?
|
||||||
options << "#{options.blank? ? '?' : '&'}#{convert_array_param('tag_id', params[:tag_id])}" unless params[:tag_id].blank?
|
options << "#{options.blank? ? '?' : '&'}tag_id=#{params[:tag_id]}" unless params[:tag_id].blank?
|
||||||
options << "#{options.blank? ? '?' : '&'}preview=#{params[:preview]}" unless params[:preview].blank?
|
options << "#{options.blank? ? '?' : '&'}preview=#{params[:preview]}" unless params[:preview].blank?
|
||||||
options << "#{options.blank? ? '?' : '&'}controller_action=#{params[:controller_action]}" unless params[:controller_action].blank?
|
options << "#{options.blank? ? '?' : '&'}controller_action=#{params[:controller_action]}" unless params[:controller_action].blank?
|
||||||
options << "#{options.blank? ? '?' : '&'}clicked_field_name=#{params[:clicked_field_name]}" unless params[:clicked_field_name].blank?
|
options << "#{options.blank? ? '?' : '&'}clicked_field_name=#{params[:clicked_field_name]}" unless params[:clicked_field_name].blank?
|
||||||
|
@ -82,41 +98,21 @@ class PagesController < ApplicationController
|
||||||
elsif params[:same_page_id]
|
elsif params[:same_page_id]
|
||||||
@item = Item.find(params[:same_page_id])
|
@item = Item.find(params[:same_page_id])
|
||||||
else
|
else
|
||||||
category_ids = Array(params[:category_id]) unless params[:category_id].nil?
|
category_ids = params[:category_id].is_a?(Array) ? params[:category_id] : [params[:category_id]]
|
||||||
tag_ids = Array(params[:tag_id]) unless params[:tag_id].nil?
|
tag_ids = params[:tag_id].is_a?(Array) ? params[:tag_id] : [params[:tag_id]]
|
||||||
module_app = ModuleApp.first(:conditions => {:key => params[:app_name]})
|
module_app = ModuleApp.first(:conditions => {:key => params[:app_name]})
|
||||||
|
|
||||||
default_query = { is_published: true, module_app_id: module_app.id, :app_frontend_url.in => [params[:app_action], 'default_widget'] }
|
|
||||||
specific_categories = { :category => category_ids }
|
|
||||||
in_categories = { :category.in => category_ids }
|
|
||||||
nil_categories = { :category.in => [nil, []] }
|
|
||||||
specific_tags = { :tag => tag_ids }
|
|
||||||
in_tags = { :tag.in => tag_ids }
|
|
||||||
nil_tags = { :tag.in => [nil, []] }
|
|
||||||
|
|
||||||
if !category_ids.blank? && !tag_ids.blank?
|
if !category_ids.blank? && !tag_ids.blank?
|
||||||
@item = Item.where(default_query.merge(specific_categories).merge(specific_tags)).first
|
@item = Item.first(:conditions => {:module_app_id => module_app.id, :app_frontend_url => params[:app_action], :category.in => category_ids, :tag.in => tag_ids})
|
||||||
@item = Item.where(default_query.merge(specific_categories).merge(in_tags)).first unless @item
|
@item = Item.first(:conditions => {:module_app_id => module_app.id, :app_frontend_url => params[:app_action], :category.in => category_ids, :tag.in => [nil, []]}) unless @item
|
||||||
@item = Item.where(default_query.merge(specific_categories).merge(nil_tags)).first unless @item
|
|
||||||
@item = Item.where(default_query.merge(specific_tags).merge(in_categories)).first unless @item
|
|
||||||
@item = Item.where(default_query.merge(specific_tags).merge(nil_categories)).first unless @item
|
|
||||||
@item = Item.where(default_query.merge(in_categories).merge(in_tags)).first unless @item
|
|
||||||
@item = Item.where(default_query.merge(in_categories).merge(nil_tags)).first unless @item
|
|
||||||
@item = Item.where(default_query.merge(in_tags).merge(nil_categories)).first unless @item
|
|
||||||
elsif !category_ids.blank?
|
elsif !category_ids.blank?
|
||||||
@item = Item.where(default_query.merge(specific_categories).merge(nil_tags)).first
|
@item = Item.where(module_app_id: module_app.id, app_frontend_url: params[:app_action], :category.in => category_ids).any_in(tag: [nil, []]).first
|
||||||
@item = Item.where(default_query.merge(specific_categories)).first unless @item
|
|
||||||
@item = Item.where(default_query.merge(in_categories).merge(nil_tags)).first unless @item
|
|
||||||
@item = Item.where(default_query.merge(in_categories)).first unless @item
|
|
||||||
elsif !tag_ids.blank?
|
elsif !tag_ids.blank?
|
||||||
@item = Item.where(default_query.merge(specific_tags).merge(nil_categories)).first
|
@item = Item.where(module_app_id: module_app.id, app_frontend_url: params[:app_action], :tag.in => tag_ids).any_in(category: [nil, []]).first
|
||||||
@item = Item.where(default_query.merge(specific_tags)).first unless @item
|
|
||||||
@item = Item.where(default_query.merge(in_tags).merge(nil_categories)).first unless @item
|
|
||||||
@item = Item.where(default_query.merge(in_tags)).first unless @item
|
|
||||||
end
|
end
|
||||||
@item = Item.find(params[:orig_page]) unless @item || params[:orig_page].blank?
|
@item = Item.find(params[:orig_page]) unless @item || params[:orig_page].blank?
|
||||||
@item = Item.where(default_query.merge(nil_categories).merge(nil_tags)).first unless @item
|
@item = Item.where(module_app_id: module_app.id, app_frontend_url: params[:app_action]).all_of("tag" => {"$in" => [nil, []]},"category" => { "$in" => [nil, []]}).first unless @item
|
||||||
@item = Item.where(default_query).first unless @item
|
@item = Item.where(module_app_id: module_app.id, app_frontend_url: 'default_widget').first unless @item
|
||||||
|
@item = Item.where(module_app_id: module_app.id, app_frontend_url: params[:app_action]).first unless @item
|
||||||
end
|
end
|
||||||
raise PageError,'Missing Frontend Page' if @item.nil?
|
raise PageError,'Missing Frontend Page' if @item.nil?
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
module ApplicationHelper
|
module ApplicationHelper
|
||||||
include OrbitApp::Module::VisitorCounter
|
|
||||||
FLASH_NOTICE_KEYS = [:error, :notice, :warning]
|
FLASH_NOTICE_KEYS = [:error, :notice, :warning]
|
||||||
|
|
||||||
|
|
||||||
|
@ -7,9 +7,8 @@ module ApplicationHelper
|
||||||
request.referer.include?('?') ? [request.referer,param_hash.to_param].join('&') : [request.referer,param_hash.to_param].join('?')
|
request.referer.include?('?') ? [request.referer,param_hash.to_param].join('&') : [request.referer,param_hash.to_param].join('?')
|
||||||
end
|
end
|
||||||
|
|
||||||
def delayed_impressionist(item)
|
def delayed_impressionist(object)
|
||||||
user_id = current_user.nil? ? nil : current_user.id
|
# Resque.enqueue_at(1.minute.from_now,DelayedImpressionist,object)
|
||||||
Resque.enqueue(DelayedImpressionist,:request=>DelayImpressionistRequest.new(request),:obj=>item,:class=>item.class.to_s,:controller_name=>controller_name,:action_name=>action_name,:user=>user_id)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def check_user_role_enable(attribute_fields)
|
def check_user_role_enable(attribute_fields)
|
||||||
|
@ -243,27 +242,25 @@ module ApplicationHelper
|
||||||
"#{t(:view_count)}: #{object.view_count}"
|
"#{t(:view_count)}: #{object.view_count}"
|
||||||
end
|
end
|
||||||
|
|
||||||
# def display_visitors(options={})
|
def display_visitors(options={})
|
||||||
# # Impression.where(options).and(:referrer.ne => nil).distinct(:session_hash).count
|
Impression.where(options).and(:referrer.ne => nil).distinct(:session_hash).count
|
||||||
# impressions = Impression.where(options).and(:referrer.ne => nil)
|
end
|
||||||
# impressions.map{|i| i[:session_hash]}.uniq.count
|
|
||||||
# end
|
|
||||||
|
|
||||||
# def display_visitors_today
|
def display_visitors_today
|
||||||
# display_visitors(created_at: {'$gte' => Date.today.beginning_of_day, '$lte' => Date.today.end_of_day})
|
display_visitors(created_at: {'$gte' => Date.today.beginning_of_day, '$lte' => Date.today.end_of_day})
|
||||||
# end
|
end
|
||||||
|
|
||||||
# def display_visitors_this_week
|
def display_visitors_this_week
|
||||||
# display_visitors(created_at: {'$gte' => Date.today.beginning_of_week, '$lte' => Date.today.end_of_week})
|
display_visitors(created_at: {'$gte' => Date.today.beginning_of_week, '$lte' => Date.today.end_of_week})
|
||||||
# end
|
end
|
||||||
|
|
||||||
# def display_visitors_this_month
|
def display_visitors_this_month
|
||||||
# display_visitors(created_at: {'$gte' => Date.today.beginning_of_month, '$lte' => Date.today.end_of_month})
|
display_visitors(created_at: {'$gte' => Date.today.beginning_of_month, '$lte' => Date.today.end_of_month})
|
||||||
# end
|
end
|
||||||
|
|
||||||
# def display_visitors_this_year
|
def display_visitors_this_year
|
||||||
# display_visitors(created_at: {'$gte' => Date.today.beginning_of_year, '$lte' => Date.today.end_of_year})
|
display_visitors(created_at: {'$gte' => Date.today.beginning_of_year, '$lte' => Date.today.end_of_year})
|
||||||
# end
|
end
|
||||||
|
|
||||||
def display_date_time(object)
|
def display_date_time(object)
|
||||||
object.strftime("%Y-%m-%d %H:%M")
|
object.strftime("%Y-%m-%d %H:%M")
|
||||||
|
@ -314,8 +311,4 @@ module ApplicationHelper
|
||||||
link_to title, params.merge({direction: direction, sort: column, sort_options: column}), {:class => "#{css_class} sortable", :remote => options[:remote]}
|
link_to title, params.merge({direction: direction, sort: column, sort_options: column}), {:class => "#{css_class} sortable", :remote => options[:remote]}
|
||||||
end
|
end
|
||||||
|
|
||||||
def convert_array_param(key, array)
|
|
||||||
Array(array).collect{|t| "#{key}[]=#{t}"}.join("&")
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -3,13 +3,6 @@ module DefaultWidgetHelper
|
||||||
I18n.t("#{@page_part.module_app.key}.default_widget.#{field}")
|
I18n.t("#{@page_part.module_app.key}.default_widget.#{field}")
|
||||||
end
|
end
|
||||||
|
|
||||||
def get_top_hot_class(row_data)
|
|
||||||
class_attr = []
|
|
||||||
class_attr << 'data_is_hot' if( row_data.is_hot? rescue false )
|
|
||||||
class_attr << 'data_is_top' if( row_data.is_top? rescue false)
|
|
||||||
return class_attr.join(" ")
|
|
||||||
end
|
|
||||||
|
|
||||||
def link_to_field(row_data,field, switch, options=nil)
|
def link_to_field(row_data,field, switch, options=nil)
|
||||||
method_ary = @page_part.module_app.widget_fields_link_method
|
method_ary = @page_part.module_app.widget_fields_link_method
|
||||||
field = field.to_sym
|
field = field.to_sym
|
||||||
|
@ -84,13 +77,4 @@ module DefaultWidgetHelper
|
||||||
content_tag(:span,get_display(row_data,field_setting),:class=>field_setting[:class])
|
content_tag(:span,get_display(row_data,field_setting),:class=>field_setting[:class])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def get_row_category(row_data)
|
|
||||||
row_data.send("#{row_data.class.to_s.underscore}_category_id") rescue nil
|
|
||||||
end
|
|
||||||
|
|
||||||
def get_row_tags(row_data)
|
|
||||||
row_data.tagged_ids rescue nil
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
|
@ -2,24 +2,16 @@ class BackupServer
|
||||||
@queue = :high
|
@queue = :high
|
||||||
|
|
||||||
def self.perform()
|
def self.perform()
|
||||||
|
#CronMail.time_check("Going to backup Orbit").deliver
|
||||||
dbhost = Mongoid.config.database.connection.primary.join ':'
|
dbhost = Mongoid.config.database.connection.primary.join ':'
|
||||||
dbname = Mongoid.config.database.name
|
dbname = Mongoid.config.database.name
|
||||||
archive_db_list_path = OrbitSystemPreference::ArchiveDbListPath
|
archive_db_list_path = OrbitSystemPreference::ArchiveDbListPath
|
||||||
dbdirectory = "#{Rails.root}/tmp/#{dbname}-"+Time.now.strftime("%Y-%m-%d-%H-%M")
|
dbdirectory = "#{Rails.root}/tmp/#{dbname}-"+Time.now.strftime("%Y-%m-%d-%H-%M")
|
||||||
%x[mongodump -h #{dbhost} -d #{dbname} -o #{dbdirectory} ]
|
%x[mongodump -h #{dbhost} -d #{dbname} -o #{dbdirectory} ]
|
||||||
|
|
||||||
Dir.foreach('tmp') do |item|
|
%x[rm #{archive_db_list_path}]
|
||||||
date_str = item.to_s.gsub("#{dbname}-",'')
|
%x[ls #{Rails.root}/tmp/#{dbname}* | du -h --max-depth=1 --block-size=1M |sort -h >> #{archive_db_list_path}]
|
||||||
next if not date_str.match(/\d{4}-\d{2}-\d{2}-\d{2}-\d{2}/)
|
|
||||||
if Date.parse(date_str).to_time < Site.first.backup_keep_for_days.days.ago
|
|
||||||
OrbitLogger.info "Deleting #{date_str}"
|
|
||||||
%x[rm -rf tmp/#{item}]
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
%x[rm -f #{archive_db_list_path}]
|
|
||||||
%x[cd tmp ; ls -l |grep #{dbname} | awk '{print $8}'|xargs du -h --block-size=1M --max-depth=0 |sort -h >> #{archive_db_list_path}]
|
|
||||||
OrbitLogger.info "DB backup done Path:#{dbdirectory}"
|
OrbitLogger.info "DB backup done Path:#{dbdirectory}"
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,21 +1,36 @@
|
||||||
class DashboardCounter < Resque::Plugins::RestrictionJob
|
class DashboardCounter < Resque::Plugins::RestrictionJob
|
||||||
extend OrbitApp::Module::VisitorCounterEval
|
|
||||||
|
|
||||||
@queue = :high
|
@queue = :high
|
||||||
|
|
||||||
def self.perform(*args)
|
def self.perform(*args)
|
||||||
site = Site.first
|
site = Site.first
|
||||||
obj = new(*args)
|
obj = new(*args)
|
||||||
site.visitor_counters[:total] = display_visitors
|
site.dashboard_counter[:visitors_this_week] = obj.display_visitors_this_week
|
||||||
site.visitor_counters[:today] = display_visitors_today
|
site.dashboard_counter[:visitors_this_month] = obj.display_visitors_this_month
|
||||||
site.visitor_counters[:this_week] = display_visitors_this_week
|
site.dashboard_counter[:visitors_this_year] = obj.display_visitors_this_year
|
||||||
site.visitor_counters[:this_month] = display_visitors_this_month
|
|
||||||
site.visitor_counters[:this_year] = display_visitors_this_year
|
|
||||||
site.save
|
site.save
|
||||||
OrbitLogger.info "DashboardCounter done #{site.visitor_counters.to_s}"
|
OrbitLogger.info "DashboardCounter done #{site.dashboard_counter.to_s}"
|
||||||
|
end
|
||||||
|
|
||||||
#Notice this is mainly used at user dashbroad. however the code there is currentlly using realtime evaluation.
|
|
||||||
#and the site model will need a field call dashboard_counter to complete this job.
|
def display_visitors(options={})
|
||||||
|
impressions = Impression.where(options).and(:referrer.ne => nil)
|
||||||
|
impressions.map{|i| i[:session_hash]}.uniq.count
|
||||||
|
end
|
||||||
|
|
||||||
|
def display_visitors_today
|
||||||
|
display_visitors(created_at: {'$gte' => Date.today.beginning_of_day, '$lte' => Date.today.end_of_day})
|
||||||
|
end
|
||||||
|
|
||||||
|
def display_visitors_this_week
|
||||||
|
display_visitors(created_at: {'$gte' => Date.today.beginning_of_week, '$lte' => Date.today.end_of_week})
|
||||||
|
end
|
||||||
|
|
||||||
|
def display_visitors_this_month
|
||||||
|
display_visitors(created_at: {'$gte' => Date.today.beginning_of_month, '$lte' => Date.today.end_of_month})
|
||||||
|
end
|
||||||
|
|
||||||
|
def display_visitors_this_year
|
||||||
|
display_visitors(created_at: {'$gte' => Date.today.beginning_of_year, '$lte' => Date.today.end_of_year})
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,51 +1,7 @@
|
||||||
class DelayedImpressionist
|
class DelayedImpressionist
|
||||||
def self.before_filter(*args)
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
include ImpressionistController::InstanceMethods
|
|
||||||
@queue = :low
|
@queue = :low
|
||||||
|
def self.perform(object)
|
||||||
def initialize(request,controller_name,action_name,user,obj)
|
impressionist(object)
|
||||||
@controller_name = controller_name
|
true
|
||||||
@action_name = action_name
|
|
||||||
@user = User.find user unless user.nil?
|
|
||||||
@request = request
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.perform(*args)
|
|
||||||
arg = args[0]
|
|
||||||
@request= DelayImpressionistRequest.new
|
|
||||||
@request.restore(arg["request"])
|
|
||||||
obj = eval("#{arg["class"]}.find '#{arg['obj']['_id']}'")
|
|
||||||
# imp = new(@request,arg["controller_name"],arg["action_name"],arg["user"],obj)
|
|
||||||
new_impression = obj.impressions.build(:user_id=>arg["user"],:controller_name=>arg["controller_name"],:action_name=>arg["action_name"],:ip_address=>@request.remote_ip,:referrer=>@request.referer)
|
|
||||||
@try = 1
|
|
||||||
loop do
|
|
||||||
result = new_impression.save rescue false
|
|
||||||
break if (result || @try >= 10)
|
|
||||||
@try = @try + 1
|
|
||||||
puts "trying:#{@try}"
|
|
||||||
end
|
|
||||||
new_impression.save
|
|
||||||
obj.update_attribute(:view_count,obj.impression_count)
|
|
||||||
end
|
|
||||||
|
|
||||||
private
|
|
||||||
def user
|
|
||||||
@user
|
|
||||||
end
|
|
||||||
|
|
||||||
def action_name
|
|
||||||
@action_name
|
|
||||||
end
|
|
||||||
|
|
||||||
def controller_name
|
|
||||||
@controller_name
|
|
||||||
end
|
|
||||||
|
|
||||||
def request
|
|
||||||
@request
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
|
@ -1,42 +0,0 @@
|
||||||
class EmailCron
|
|
||||||
@queue = :mail
|
|
||||||
|
|
||||||
def self.perform
|
|
||||||
|
|
||||||
@datas = MailCron.where(:mail_sentdate.lte => Time.now)
|
|
||||||
|
|
||||||
@datas.each do |mail_data|
|
|
||||||
|
|
||||||
@mail_j = 0
|
|
||||||
@read_mails = Array.new
|
|
||||||
|
|
||||||
@mails = mail_data.mail_to.split(",")
|
|
||||||
|
|
||||||
@mails.each do |send_mail|
|
|
||||||
|
|
||||||
@read_mails << send_mail
|
|
||||||
|
|
||||||
@mail_j += 1
|
|
||||||
|
|
||||||
if 0 == @mail_j % 30
|
|
||||||
MailCronMailer.cron_mail( mail_data.id, @read_mails.join(',') ).deliver
|
|
||||||
@read_mails = Array.new
|
|
||||||
|
|
||||||
sleep 10
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
if !@read_mails.join(',').blank?
|
|
||||||
MailCronMailer.cron_mail( mail_data.id, @read_mails.join(',') ).deliver
|
|
||||||
@read_mails = Array.new
|
|
||||||
|
|
||||||
sleep 10
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
end
|
|
|
@ -1,10 +0,0 @@
|
||||||
class SendAskNoticeMail
|
|
||||||
@queue = :mail
|
|
||||||
|
|
||||||
def self.perform(ask_admin_id, ask_question_id)
|
|
||||||
ask_admin = AskAdmin.find(ask_admin_id)
|
|
||||||
ask_question = AskQuestion.find(ask_question_id)
|
|
||||||
AskMailer.notice(ask_admin, ask_question).deliver
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
|
@ -1,9 +0,0 @@
|
||||||
class SendAskReplyMail
|
|
||||||
@queue = :mail
|
|
||||||
|
|
||||||
def self.perform(ask_question_id)
|
|
||||||
ask_question = AskQuestion.find(ask_question_id)
|
|
||||||
AskMailer.reply(ask_question).deliver
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
|
@ -3,7 +3,7 @@ class UpdateTagCloud
|
||||||
|
|
||||||
def self.perform()
|
def self.perform()
|
||||||
Tag.all.each do |tag|
|
Tag.all.each do |tag|
|
||||||
tag.update_attribute(:cloud_view_count, tag.get_impressionist)
|
tag.update_attribute(:cloud_view_count, tag.impressionist_count(:created_at.gte => 14.days.ago, :created_at.lte => Time.now))
|
||||||
end
|
end
|
||||||
OrbitLogger.info "UpdateTagCloud Done"
|
OrbitLogger.info "UpdateTagCloud Done"
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,81 +0,0 @@
|
||||||
class MailCronMailer < ActionMailer::Base
|
|
||||||
default :from => "orbit_test@rulingcom.com"
|
|
||||||
|
|
||||||
def get_settings
|
|
||||||
|
|
||||||
@site = Site.first
|
|
||||||
|
|
||||||
@smtp_settings = {
|
|
||||||
:address => @site['site_settings']['address'],
|
|
||||||
:port => @site['site_settings']['port'],
|
|
||||||
:domain => @site['site_settings']['domain'],
|
|
||||||
:authentication => @site['site_settings']['authentication'],
|
|
||||||
# :user_name => @site['site_settings']['user_name'],
|
|
||||||
# :password => @site['site_settings']['password'],
|
|
||||||
:tls => (@site['site_settings']['tls'] == '0' ? false : true ) ,
|
|
||||||
:enable_starttls_auto => (@site['site_settings']['enable_starttls_auto'] == '0' ? false : true )
|
|
||||||
}
|
|
||||||
|
|
||||||
if !@site['site_settings']['user_name'].blank?
|
|
||||||
@smtp_settings[:user_name] = @site['site_settings']['user_name']
|
|
||||||
end
|
|
||||||
|
|
||||||
if !@site['site_settings']['password'].blank?
|
|
||||||
@smtp_settings[:password] = @site['site_settings']['password']
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
ActionMailer::Base.smtp_settings = @smtp_settings
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
def cron_mail( data_id, group_mail )
|
|
||||||
|
|
||||||
get_settings
|
|
||||||
|
|
||||||
@data = MailCron.find(data_id)
|
|
||||||
|
|
||||||
if @data
|
|
||||||
|
|
||||||
@user = User.find(@data.create_user_id)
|
|
||||||
|
|
||||||
if !@data.mail_cron_files.blank?
|
|
||||||
@data.mail_cron_files.each_with_index do |mail_cron_file, i|
|
|
||||||
file_type = File.extname(mail_cron_file.file.to_s)
|
|
||||||
file_content = Mongo::GridFileSystem.new(Mongoid.database).open(mail_cron_file.file.url.gsub("/gridfs/", "").force_encoding("UTF-8"), 'r')
|
|
||||||
attachments["#{mail_cron_file.title}#{file_type}"] = file_content.read
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if !@data.mail_content["text"].blank?
|
|
||||||
mail( :from => @data.mail_from, :reply_to => @data.mail_reply_to, :bcc => group_mail, :subject => @data.mail_subject ) do |format|
|
|
||||||
format.html { render :text => @data.mail_content["text"] }
|
|
||||||
end
|
|
||||||
elsif !@data.mail_content["template"].blank?
|
|
||||||
mail( :from => @data.mail_from, :reply_to => @data.mail_reply_to, :bcc => group_mail, :subject => @data.mail_subject ) do |format|
|
|
||||||
format.html { render :template => @data.mail_content["template"], :collection => @data.mail_content }
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
@mail_cron_log = {
|
|
||||||
:mail_subject => @data.mail_subject,
|
|
||||||
:mail_to => group_mail,
|
|
||||||
:mail_user => @user.name,
|
|
||||||
:mailer_count => group_mail.split(",").size,
|
|
||||||
:mail_from_app => @data.mail_from_app
|
|
||||||
}
|
|
||||||
|
|
||||||
@mail_cron_log = MailCronLog.new(@mail_cron_log)
|
|
||||||
|
|
||||||
|
|
||||||
@mail_cron_log.save
|
|
||||||
|
|
||||||
@data.destroy
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
|
@ -1,70 +0,0 @@
|
||||||
class MailCron
|
|
||||||
|
|
||||||
include Mongoid::Document
|
|
||||||
include Mongoid::Timestamps
|
|
||||||
|
|
||||||
|
|
||||||
field :mail_from_app
|
|
||||||
field :mail_from
|
|
||||||
field :mail_to
|
|
||||||
field :mail_reply_to
|
|
||||||
field :mail_subject
|
|
||||||
field :mail_content, :type => Hash
|
|
||||||
field :mail_sentdate , :type => DateTime
|
|
||||||
|
|
||||||
field :create_user_id
|
|
||||||
field :update_user_id
|
|
||||||
|
|
||||||
has_many :mail_cron_files, :autosave => true, :dependent => :destroy
|
|
||||||
|
|
||||||
accepts_nested_attributes_for :mail_cron_files, :allow_destroy => true
|
|
||||||
|
|
||||||
after_save :save_mail_cron_files
|
|
||||||
|
|
||||||
|
|
||||||
def save_mail_cron_files
|
|
||||||
self.mail_cron_files.each do |t|
|
|
||||||
if t.should_destroy
|
|
||||||
t.destroy
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def self.send_mail_now(mail_cron_id)
|
|
||||||
|
|
||||||
mail_data = MailCron.find(mail_cron_id)
|
|
||||||
|
|
||||||
if !mail_data.blank?
|
|
||||||
|
|
||||||
@mail_j = 0
|
|
||||||
@read_mails = Array.new
|
|
||||||
|
|
||||||
@mails = mail_data.mail_to.split(",")
|
|
||||||
|
|
||||||
@mails.each do |send_mail|
|
|
||||||
|
|
||||||
@read_mails << send_mail
|
|
||||||
|
|
||||||
@mail_j += 1
|
|
||||||
|
|
||||||
if 0 == @mail_j % 30
|
|
||||||
MailCronMailer.cron_mail( mail_data.id, @read_mails.join(',') ).deliver
|
|
||||||
@read_mails = Array.new
|
|
||||||
|
|
||||||
sleep 10
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
if !@read_mails.join(',').blank?
|
|
||||||
MailCronMailer.cron_mail( mail_data.id, @read_mails.join(',') ).deliver
|
|
||||||
@read_mails = Array.new
|
|
||||||
|
|
||||||
sleep 10
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
|
@ -1,13 +0,0 @@
|
||||||
class MailCronFile
|
|
||||||
|
|
||||||
include Mongoid::Document
|
|
||||||
include Mongoid::Timestamps
|
|
||||||
|
|
||||||
mount_uploader :file, AssetUploader
|
|
||||||
|
|
||||||
field :should_destroy, :type => Boolean
|
|
||||||
field :title
|
|
||||||
|
|
||||||
belongs_to :mail_cron
|
|
||||||
|
|
||||||
end
|
|
|
@ -1,14 +0,0 @@
|
||||||
class MailCronLog
|
|
||||||
|
|
||||||
include Mongoid::Document
|
|
||||||
include Mongoid::Timestamps
|
|
||||||
|
|
||||||
|
|
||||||
field :mail_subject
|
|
||||||
field :mail_to
|
|
||||||
field :mail_user
|
|
||||||
field :mailer_count
|
|
||||||
field :mail_from_app
|
|
||||||
|
|
||||||
|
|
||||||
end
|
|
|
@ -140,7 +140,7 @@ class ModuleApp
|
||||||
def sorted_tags_for_cloud
|
def sorted_tags_for_cloud
|
||||||
temp_tags = {}
|
temp_tags = {}
|
||||||
self.tags.each{ |tag|
|
self.tags.each{ |tag|
|
||||||
temp_tags.merge!({tag => tag.cloud_view_count})
|
temp_tags.merge!({tag => Tag.get_impressionist(tag)})
|
||||||
}
|
}
|
||||||
if !temp_tags.blank?
|
if !temp_tags.blank?
|
||||||
sorted_tags = temp_tags.sort{|a,b| a[1]<=>b[1]}.reverse
|
sorted_tags = temp_tags.sort{|a,b| a[1]<=>b[1]}.reverse
|
||||||
|
|
|
@ -23,7 +23,7 @@ module Mongoid
|
||||||
def set_sort_number
|
def set_sort_number
|
||||||
if self.new? && self.sort_number.nil?
|
if self.new? && self.sort_number.nil?
|
||||||
last_record = self.class.desc(:sort_number).first
|
last_record = self.class.desc(:sort_number).first
|
||||||
if last_record && last_record.sort_number
|
if last_record.sort_number
|
||||||
self.sort_number = (last_record.sort_number + 10) / 10 * 10
|
self.sort_number = (last_record.sort_number + 10) / 10 * 10
|
||||||
else
|
else
|
||||||
self.sort_number = 10
|
self.sort_number = 10
|
||||||
|
|
|
@ -3,7 +3,7 @@ class Page < Item
|
||||||
include Impressionist::Impressionable
|
include Impressionist::Impressionable
|
||||||
include ParserFrontEnd
|
include ParserFrontEnd
|
||||||
|
|
||||||
is_impressionable #:counter_cache => { :column_name => :view_count }
|
is_impressionable :counter_cache => { :column_name => :view_count }
|
||||||
|
|
||||||
field :content, localize: true
|
field :content, localize: true
|
||||||
field :app_frontend_url
|
field :app_frontend_url
|
||||||
|
|
|
@ -51,9 +51,8 @@ class PrototypeAuth
|
||||||
end
|
end
|
||||||
|
|
||||||
def remove_operation(item,obj)
|
def remove_operation(item,obj)
|
||||||
item = (item.to_s.singularize == item.to_s) ? "#{item.to_s}_id" : "#{item.to_s.singularize}_ids"
|
if (self.send item).include? obj
|
||||||
if (self.send item).include? obj.id
|
(self.send item).delete obj
|
||||||
(self.send item).delete obj.id
|
|
||||||
self.save!
|
self.save!
|
||||||
else
|
else
|
||||||
false #should put error message for user not existed in list
|
false #should put error message for user not existed in list
|
||||||
|
|
|
@ -18,7 +18,6 @@ class Site
|
||||||
field :title_always_on, :type => Boolean, :default => false
|
field :title_always_on, :type => Boolean, :default => false
|
||||||
field :dashbroad_allow_visitor, :type => Boolean, :default => false
|
field :dashbroad_allow_visitor, :type => Boolean, :default => false
|
||||||
field :mail_settings, :type => Hash
|
field :mail_settings, :type => Hash
|
||||||
field :visitor_counters,:type=> Hash,:default=>{:total=>0,:today=>0,:this_week=>0,:this_month=>0,:this_year=>0}
|
|
||||||
|
|
||||||
field :disk_space, :type => String
|
field :disk_space, :type => String
|
||||||
field :system_package_info, :type => Hash,:default=>{}
|
field :system_package_info, :type => Hash,:default=>{}
|
||||||
|
@ -29,11 +28,10 @@ class Site
|
||||||
mount_uploader :default_image, ImageUploader
|
mount_uploader :default_image, ImageUploader
|
||||||
|
|
||||||
field :search,:type => Hash
|
field :search,:type => Hash
|
||||||
field :resque_namespace,:type => String, :default=>APP_CONFIG['orbit']
|
|
||||||
field :title, localize: true
|
field :title, localize: true
|
||||||
field :footer, localize: true
|
field :footer, localize: true
|
||||||
field :sub_menu, localize: true
|
field :sub_menu, localize: true
|
||||||
field :backup_keep_for_days,:type=>Integer,:default=> APP_CONFIG['backup_keep_for_days']
|
|
||||||
|
|
||||||
field :mobile_on, :type => Boolean, :default => false
|
field :mobile_on, :type => Boolean, :default => false
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@ class Tag
|
||||||
include Mongoid::Timestamps
|
include Mongoid::Timestamps
|
||||||
include Impressionist::Impressionable
|
include Impressionist::Impressionable
|
||||||
|
|
||||||
is_impressionable #:counter_cache => { :column_name => :view_count }
|
is_impressionable :counter_cache => { :column_name => :view_count }
|
||||||
|
|
||||||
field :name, localize: true
|
field :name, localize: true
|
||||||
field :view_count, :type => Integer, :default => 0
|
field :view_count, :type => Integer, :default => 0
|
||||||
|
@ -17,6 +17,30 @@ class Tag
|
||||||
belongs_to :module_tag, polymorphic: true
|
belongs_to :module_tag, polymorphic: true
|
||||||
has_many :taggings, dependent: :destroy
|
has_many :taggings, dependent: :destroy
|
||||||
|
|
||||||
|
#field :cloud_amper,:type: Integer,:default=> 0
|
||||||
|
|
||||||
|
# def self.sorted_for_cloud
|
||||||
|
# tags = {}
|
||||||
|
# self.all.each{ |tag|
|
||||||
|
# tags.merge!({tag => self.get_impressionist(tag)})
|
||||||
|
# }
|
||||||
|
# if !tags.blank?
|
||||||
|
# sorted_tags = tags.sort{|a,b| a[1]<=>b[1]}.reverse
|
||||||
|
# sorted_tags[0][1] = :hot1
|
||||||
|
# offset = (sorted_tags.size - 1) / 3
|
||||||
|
# i = 1
|
||||||
|
# class_i = 2
|
||||||
|
# sorted_tags[1..-1].collect!{ |x|
|
||||||
|
# x[1] = "hot#{class_i}"
|
||||||
|
# i == offset ? i = 1 : i += 1 if class_i < 4
|
||||||
|
# class_i += 1 if i == offset && class_i < 4
|
||||||
|
# }
|
||||||
|
# sorted_tags
|
||||||
|
# else
|
||||||
|
# []
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
|
||||||
protected
|
protected
|
||||||
|
|
||||||
def self.get_impressionist(item_tag = self)
|
def self.get_impressionist(item_tag = self)
|
||||||
|
|
|
@ -3,7 +3,7 @@ class User
|
||||||
include Mongoid::Document
|
include Mongoid::Document
|
||||||
include Mongoid::Timestamps
|
include Mongoid::Timestamps
|
||||||
|
|
||||||
devise :database_authenticatable, :recoverable, :rememberable, :trackable, :validatable #, :timeoutable
|
devise :database_authenticatable, :recoverable, :rememberable, :trackable, :registerable, :validatable #, :timeoutable
|
||||||
|
|
||||||
mount_uploader :avatar, AvatarUploader
|
mount_uploader :avatar, AvatarUploader
|
||||||
|
|
||||||
|
@ -42,6 +42,7 @@ class User
|
||||||
|
|
||||||
before_create :initialize_desktop
|
before_create :initialize_desktop
|
||||||
before_save :rebuild_status_record
|
before_save :rebuild_status_record
|
||||||
|
before_save :save_roles
|
||||||
scope :remote_account, where(:nccu_id.ne => nil)
|
scope :remote_account, where(:nccu_id.ne => nil)
|
||||||
scope :not_guest_user, all_of(:name.ne => "guest")
|
scope :not_guest_user, all_of(:name.ne => "guest")
|
||||||
|
|
||||||
|
@ -88,9 +89,9 @@ class User
|
||||||
var[:id].each do |id,val|
|
var[:id].each do |id,val|
|
||||||
# binding.pry if id == '5052c5b22b5c49ab02000004'
|
# binding.pry if id == '5052c5b22b5c49ab02000004'
|
||||||
if (val=="true")
|
if (val=="true")
|
||||||
self.role_ids.reject!{|t| t.to_s == id}
|
self.roles = self.roles.reject{|t| t.id.to_s==id}
|
||||||
elsif(val=="false")
|
elsif(val=="false")
|
||||||
self.role_ids += Array(id)
|
self.roles << Role.find(id)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -105,9 +106,9 @@ class User
|
||||||
# binding.pry if id == '5052c5b22b5c49ab02000004'
|
# binding.pry if id == '5052c5b22b5c49ab02000004'
|
||||||
|
|
||||||
if ( self.roles.include?(@roid) == false or val=="true")
|
if ( self.roles.include?(@roid) == false or val=="true")
|
||||||
self.sub_role_ids.reject!{|t| t.to_s == id}
|
self.sub_roles = self.sub_roles.reject{|t| t.id.to_s==id}
|
||||||
elsif(val=="false")
|
elsif(val=="false")
|
||||||
self.sub_role_ids += Array(id)
|
self.sub_roles << SubRole.find(id)
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
@ -272,6 +273,10 @@ class User
|
||||||
end
|
end
|
||||||
|
|
||||||
protected
|
protected
|
||||||
|
def save_roles
|
||||||
|
# self.roles = self.sub_roles.collect{|t| t.role}.uniq
|
||||||
|
self.roles = self.roles.uniq
|
||||||
|
end
|
||||||
|
|
||||||
def rebuild_status_record
|
def rebuild_status_record
|
||||||
self.status_record = {}
|
self.status_record = {}
|
||||||
|
|
|
@ -8,5 +8,6 @@
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
<div class="form-actions form-fixed pagination-right">
|
<div class="form-actions form-fixed pagination-right">
|
||||||
|
<%= link_to content_tag(:i, nil, :class => 'icon-plus icon-white') + t(:add), new_admin_design_path, :class => 'btn btn-primary pull-right' %>
|
||||||
<%= link_to content_tag(:i, nil, :class => 'icon-plus icon-white') + t(:upload), upload_package_admin_designs_path, :class => 'btn btn-primary pull-right' %>
|
<%= link_to content_tag(:i, nil, :class => 'icon-plus icon-white') + t(:upload), upload_package_admin_designs_path, :class => 'btn btn-primary pull-right' %>
|
||||||
</div>
|
</div>
|
|
@ -1,3 +0,0 @@
|
||||||
<div class="filter-clear">
|
|
||||||
<%= link_to content_tag(:i, nil, :class => 'icons-cycle') + t(:clear), admin_mail_crons_path(:filter => @filter, :sort => params[:sort], :direction => params[:direction], :clear => true, :type => type), :class => "btn btn-small js_history" %>
|
|
||||||
</div>
|
|
|
@ -1,11 +0,0 @@
|
||||||
<div id="filter" class="subnav">
|
|
||||||
<div class="filters">
|
|
||||||
<div id="sort_headers" class="table-label">
|
|
||||||
<%= render 'sort_headers' %>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<% content_for :page_specific_javascript do %>
|
|
||||||
<%= javascript_include_tag "sort_header" %>
|
|
||||||
<% end %>
|
|
|
@ -1,29 +0,0 @@
|
||||||
<tr id="<%= dom_id mail_cron_log %>" class="with_action">
|
|
||||||
<td class="span1">
|
|
||||||
<% if is_manager? %>
|
|
||||||
<%= check_box_tag 'to_delete[]', mail_cron_log.id, false, :class => "checkbox_in_list" %>
|
|
||||||
<% end -%>
|
|
||||||
</td>
|
|
||||||
<td class="span1-2">
|
|
||||||
<%= mail_cron_log.mail_subject %>
|
|
||||||
<div class="quick-edit">
|
|
||||||
<ul class="nav nav-pills hide">
|
|
||||||
<%if at_least_module_manager %>
|
|
||||||
<li><%= link_to t(:delete_), admin_mail_cron_log_path(mail_cron_log), :confirm => t('sure?'), :method => :delete, :remote => true %></li>
|
|
||||||
<% end -%>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</td>
|
|
||||||
<td class="span2">
|
|
||||||
<%= mail_cron_log.mail_to.gsub(/,/, "<br />").html_safe %>
|
|
||||||
</td>
|
|
||||||
<td class="span2">
|
|
||||||
<%= mail_cron_log.mail_user %>
|
|
||||||
</td>
|
|
||||||
<td class="span2">
|
|
||||||
<%= mail_cron_log.mail_from_app %>
|
|
||||||
</td>
|
|
||||||
<td class="span2">
|
|
||||||
<%= display_date_time(mail_cron_log.created_at) %>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
|
@ -1,6 +0,0 @@
|
||||||
<%= render_sort_bar(true, delete_admin_mail_cron_logs_path(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options]),
|
|
||||||
['subject', 'mail_subject','span2', :subject] ,
|
|
||||||
['mail_to', 'mail_to','span2', :mail_to] ,
|
|
||||||
['mail_user', 'mail_user','span2', :mail_user] ,
|
|
||||||
['mail_from_app', 'mail_from_app','span2', :mail_from_app] ,
|
|
||||||
['sentdate', 'created_at','span2', :sentdate] ).html_safe %>
|
|
|
@ -1 +0,0 @@
|
||||||
$("#<%= dom_id @mail_cron_log %>").remove();
|
|
|
@ -1,28 +0,0 @@
|
||||||
<% content_for :side_bar do %>
|
|
||||||
<%= render :partial => 'layouts/side_bar', :locals => {:link_name => t('site.settings'), :link_url => admin_site_site_info_path(@site), :icon => 'icons-cog', :side_bar_content => 'admin/sites/side_bar'} %>
|
|
||||||
<% end %>
|
|
||||||
|
|
||||||
<%= render 'filter' %>
|
|
||||||
<table class="table main-list">
|
|
||||||
<thead>
|
|
||||||
<tr>
|
|
||||||
<th class="span1"></th>
|
|
||||||
<th class="span2"></th>
|
|
||||||
<th class="span2"></th>
|
|
||||||
<th class="span2"></th>
|
|
||||||
<th class="span2"></th>
|
|
||||||
<th class="span2"></th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
<tbody id="tbody_mail_cron_logs" class="sort-holder">
|
|
||||||
<%= render :partial => "mail_cron_log",:collection=> @mail_cron_logs%>
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
|
|
||||||
<div class="form-actions form-fixed pagination-right">
|
|
||||||
<div id="web_link_pagination" class="paginationFixed">
|
|
||||||
<%= paginate @mail_cron_logs, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
|
@ -1,4 +0,0 @@
|
||||||
$("#delete_all").attr("action", "<%= delete_admin_mail_cron_logs_path(:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil, :sort_options => params[:sort_options]) %>");
|
|
||||||
$("#sort_headers").html("<%= j render 'sort_headers' %>");
|
|
||||||
$("#tbody_mail_cron_logs").html("<%= j render :partial => 'mail_cron_log', :collection => @mail_cron_logs %>");
|
|
||||||
$("#mail_cron_log_pagination").html("<%= j paginate @mail_cron_logs, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>");
|
|
|
@ -1,3 +0,0 @@
|
||||||
<div class="filter-clear">
|
|
||||||
<%= link_to content_tag(:i, nil, :class => 'icons-cycle') + t(:clear), admin_mail_crons_path(:filter => @filter, :sort => params[:sort], :direction => params[:direction], :clear => true, :type => type), :class => "btn btn-small js_history" %>
|
|
||||||
</div>
|
|
|
@ -1,11 +0,0 @@
|
||||||
<div id="filter" class="subnav">
|
|
||||||
<div class="filters">
|
|
||||||
<div id="sort_headers" class="table-label">
|
|
||||||
<%= render 'sort_headers' %>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<% content_for :page_specific_javascript do %>
|
|
||||||
<%= javascript_include_tag "sort_header" %>
|
|
||||||
<% end %>
|
|
|
@ -1,122 +0,0 @@
|
||||||
<div id= "poststuff">
|
|
||||||
<% # encoding: utf-8 %>
|
|
||||||
|
|
||||||
<%= f.error_messages %>
|
|
||||||
|
|
||||||
<!--Widget start-->
|
|
||||||
|
|
||||||
<div id="sub-wiget">
|
|
||||||
|
|
||||||
<div id="widget-date" class="widget-box widget-size-300">
|
|
||||||
<h3 class="widget-title"><i class="icons-calendar"></i><%= t(:date_) %></h3>
|
|
||||||
<div class="widget-content clear">
|
|
||||||
<div class="control-group">
|
|
||||||
<%= f.datetime_picker :mail_sentdate, :picker_type => 'separated', :label => t(:start) %>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
<!--Wiget End-->
|
|
||||||
<!--Post Start-->
|
|
||||||
|
|
||||||
<div id="post-body">
|
|
||||||
<div id="post-body-content" class="clear">
|
|
||||||
|
|
||||||
<%= f.label :mail_subject ,t(:mail_subject)%>
|
|
||||||
<%= f.text_field :mail_subject %>
|
|
||||||
|
|
||||||
<%= f.label :mail_from ,t(:mail_from)%>
|
|
||||||
<%= f.text_field :mail_from %>
|
|
||||||
|
|
||||||
<%= f.label :mail_reply_to ,t(:mail_reply_to)%>
|
|
||||||
<%= f.text_field :mail_reply_to %>
|
|
||||||
|
|
||||||
<%= f.label :mail_to ,t(:mail_to)%>
|
|
||||||
<%= f.text_field :mail_to %>
|
|
||||||
|
|
||||||
<%= f.label :mail_content ,t(:mail_content)%>
|
|
||||||
<%= f.text_area :mail_content, :class=>"span12", :cols=>"25", :rows=>"10" %>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<div>
|
|
||||||
|
|
||||||
<div id='plugin_files' class="plugin_files_block">
|
|
||||||
|
|
||||||
<table class="table table-condensed">
|
|
||||||
<thead>
|
|
||||||
<tr>
|
|
||||||
<th>File</th>
|
|
||||||
<th>File Name</th>
|
|
||||||
<th class="span1"></th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
<tfoot>
|
|
||||||
<tr>
|
|
||||||
<td style="text-align:center" colspan="3">
|
|
||||||
<div id='add_plugin_file' class="info_input plugin_files_block">
|
|
||||||
<%= hidden_field_tag 'plugin_file_field_count', @mail_cron.mail_cron_files.count %>
|
|
||||||
<a class="add"><span class="btn btn-primary btn-small"><i class="icon-plus icon-white"></i> ADD/新增</span></a>
|
|
||||||
</div>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
|
|
||||||
</tfoot>
|
|
||||||
<tbody>
|
|
||||||
|
|
||||||
<% @mail_cron.mail_cron_files.each_with_index do |mail_cron_file, i| %>
|
|
||||||
<%= f.fields_for :mail_cron_files, mail_cron_file do |f| %>
|
|
||||||
<%= render :partial => 'form_file', :object => mail_cron_file, :locals => {:f => f, :i => i} %>
|
|
||||||
<% end %>
|
|
||||||
<% end %>
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
<!--Post End-->
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
<div class="form-actions">
|
|
||||||
<%= f.submit t('submit'), :class=>'btn btn-primary' %>
|
|
||||||
<%= link_to t('cancel'), get_go_back, :class=>"btn" %>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<% content_for :page_specific_javascript do %>
|
|
||||||
<%= javascript_include_tag "archive_plugin_form" %>
|
|
||||||
<script>
|
|
||||||
$('#add_plugin_file a.add').live('click', function(){
|
|
||||||
var new_id = $(this).prev().attr('value');
|
|
||||||
var old_id = new RegExp("new_add_plugin_files", "g");
|
|
||||||
$(this).prev().attr('value', parseInt(new_id) + 1);
|
|
||||||
$(this).parents('table').append(("<%= escape_javascript(add_attribute 'form_file', f, :mail_cron_files) %>").replace(old_id, new_id));
|
|
||||||
});
|
|
||||||
|
|
||||||
$('.add_plugin_files_block a.delete').live('click', function(){
|
|
||||||
$(this).parents('.list_item').remove();
|
|
||||||
});
|
|
||||||
|
|
||||||
$('.action a.remove_existing_record').live('click', function(){
|
|
||||||
$(this).next('.should_destroy').attr('value', 1);
|
|
||||||
$("tr#add_plugin_file_" + $(this).prev().attr('value')).hide();
|
|
||||||
});
|
|
||||||
|
|
||||||
</script>
|
|
||||||
<% end %>
|
|
||||||
|
|
||||||
|
|
||||||
</div>
|
|
|
@ -1,35 +0,0 @@
|
||||||
<% # encoding: utf-8 %>
|
|
||||||
|
|
||||||
<tr id="<%= "plugin_file_#{form_file.id}" if !form_file.new_record? %>" class='list_item'>
|
|
||||||
<td>
|
|
||||||
<div class="control-group">
|
|
||||||
<div class="controls">
|
|
||||||
<%= f.file_field :file %>
|
|
||||||
<%= form_file.file.file ? ( link_to t(:view), form_file.file.url, {:class => 'btn', :target => '_blank', :title => t(:view)} ) : '' %>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</td>
|
|
||||||
<td>
|
|
||||||
|
|
||||||
<div class="tab-content">
|
|
||||||
|
|
||||||
<%= f.text_field :title %>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</td>
|
|
||||||
|
|
||||||
<td>
|
|
||||||
<span class="action">
|
|
||||||
<% if form_file.new_record? %>
|
|
||||||
<a class="delete"><i class="icon-remove"></i></a>
|
|
||||||
<% else %>
|
|
||||||
<%= f.hidden_field :id %>
|
|
||||||
<a class="remove_existing_record"><i class="icon-remove"></i></a>
|
|
||||||
<%= f.hidden_field :should_destroy, :value => nil, :class => 'should_destroy' %>
|
|
||||||
<% end %>
|
|
||||||
</span>
|
|
||||||
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
|
|
|
@ -1,26 +0,0 @@
|
||||||
<tr id="<%= dom_id mail_cron %>" class="with_action">
|
|
||||||
<td class="span1">
|
|
||||||
<% if is_manager? %>
|
|
||||||
<%= check_box_tag 'to_delete[]', mail_cron.id, false, :class => "checkbox_in_list" %>
|
|
||||||
<% end -%>
|
|
||||||
</td>
|
|
||||||
<td class="span1-2">
|
|
||||||
<%= mail_cron.mail_subject %>
|
|
||||||
<div class="quick-edit">
|
|
||||||
<ul class="nav nav-pills hide">
|
|
||||||
<%if at_least_module_manager %>
|
|
||||||
<li><%= link_to t(:delete_), admin_mail_cron_path(mail_cron), :confirm => t('sure?'), :method => :delete, :remote => true %></li>
|
|
||||||
<% end -%>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</td>
|
|
||||||
<td class="span2">
|
|
||||||
<%= mail_cron.mail_to.gsub(/,/, "<br />").html_safe %>
|
|
||||||
</td>
|
|
||||||
<td class="span2">
|
|
||||||
<%= mail_cron.mail_from_app %>
|
|
||||||
</td>
|
|
||||||
<td class="span2">
|
|
||||||
<%= display_date_time(mail_cron.mail_sentdate) %>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
|
@ -1,5 +0,0 @@
|
||||||
<%= render_sort_bar(true, delete_admin_mail_crons_path(:direction => params[:direction], :sort => params[:sort], :sort_options => params[:sort_options]),
|
|
||||||
['subject', 'mail_subject','span2', :mail_subject] ,
|
|
||||||
['mail_to', 'mail_to','span2', :mail_to] ,
|
|
||||||
['mail_from_app', 'mail_from_app','span2', :mail_from_app] ,
|
|
||||||
['sentdate', 'mail_sentdate','span2', :mail_sentdate] ).html_safe %>
|
|
|
@ -1 +0,0 @@
|
||||||
$("#<%= dom_id @mail_cron %>").remove();
|
|
|
@ -1,9 +0,0 @@
|
||||||
<% content_for :side_bar do %>
|
|
||||||
<%= render :partial => 'layouts/side_bar', :locals => {:link_name => t('site.settings'), :link_url => admin_site_site_info_path(@site), :icon => 'icons-cog', :side_bar_content => 'admin/sites/side_bar'} %>
|
|
||||||
<% end %>
|
|
||||||
|
|
||||||
<h1><%= t('mail_cron.editing_mail_cron') %></h1>
|
|
||||||
|
|
||||||
<%= form_for @mail_cron, :url => admin_mail_cron_path(@mail_cron), :html => {:class => 'clear'} do |f| %>
|
|
||||||
<%= render :partial => 'form', :locals => {:f => f} %>
|
|
||||||
<% end %>
|
|
|
@ -1,27 +0,0 @@
|
||||||
<% content_for :side_bar do %>
|
|
||||||
<%= render :partial => 'layouts/side_bar', :locals => {:link_name => t('site.settings'), :link_url => admin_site_site_info_path(@site), :icon => 'icons-cog', :side_bar_content => 'admin/sites/side_bar'} %>
|
|
||||||
<% end %>
|
|
||||||
|
|
||||||
<%= render 'filter' %>
|
|
||||||
<table class="table main-list">
|
|
||||||
<thead>
|
|
||||||
<tr>
|
|
||||||
<th class="span1"></th>
|
|
||||||
<th class="span2"></th>
|
|
||||||
<th class="span2"></th>
|
|
||||||
<th class="span2"></th>
|
|
||||||
<th class="span2"></th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
<tbody id="tbody_mail_crons" class="sort-holder">
|
|
||||||
<%= render :partial => "mail_cron",:collection=> @mail_crons%>
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
|
|
||||||
<div class="form-actions form-fixed pagination-right">
|
|
||||||
<div id="web_link_pagination" class="paginationFixed">
|
|
||||||
<%= paginate @mail_crons, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
|
@ -1,4 +0,0 @@
|
||||||
$("#delete_all").attr("action", "<%= delete_admin_mail_crons_path(:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil, :sort_options => params[:sort_options]) %>");
|
|
||||||
$("#sort_headers").html("<%= j render 'sort_headers' %>");
|
|
||||||
$("#tbody_mail_crons").html("<%= j render :partial => 'mail_cron', :collection => @mail_crons %>");
|
|
||||||
$("#mail_cron_pagination").html("<%= j paginate @mail_crons, :params => {:direction => params[:direction], :sort => params[:sort], :filter => @filter, :new_filter => nil} %>");
|
|
|
@ -1,12 +0,0 @@
|
||||||
|
|
||||||
<% content_for :side_bar do %>
|
|
||||||
<%= render :partial => 'layouts/side_bar', :locals => {:link_name => t('site.settings'), :link_url => admin_site_site_info_path(@site), :icon => 'icons-cog', :side_bar_content => 'admin/sites/side_bar'} %>
|
|
||||||
<% end %>
|
|
||||||
|
|
||||||
<div id="poststuff">
|
|
||||||
<h1><%= t('mail_cron.new_mail_cron') %></h1>
|
|
||||||
<%= form_for @mail_cron, :url => admin_mail_crons_path, :html => {:class => 'clear'} do |f| %>
|
|
||||||
<%= render :partial => 'form', :locals => {:f => f} %>
|
|
||||||
<% end %>
|
|
||||||
</div>
|
|
||||||
|
|
|
@ -8,9 +8,6 @@
|
||||||
<%= content_tag :li, link_to(t('mail.setting'), admin_site_mail_setting_path(@site)), :class => active_for_action('sites', 'mail_setting') %>
|
<%= content_tag :li, link_to(t('mail.setting'), admin_site_mail_setting_path(@site)), :class => active_for_action('sites', 'mail_setting') %>
|
||||||
<%#= content_tag :li, link_to(t(:theme), admin_site_ui_theme_path(@site)), :class => active_for_action('sites', 'ui_theme') %>
|
<%#= content_tag :li, link_to(t(:theme), admin_site_ui_theme_path(@site)), :class => active_for_action('sites', 'ui_theme') %>
|
||||||
<%= content_tag :li, link_to(t('sitemap'), admin_site_sitemap_path(@site)), :class => active_for_action('sites', 'sitemap') %>
|
<%= content_tag :li, link_to(t('sitemap'), admin_site_sitemap_path(@site)), :class => active_for_action('sites', 'sitemap') %>
|
||||||
<%= content_tag :li, link_to(t('user_actions'), admin_user_actions_path), :class => active_for_action('user_actions', 'index') %>
|
|
||||||
<%= content_tag :li, link_to(t('mail.mail_cron'), admin_mail_crons_path), :class => active_for_action('mail_cron', 'index') %>
|
|
||||||
<%= content_tag :li, link_to(t('mail.mail_cron_log'), admin_mail_cron_logs_path), :class => active_for_action('mail_cron_log', 'index') %>
|
|
||||||
<% end -%>
|
<% end -%>
|
||||||
|
|
||||||
<% end -%>
|
<% end -%>
|
||||||
|
|
|
@ -8,6 +8,6 @@
|
||||||
</div>
|
</div>
|
||||||
<div class="action">
|
<div class="action">
|
||||||
<%= link_to t(:edit), edit_admin_tag_path(tag, :module_app_id => @module_app_id), :remote => true %>
|
<%= link_to t(:edit), edit_admin_tag_path(tag, :module_app_id => @module_app_id), :remote => true %>
|
||||||
<%= link_to t(:delete_), admin_tag_path(tag, :module_app_id => @module_app_id), :confirm => t('sure?'), :method => :delete, :remote => true %>
|
<%= link_to t(:delete_), admin_tag_path(tag), :confirm => t('sure?'), :method => :delete, :remote => true %>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
|
@ -1,7 +1,3 @@
|
||||||
<% content_for :side_bar do %>
|
|
||||||
<%= render :partial => 'layouts/side_bar', :locals => {:link_name => t('site.settings'), :link_url => admin_site_site_info_path(@site), :icon => 'icons-cog', :side_bar_content => 'admin/sites/side_bar'} %>
|
|
||||||
<% end %>
|
|
||||||
|
|
||||||
<table class="table">
|
<table class="table">
|
||||||
<tr>
|
<tr>
|
||||||
<th><%= I18n.t 'user_action.time' %></th>
|
<th><%= I18n.t 'user_action.time' %></th>
|
||||||
|
|
|
@ -1,22 +1,19 @@
|
||||||
<%= content_tag :div, class: @tag_class do %>
|
<%= content_tag :div,:class=>@tag_class do%>
|
||||||
<div class="default_widget_type_A">
|
<div class="default_widget_type_A">
|
||||||
<table class="default_widget_tb" border="0" cellpadding="0" cellspacing="0" >
|
<table class="default_widget_tb" border="0" cellpadding="0" cellspacing="0" >
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<% @frontend_field_names.each_with_index do |field,index|%>
|
<% @frontend_field_names.each_with_index do |field,index|%>
|
||||||
<%= content_tag(:th, content_tag(:span, get_field_header(field), class: @frontend_classes[index])) unless field.blank? %>
|
<%= content_tag(:th,content_tag(:span,get_field_header(field),:class=>@frontend_classes[index]))unless field.blank?%>
|
||||||
<% end %>
|
<% end %>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
|
||||||
<% @data.each do |row_data| %>
|
<% @data.each do |row_data| %>
|
||||||
<tr class="<%= get_top_hot_class(row_data) %>">
|
<tr>
|
||||||
<% @frontend_field_names.each_with_index do |field,index|%>
|
<% @frontend_field_names.each_with_index do |field,index|%>
|
||||||
<%= content_tag(:td, content_tag(:span, link_to_field(row_data, field, @frontend_sat_to_links[index], {orig_page: @page_id.to_s, category_id: get_row_category(row_data), tag_id: get_row_tags(row_data)}), class: @frontend_classes[index])) unless field.blank? %>
|
<%= content_tag(:td,content_tag(:span,link_to_field(row_data,field, @frontend_sat_to_links[index], {orig_page: @page_id.to_s}),:class=>@frontend_classes[index]))unless field.blank?%>
|
||||||
<% end %>
|
<% end %>
|
||||||
</tr>
|
</tr>
|
||||||
<% end %>
|
<% end %>
|
||||||
</tbody>
|
|
||||||
</table>
|
</table>
|
||||||
</div>
|
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
<%= content_tag :div, class: @tag_class do %>
|
<%= content_tag :div,:class=>@tag_class do%>
|
||||||
<ul class="default_widget_list">
|
<ul class="default_widget_list">
|
||||||
<% @data.each do |row_data| %>
|
<% @data.each do |row_data| %>
|
||||||
<%= content_tag(:li, class: get_top_hot_class(row_data)) do %>
|
<%= content_tag(:li) do %>
|
||||||
<div class="img app-pic">
|
<div class="img app-pic">
|
||||||
<%= image_tag row_data.send(@widget_image_field)%>
|
<%= image_tag row_data.send(@widget_image_field)%>
|
||||||
</div>
|
</div>
|
||||||
<div class="wrap">
|
<div class="wrap">
|
||||||
<% @frontend_field_names.each_with_index do |field,index|%>
|
<% @frontend_field_names.each_with_index do |field,index|%>
|
||||||
<%= content_tag(:span, link_to_field(row_data,field, @frontend_sat_to_links[index], {orig_page: @page_id.to_s, category_id: get_row_category(row_data), tag_id: get_row_tags(row_data)}), class: @frontend_classes[index]) unless field.blank? %>
|
<%= content_tag(:span,link_to_field(row_data,field, @frontend_sat_to_links[index], {orig_page: @page_id.to_s}),:class=>@frontend_classes[index]) unless field.blank?%>
|
||||||
<% end %>
|
<% end %>
|
||||||
</div>
|
</div>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
<%= content_tag :div, class: @tag_class do %>
|
<%= content_tag :div,:class=>@tag_class do%>
|
||||||
<div class="img app-pic">
|
<div class="img app-pic">
|
||||||
<%= image_tag @data.first.send(@widget_image_field)%>
|
<%= image_tag @data.first.send(@widget_image_field)%>
|
||||||
</div>
|
</div>
|
||||||
<ul class="default_widget_list">
|
<ul class="default_widget_list">
|
||||||
<% @data.each do |row_data| %>
|
<% @data.each do |row_data| %>
|
||||||
<%= content_tag(:li, class: get_top_hot_class(row_data)) do %>
|
<%= content_tag(:li) do %>
|
||||||
<% @frontend_field_names.each_with_index do |field,index|%>
|
<% @frontend_field_names.each_with_index do |field,index|%>
|
||||||
<%= content_tag(:span, link_to_field(row_data, field, @frontend_sat_to_links[index], {orig_page: @page_id.to_s, category_id: get_row_category(row_data), tag_id: get_row_tags(row_data)}), class: @frontend_classes[index]) unless field.blank? %>
|
<%= content_tag(:span, link_to_field(row_data,field, @frontend_sat_to_links[index], {orig_page: @page_id.to_s}),:class=>@frontend_classes[index]) unless field.blank?%>
|
||||||
<% end %>
|
<% end %>
|
||||||
<% end %>
|
<% end %>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
|
@ -3,7 +3,6 @@ defaults: &defaults
|
||||||
store_ip: 'redmine.rulingcom.com:3001'
|
store_ip: 'redmine.rulingcom.com:3001'
|
||||||
orbit: 'Orbit'
|
orbit: 'Orbit'
|
||||||
ruling_digital: 'RulingDigital'
|
ruling_digital: 'RulingDigital'
|
||||||
backup_keep_for_days: 30
|
|
||||||
|
|
||||||
development:
|
development:
|
||||||
<<: *defaults
|
<<: *defaults
|
||||||
|
|
|
@ -34,15 +34,16 @@ Orbit::Application.configure do
|
||||||
# :sender_address => %{"notifier" <redmine@rulingcom.com>},
|
# :sender_address => %{"notifier" <redmine@rulingcom.com>},
|
||||||
# :exception_recipients => %w{chris@rulingcom.com}
|
# :exception_recipients => %w{chris@rulingcom.com}
|
||||||
|
|
||||||
config.action_mailer.delivery_method = :smtp
|
# config.action_mailer.delivery_method = :smtp
|
||||||
config.action_mailer.smtp_settings = {
|
# config.action_mailer.smtp_settings = {
|
||||||
:enable_starttls_auto => true,
|
# :tls => true,
|
||||||
:address => "smtp.gmail.com",
|
# :enable_starttls_auto => true,
|
||||||
:port => '587',
|
# :address => "smtp.gmail.com",
|
||||||
:domain => "smtp.gmail.com",
|
# :port => '587',
|
||||||
:authentication => "plain",
|
# :domain => "smtp.gmail.com",
|
||||||
:user_name => "redmine@rulingcom.com",
|
# :authentication => "plain",
|
||||||
:password => "rulingredmine" }
|
# :user_name => "redmine@rulingcom.com",
|
||||||
|
# :password => "rulingredmine" }
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@ Orbit::Application.configure do
|
||||||
|
|
||||||
# Generate digests for assets URLs
|
# Generate digests for assets URLs
|
||||||
config.assets.digest = true
|
config.assets.digest = true
|
||||||
|
config.logger = Logger::Syslog.new
|
||||||
|
|
||||||
# Defaults to Rails.root.join("public/assets")
|
# Defaults to Rails.root.join("public/assets")
|
||||||
# config.assets.manifest = YOUR_PATH
|
# config.assets.manifest = YOUR_PATH
|
||||||
|
@ -63,9 +64,9 @@ Orbit::Application.configure do
|
||||||
config.action_mailer.delivery_method = :smtp
|
config.action_mailer.delivery_method = :smtp
|
||||||
config.action_mailer.smtp_settings = {
|
config.action_mailer.smtp_settings = {
|
||||||
:enable_starttls_auto => true,
|
:enable_starttls_auto => true,
|
||||||
:address => "http://smtp.gmail.com",
|
:address => "smtp.gmail.com",
|
||||||
:port => '587',
|
:port => '587',
|
||||||
:domain => "http://smtp.gmail.com",
|
:domain => "smtp.gmail.com",
|
||||||
:authentication => "plain",
|
:authentication => "plain",
|
||||||
:user_name => "redmine@rulingcom.com",
|
:user_name => "redmine@rulingcom.com",
|
||||||
:password => "rulingredmine"
|
:password => "rulingredmine"
|
||||||
|
|
|
@ -3,7 +3,7 @@ require 'resque_scheduler/server'
|
||||||
# require 'yaml'
|
# require 'yaml'
|
||||||
|
|
||||||
Resque.redis = 'localhost:6379'
|
Resque.redis = 'localhost:6379'
|
||||||
Resque.redis.namespace = Site.first.resque_namespace rescue APP_CONFIG['orbit']
|
Resque.redis.namespace = "resque"
|
||||||
|
|
||||||
# If you want to be able to dynamically change the schedule,
|
# If you want to be able to dynamically change the schedule,
|
||||||
# uncomment this line. A dynamic schedule can be updated via the
|
# uncomment this line. A dynamic schedule can be updated via the
|
||||||
|
|
|
@ -272,8 +272,6 @@ en:
|
||||||
setting: Mail settings
|
setting: Mail settings
|
||||||
tls: TLS
|
tls: TLS
|
||||||
user_name: User Name
|
user_name: User Name
|
||||||
mail_cron: Scheduled Email
|
|
||||||
mail_cron_log: Email Log
|
|
||||||
manager: Manager
|
manager: Manager
|
||||||
markup: Markup
|
markup: Markup
|
||||||
markup_options: Markup options
|
markup_options: Markup options
|
||||||
|
@ -467,7 +465,6 @@ en:
|
||||||
url: URL
|
url: URL
|
||||||
use_status: Use Statue
|
use_status: Use Statue
|
||||||
user: User
|
user: User
|
||||||
user_actions: User log
|
|
||||||
user_action:
|
user_action:
|
||||||
time: Time
|
time: Time
|
||||||
name: Account
|
name: Account
|
||||||
|
|
|
@ -272,8 +272,6 @@ zh_tw:
|
||||||
setting: 電子郵件設定
|
setting: 電子郵件設定
|
||||||
tls: 電子郵件TLS
|
tls: 電子郵件TLS
|
||||||
user_name: 電子郵件帳號
|
user_name: 電子郵件帳號
|
||||||
mail_cron: 待寄Email
|
|
||||||
mail_cron_log: Email發送記錄
|
|
||||||
manager: 管理者
|
manager: 管理者
|
||||||
markup: 輸入模式
|
markup: 輸入模式
|
||||||
markup_options: 標註選項
|
markup_options: 標註選項
|
||||||
|
@ -468,7 +466,6 @@ zh_tw:
|
||||||
url: 網址
|
url: 網址
|
||||||
use_status: 使用狀態
|
use_status: 使用狀態
|
||||||
user: 使用者
|
user: 使用者
|
||||||
user_actions: 使用者Log
|
|
||||||
user_action:
|
user_action:
|
||||||
time: 時間
|
time: 時間
|
||||||
name: 使用帳號
|
name: 使用帳號
|
||||||
|
|
|
@ -8,7 +8,7 @@ defaults: &defaults
|
||||||
|
|
||||||
development:
|
development:
|
||||||
<<: *defaults
|
<<: *defaults
|
||||||
database: test_site
|
database: production_7
|
||||||
test:
|
test:
|
||||||
<<: *defaults
|
<<: *defaults
|
||||||
database: test_site
|
database: test_site
|
||||||
|
@ -21,4 +21,4 @@ production:
|
||||||
# password: <%= ENV['MONGOID_PASSWORD'] %>
|
# password: <%= ENV['MONGOID_PASSWORD'] %>
|
||||||
# database: <%= ENV['MONGOID_DATABASE'] %>
|
# database: <%= ENV['MONGOID_DATABASE'] %>
|
||||||
<<: *defaults
|
<<: *defaults
|
||||||
database: test_site
|
database: demo_site_production
|
||||||
|
|
|
@ -4,32 +4,33 @@ user_home = ENV['HOME'] || File.dirname(__FILE__) + '/../..'
|
||||||
development_uid = ''
|
development_uid = ''
|
||||||
development_gid = ''
|
development_gid = ''
|
||||||
|
|
||||||
num_workers = rails_env == 'production' ? <%= @resque_workers %> : 1
|
num_workers = rails_env == 'production' ? 5 : 2
|
||||||
|
|
||||||
num_workers.times do |num|
|
num_workers.times do |num|
|
||||||
God.watch do |w|
|
God.watch do |w|
|
||||||
|
|
||||||
w.dir = rails_root
|
w.dir = rails_root
|
||||||
w.name = "<%= @resque_namespace.nil? ? "" : "#{@resque_namespace}-" %>resque-worker-#{num}"
|
w.name = "worker-#{num}"
|
||||||
w.group = 'rulingcom'
|
w.group = 'resque'
|
||||||
|
|
||||||
w.interval = 30.seconds
|
w.interval = 30.seconds
|
||||||
|
|
||||||
queue = case num
|
queue = case num
|
||||||
when 0..2
|
when 0
|
||||||
|
'critical'
|
||||||
|
when 1..2
|
||||||
'high,low'
|
'high,low'
|
||||||
when 3..num_workers
|
when 3..num_workers
|
||||||
'low'
|
'low'
|
||||||
end
|
end
|
||||||
|
|
||||||
w.pid_file = "#{rails_root}/tmp/#{w.name}.pid"
|
w.env = {"QUEUE"=>queue, "RAILS_ENV"=>rails_env}
|
||||||
w.env = {"RAILS_ENV"=>rails_env,"PIDFILE" => w.pid_file ,"HOME"=>user_home, "QUEUE"=>queue, "RAILS_ENV"=>rails_env }
|
w.start = "HOME=#{user_home} QUEUE=* RAILS_ENV=#{rails_env} rake -f #{rails_root}/Rakefile resque:work"
|
||||||
w.start = "rake -f #{rails_root}/Rakefile resque:work"
|
|
||||||
w.stop = "sudo kill -KILL $(cat #{w.pid_file})"
|
|
||||||
w.uid = (rails_env == 'production' )? "root" : development_uid
|
w.uid = (rails_env == 'production' )? "root" : development_uid
|
||||||
w.gid = (rails_env == 'production' )? "root" : development_gid
|
w.gid = (rails_env == 'production' )? "root" : development_gid
|
||||||
|
|
||||||
w.log = (rails_env == 'production' )? "/var/log/#{w.group}/#{w.name}.log":"#{rails_root}/log/dev-#{w.name}.log"
|
w.log = (rails_env == 'production' )? "/var/log/#{w.group}/#{w.name}.log":"#{rails_root}/log/dev_resque-#{w.name}.log"
|
||||||
|
|
||||||
# restart if memory gets too high
|
# restart if memory gets too high
|
||||||
w.transition(:up, :restart) do |on|
|
w.transition(:up, :restart) do |on|
|
|
@ -6,19 +6,16 @@ development_gid = ''
|
||||||
|
|
||||||
God.watch do |w|
|
God.watch do |w|
|
||||||
w.dir = rails_root
|
w.dir = rails_root
|
||||||
w.name = "<%= @resque_namespace.nil? ? "" : "#{@resque_namespace}-" %>sunspot-solr"
|
w.name = "scheduler"
|
||||||
w.group = 'rulingcom'
|
w.group = 'resque'
|
||||||
w.pid_file = "#{rails_root}/solr/pids/production/sunspot-solr-production.pid"
|
|
||||||
w.interval = 30.seconds
|
w.interval = 30.seconds
|
||||||
w.env = {"RAILS_ENV"=>rails_env,"HOME"=>user_home ,"RAILS_ENV"=>rails_env}
|
w.env = {"QUEUE"=>"critical,high,low", "RAILS_ENV"=>rails_env}
|
||||||
w.start = "rake -f #{rails_root}/Rakefile sunspot:solr:start"
|
w.start = "HOME= #{user_home} QUEUE=* RAILS_ENV=#{rails_env} rake -f #{rails_root}/Rakefile resque:scheduler"
|
||||||
w.stop = "sudo kill -KILL $(cat #{w.pid_file})"
|
|
||||||
w.keepalive
|
|
||||||
|
|
||||||
w.uid = (rails_env == 'production' )? "root" : development_uid
|
w.uid = (rails_env == 'production' )? "root" : development_uid
|
||||||
w.gid = (rails_env == 'production' )? "root" : development_gid
|
w.gid = (rails_env == 'production' )? "root" : development_gid
|
||||||
|
|
||||||
w.log = (rails_env == 'production' )? "/var/log/#{w.group}/#{w.name}.log":"#{rails_root}/log/dev-#{w.name}.log"
|
w.log = (rails_env == 'production' )? "/var/log/#{w.group}/#{w.name}.log":"#{rails_root}/log/dev_resque-#{w.name}.log"
|
||||||
|
|
||||||
# restart if memory gets too high
|
# restart if memory gets too high
|
||||||
w.transition(:up, :restart) do |on|
|
w.transition(:up, :restart) do |on|
|
|
@ -1,15 +1,3 @@
|
||||||
dashboard_counter_cache:
|
|
||||||
cron: 0 * * * * *
|
|
||||||
class: DashboardCounter
|
|
||||||
args:
|
|
||||||
description: DashboardCounterCache
|
|
||||||
|
|
||||||
backup_server:
|
|
||||||
cron: 0 0 2 * * *
|
|
||||||
class: BackupServer
|
|
||||||
args:
|
|
||||||
description: BackupServer and remove old backups
|
|
||||||
|
|
||||||
update_tag_cloud:
|
update_tag_cloud:
|
||||||
cron: 0 0 [0,12] * * *
|
cron: 0 0 [0,12] * * *
|
||||||
class: UpdateTagCloud
|
class: UpdateTagCloud
|
||||||
|
@ -21,9 +9,3 @@ generate_system_summary:
|
||||||
class: GenerateSystemSummary
|
class: GenerateSystemSummary
|
||||||
args:
|
args:
|
||||||
description: Generate the system status such as disk free space,package version list for showing at site tab
|
description: Generate the system status such as disk free space,package version list for showing at site tab
|
||||||
|
|
||||||
email_cron:
|
|
||||||
cron: 0 0 [10,16,22] * * *
|
|
||||||
class: EmailCron
|
|
||||||
args:
|
|
||||||
description: EmailCron
|
|
||||||
|
|
|
@ -29,19 +29,6 @@ Orbit::Application.routes.draw do
|
||||||
get 'delete'
|
get 'delete'
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
resources :mail_crons do
|
|
||||||
collection do
|
|
||||||
get 'delete'
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
resources :mail_cron_logs do
|
|
||||||
collection do
|
|
||||||
get 'delete'
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
resources :asset_categories
|
resources :asset_categories
|
||||||
resources :asset_tags
|
resources :asset_tags
|
||||||
resources :app_auths
|
resources :app_auths
|
||||||
|
|
|
@ -1,18 +0,0 @@
|
||||||
class DelayImpressionistRequest
|
|
||||||
attr_accessor :session_options,:remote_ip,:referer,:user_agent
|
|
||||||
def initialize(request=nil)
|
|
||||||
if request
|
|
||||||
self.session_options=request.session_options
|
|
||||||
self.remote_ip=request.remote_ip
|
|
||||||
self.referer=request.referer
|
|
||||||
self.user_agent=request.user_agent
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def restore(args)
|
|
||||||
args.each do |key,value|
|
|
||||||
self.send("#{key}=", value)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
|
@ -6,14 +6,15 @@ module DefaultWidgetTagHelper
|
||||||
@request = req
|
@request = req
|
||||||
params.delete :inner
|
params.delete :inner
|
||||||
@params = params
|
@params = params
|
||||||
|
|
||||||
params_str ="?"
|
params_str ="?"
|
||||||
params.each do |index,param|
|
params.each do |index,param|
|
||||||
if param.is_a?(Array) and !param.blank?
|
if param.is_a?(Array) and !param.blank?
|
||||||
params_str << "&" unless params_str.eql?("?")
|
|
||||||
params_str << param.collect{|t| "#{index}[]=#{t}"}.join("&")
|
params_str << param.collect{|t| "#{index}[]=#{t}"}.join("&")
|
||||||
params.delete index
|
params.delete index
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
params_str = params_str + (params_str.eql?("?") ? params.to_param : "&#{params.to_param}" )
|
params_str = params_str + (params_str.eql?("?") ? params.to_param : "&#{params.to_param}" )
|
||||||
content_tag :div,:class=> 'more' do
|
content_tag :div,:class=> 'more' do
|
||||||
link_to I18n.t(@more_link[:label_i18n]),[eval("#{@more_link[:path_method]}"),params_str].join()
|
link_to I18n.t(@more_link[:label_i18n]),[eval("#{@more_link[:path_method]}"),params_str].join()
|
||||||
|
|
|
@ -1,28 +0,0 @@
|
||||||
module OrbitApp
|
|
||||||
module Module
|
|
||||||
module VisitorCounter
|
|
||||||
Version = "0.1"
|
|
||||||
|
|
||||||
def display_visitors(options={})
|
|
||||||
Site.first.visitor_counters["total"]
|
|
||||||
end
|
|
||||||
|
|
||||||
def display_visitors_today
|
|
||||||
Site.first.visitor_counters["today"]
|
|
||||||
end
|
|
||||||
|
|
||||||
def display_visitors_this_week
|
|
||||||
Site.first.visitor_counters["this_week"]
|
|
||||||
end
|
|
||||||
|
|
||||||
def display_visitors_this_month
|
|
||||||
Site.first.visitor_counters["this_month"]
|
|
||||||
end
|
|
||||||
|
|
||||||
def display_visitors_this_year
|
|
||||||
Site.first.visitor_counters["this_year"]
|
|
||||||
end
|
|
||||||
|
|
||||||
end # of VisitorCounter
|
|
||||||
end # of Module
|
|
||||||
end # of OrbitApp
|
|
|
@ -1,36 +0,0 @@
|
||||||
module OrbitApp
|
|
||||||
module Module
|
|
||||||
module VisitorCounterEval
|
|
||||||
Version = "0.1"
|
|
||||||
|
|
||||||
def display_visitors(options={})
|
|
||||||
map = "function(){ emit( this.referrer,{session_hash: this.session_hash,created_at: this.created_at}); };"
|
|
||||||
reduce = "function(key, values){ var sum = 0; values.forEach(function(doc){sum += doc.amount; }); return {amount: sum};};"
|
|
||||||
if options.blank?
|
|
||||||
impressions = Impression.collection.map_reduce(map, reduce,read: :primary, out: "vr")
|
|
||||||
else
|
|
||||||
query = Impression.where(options).selector
|
|
||||||
impressions = Impression.where(options).collection.map_reduce(map, reduce,read: :primary, out: "vr",:query=>query)
|
|
||||||
end
|
|
||||||
impressions.count
|
|
||||||
end
|
|
||||||
|
|
||||||
def display_visitors_today
|
|
||||||
display_visitors(created_at: {'$gte' => Date.today.beginning_of_day , '$lte' => DateTime.now})
|
|
||||||
end
|
|
||||||
|
|
||||||
def display_visitors_this_week
|
|
||||||
display_visitors(created_at: {'$gte' => Date.today.beginning_of_day - 7.days, '$lte' => DateTime.now})
|
|
||||||
end
|
|
||||||
|
|
||||||
def display_visitors_this_month
|
|
||||||
display_visitors(created_at: {'$gte' => Date.today.beginning_of_day - 1.month, '$lte' => DateTime.now})
|
|
||||||
end
|
|
||||||
|
|
||||||
def display_visitors_this_year
|
|
||||||
display_visitors(created_at: {'$gte' => Date.today.beginning_of_day - 1.year, '$lte' =>DateTime.now})
|
|
||||||
end
|
|
||||||
end # end of VisitorCounterEval
|
|
||||||
end # of Module
|
|
||||||
end # of OrbitApp
|
|
||||||
|
|
|
@ -102,17 +102,12 @@ module OrbitApp
|
||||||
def initialize(&block)
|
def initialize(&block)
|
||||||
@query = nil
|
@query = nil
|
||||||
@image = nil
|
@image = nil
|
||||||
@sorting_query = 'desc(:created_at)'
|
|
||||||
@more_link = {}
|
@more_link = {}
|
||||||
@fields = []
|
@fields = []
|
||||||
@enabled_styles = STYLE
|
@enabled_styles = STYLE
|
||||||
block.arity < 1 ? instance_eval(&block) : block.call(self) if block_given?
|
block.arity < 1 ? instance_eval(&block) : block.call(self) if block_given?
|
||||||
end
|
end
|
||||||
|
|
||||||
def sorting(query)
|
|
||||||
@sorting_query = query
|
|
||||||
end
|
|
||||||
|
|
||||||
def enable(args)
|
def enable(args)
|
||||||
@enabled_styles = args
|
@enabled_styles = args
|
||||||
end
|
end
|
||||||
|
@ -127,7 +122,7 @@ module OrbitApp
|
||||||
end
|
end
|
||||||
|
|
||||||
def to_module_app_format
|
def to_module_app_format
|
||||||
{"query"=>@query,"image"=>@image,"more_link"=>@more_link,"enabled_styles"=>@enabled_styles,:sorting_query=>@sorting_query} rescue nil
|
{"query"=>@query,"image"=>@image,"more_link"=>@more_link,"enabled_styles"=>@enabled_styles} rescue nil
|
||||||
end
|
end
|
||||||
|
|
||||||
def link_field(field_name,setting)
|
def link_field(field_name,setting)
|
||||||
|
|
|
@ -79,10 +79,9 @@ module OrbitCoreLib
|
||||||
else
|
else
|
||||||
auth_object_space = ObjectAuth.where(obj_authable_type: self.to_s,title: title)
|
auth_object_space = ObjectAuth.where(obj_authable_type: self.to_s,title: title)
|
||||||
end
|
end
|
||||||
query1 = auth_object_space.any_in({sub_role_ids: sub_role_ids_ary}).excludes(blocked_user_ids: user.id)
|
|
||||||
query2 = auth_object_space.any_of({all: true},{privilege_user_ids: user.id}).excludes(blocked_user_ids: user.id)
|
|
||||||
# query2 = auth_object_space.any_of({all: true},{privilege_user_ids: user.id},{role_ids: user.role_ids}).excludes(blocked_user_ids: user.id) #save for backup if something went wrong (0626 Matt)
|
|
||||||
|
|
||||||
|
query1 = auth_object_space.any_in({sub_role_ids: sub_role_ids_ary}).excludes(blocked_user_ids: user.id)
|
||||||
|
query2 = auth_object_space.any_of({all: true},{privilege_user_ids: user.id},{role_ids: user.role_ids}).excludes(blocked_user_ids: user.id)
|
||||||
result = (query1 + query2).uniq
|
result = (query1 + query2).uniq
|
||||||
result.collect{|t| t.obj_authable}.delete_if{|val| val==nil}
|
result.collect{|t| t.obj_authable}.delete_if{|val| val==nil}
|
||||||
end
|
end
|
||||||
|
|
|
@ -43,7 +43,6 @@ module OrbitTag
|
||||||
def tags=(tag_ids)
|
def tags=(tag_ids)
|
||||||
ids = [tag_ids].flatten
|
ids = [tag_ids].flatten
|
||||||
tag_ids.delete('')
|
tag_ids.delete('')
|
||||||
self.tagged_ids = tag_ids
|
|
||||||
ids = self.taggings.blank? ? [] : self.taggings.map{|t| t.tag.id}
|
ids = self.taggings.blank? ? [] : self.taggings.map{|t| t.tag.id}
|
||||||
tag_ids.each do |tag_id|
|
tag_ids.each do |tag_id|
|
||||||
unless ids.include? tag_id
|
unless ids.include? tag_id
|
||||||
|
@ -59,6 +58,9 @@ module OrbitTag
|
||||||
|
|
||||||
def tag_ids=(ids)
|
def tag_ids=(ids)
|
||||||
self.tags = ids
|
self.tags = ids
|
||||||
|
ids = [ids].flatten
|
||||||
|
ids.delete('')
|
||||||
|
self.tagged_ids = ids
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
|
@ -310,60 +310,4 @@ namespace :migrate do
|
||||||
Rake::Task["web_link_url:web_link_url_i18n"].execute
|
Rake::Task["web_link_url:web_link_url_i18n"].execute
|
||||||
end
|
end
|
||||||
|
|
||||||
task :fix_tagged_ids => :environment do
|
|
||||||
Tag.all.each do |tag|
|
|
||||||
tag.taggings.each do |tagging|
|
|
||||||
tagged_ids = tagging.taggable.tagged_ids
|
|
||||||
unless tagged_ids.include?(tag.id.to_s)
|
|
||||||
tagged_ids << tag.id.to_s
|
|
||||||
tagging.taggable.update_attribute(:tagged_ids, tagged_ids)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
task :clear_news_tags => :environment do
|
|
||||||
`mongo #{Mongoid.config.database.name} --eval "db.tags.remove({_type: {$ne: 'Tag'}})"`
|
|
||||||
end
|
|
||||||
|
|
||||||
task :add_missing_user_link => :environment do
|
|
||||||
User.all.each do |user|
|
|
||||||
user.role_ids.uniq!
|
|
||||||
user.sub_role_ids.uniq!
|
|
||||||
user.save
|
|
||||||
user.roles.each do |role|
|
|
||||||
unless role.user_ids.include?(user.id)
|
|
||||||
role.user_ids << user.id
|
|
||||||
role.save
|
|
||||||
end
|
|
||||||
end
|
|
||||||
user.sub_roles.each do |sub_role|
|
|
||||||
unless sub_role.user_ids.include?(user.id)
|
|
||||||
sub_role.user_ids << user.id
|
|
||||||
sub_role.save
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
Role.all.each do |role|
|
|
||||||
role.user_ids.uniq!
|
|
||||||
role.save
|
|
||||||
role.users.each do |user|
|
|
||||||
unless user.role_ids.include?(role.id)
|
|
||||||
user.role_ids << role.id
|
|
||||||
user.save
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
SubRole.all.each do |sub_role|
|
|
||||||
sub_role.user_ids.uniq!
|
|
||||||
sub_role.save
|
|
||||||
sub_role.users.each do |user|
|
|
||||||
unless user.sub_role_ids.include?(sub_role.id)
|
|
||||||
user.sub_role_ids << sub_role.id
|
|
||||||
user.save
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -15,7 +15,7 @@ namespace :resque do
|
||||||
require 'resque/scheduler'
|
require 'resque/scheduler'
|
||||||
|
|
||||||
# you probably already have this somewhere
|
# you probably already have this somewhere
|
||||||
# Resque.redis = 'localhost:6379'
|
Resque.redis = 'localhost:6379'
|
||||||
|
|
||||||
# If you want to be able to dynamically change the schedule,
|
# If you want to be able to dynamically change the schedule,
|
||||||
# uncomment this line. A dynamic schedule can be updated via the
|
# uncomment this line. A dynamic schedule can be updated via the
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
# encoding: utf-8
|
# encoding: utf-8
|
||||||
require 'erb'
|
|
||||||
|
|
||||||
namespace :site do
|
namespace :site do
|
||||||
|
|
||||||
|
@ -10,7 +9,6 @@ namespace :site do
|
||||||
Site.create( :school => 'RulingDigital University', :department => 'Computer Science', :valid_locales => [ 'en', 'zh_tw' ], :in_use_locales => [ 'zh_tw', 'en' ])
|
Site.create( :school => 'RulingDigital University', :department => 'Computer Science', :valid_locales => [ 'en', 'zh_tw' ], :in_use_locales => [ 'zh_tw', 'en' ])
|
||||||
User.create!(:email=>'chris@rulingcom.com',:admin=>true,:user_id=>'chris',:password=>'password')
|
User.create!(:email=>'chris@rulingcom.com',:admin=>true,:user_id=>'chris',:password=>'password')
|
||||||
`mongo #{Mongoid.config.database.name} --eval "db.fs.chunks.ensureIndex({files_id: 1, n: 1})"`
|
`mongo #{Mongoid.config.database.name} --eval "db.fs.chunks.ensureIndex({files_id: 1, n: 1})"`
|
||||||
|
|
||||||
puts "Congres you can now login within url"
|
puts "Congres you can now login within url"
|
||||||
puts 'Please upload design package (/admin/designs/upload_package ) and run rake site:necessary_data'
|
puts 'Please upload design package (/admin/designs/upload_package ) and run rake site:necessary_data'
|
||||||
I18nVariable.create!( :document_class => 'language', :key => 'en', :en => 'English', :zh_tw => '英文' )
|
I18nVariable.create!( :document_class => 'language', :key => 'en', :en => 'English', :zh_tw => '英文' )
|
||||||
|
@ -18,18 +16,14 @@ namespace :site do
|
||||||
Info.create!(key: "profile", built_in: true, disabled: false, title: {"zh_tw"=>"基本欄位", "en"=>"Basic Info"}, to_search: false)
|
Info.create!(key: "profile", built_in: true, disabled: false, title: {"zh_tw"=>"基本欄位", "en"=>"Basic Info"}, to_search: false)
|
||||||
end
|
end
|
||||||
|
|
||||||
task :create_logrotate => :environment do #Can remove after all products update
|
|
||||||
create_rulingcom_logrotate
|
|
||||||
end
|
|
||||||
|
|
||||||
task :necessary_data => :environment do
|
task :necessary_data => :environment do
|
||||||
auto_setting
|
|
||||||
site = Site.first
|
site = Site.first
|
||||||
site.update_attribute(:title,'RulingOrbit Demo Site')
|
site.title = 'RulingOrbit Demo Site'
|
||||||
site.update_attribute(:resque_namespace,@resque_namespace)
|
site.save
|
||||||
|
|
||||||
# home_trans = I18nVariable.create!( :document_class => 'Home', :key => 'home', :en => 'Homepage', :zh_tw => '首頁')
|
# home_trans = I18nVariable.create!( :document_class => 'Home', :key => 'home', :en => 'Homepage', :zh_tw => '首頁')
|
||||||
design = Design.first
|
design = Design.first
|
||||||
|
site = Site.first
|
||||||
site.design = design
|
site.design = design
|
||||||
site.save
|
site.save
|
||||||
theme = design.themes.first
|
theme = design.themes.first
|
||||||
|
@ -37,78 +31,6 @@ namespace :site do
|
||||||
|
|
||||||
home.title_translations = {"zh_tw"=>"首頁", "en"=>"Home"}
|
home.title_translations = {"zh_tw"=>"首頁", "en"=>"Home"}
|
||||||
home.save
|
home.save
|
||||||
|
|
||||||
puts "Rember to restart server after you setup all sites for starting God"
|
|
||||||
end
|
|
||||||
|
|
||||||
task :start_auto_setting => :environment do
|
|
||||||
auto_setting
|
|
||||||
end
|
|
||||||
|
|
||||||
def auto_setting
|
|
||||||
puts "Enter your resque namespace[Orbit]:......"
|
|
||||||
@resque_namespace = STDIN.gets.gsub("\n",'')
|
|
||||||
@resque_namespace = APP_CONFIG['orbit'] if @resque_namespace.empty?
|
|
||||||
|
|
||||||
|
|
||||||
puts "Is this the only site [ Entry site? ] on this mechine?[Default No]:......"
|
|
||||||
site_is_alone = false
|
|
||||||
site_is_alone = STDIN.gets.gsub("\n",'')
|
|
||||||
site_is_alone = true if site_is_alone.downcase == 'yes'
|
|
||||||
|
|
||||||
puts "Is this a primary site?[Default No]:......"
|
|
||||||
site_is_primary = false
|
|
||||||
site_is_primary = STDIN.gets.gsub("\n",'')
|
|
||||||
site_is_primary = true if site_is_primary.downcase == 'yes'
|
|
||||||
|
|
||||||
puts "Traffic heavy?[Default No]:......"
|
|
||||||
traffic_heavy = false
|
|
||||||
traffic_heavy = STDIN.gets.gsub("\n",'')
|
|
||||||
traffic_heavy = true if traffic_heavy.downcase == 'yes'
|
|
||||||
|
|
||||||
@traffic_rate = traffic_heavy ? 2 : 1
|
|
||||||
|
|
||||||
if site_is_alone
|
|
||||||
@resque_workers = 5 * @traffic_rate #Entry Site
|
|
||||||
else
|
|
||||||
if site_is_primary
|
|
||||||
@resque_workers = 2 * @traffic_rate #Primary Site
|
|
||||||
else
|
|
||||||
@resque_workers = 1 * @traffic_rate #Secondary Site
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
resque_setting = ERB.new(File.new("lib/template/setting/resque.god.erb").read)
|
|
||||||
File.open("config/resque.god", 'w') { |file| file.write(resque_setting.result) }
|
|
||||||
|
|
||||||
resque_schedule_setting = ERB.new(File.new("lib/template/setting/resque_schedule.god.erb").read)
|
|
||||||
File.open("config/resque_schedule.god", 'w') { |file| file.write(resque_schedule_setting.result) }
|
|
||||||
|
|
||||||
if site_is_primary
|
|
||||||
solr_setting = ERB.new(File.new("lib/template/setting/solr.god.erb").read)
|
|
||||||
File.open("config/solr.god", 'w') { |file| file.write(solr_setting.result) }
|
|
||||||
create_rulingcom_logrotate
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
def create_rulingcom_logrotate
|
|
||||||
`sudo mkdir -p /var/log/rulingcom` unless File.directory? "/var/log/rulingcom"
|
|
||||||
@project_folder = ENV["PWD"]
|
|
||||||
puts "Is your Orbit folder: #{@project_folder} (If YES => Press enter,or enter your path)"
|
|
||||||
user_enter_project_folder = STDIN.gets.gsub("\n",'')
|
|
||||||
@project_folder = user_enter_project_folder unless user_enter_project_folder.empty?
|
|
||||||
|
|
||||||
@user_home_folder = ENV["HOME"]
|
|
||||||
puts "Is your Home folder: #{@user_home_folder} (If YES => Press enter,or enter your path)"
|
|
||||||
user_enter_home_folder = STDIN.gets.gsub("\n",'')
|
|
||||||
@user_home_folder = user_enter_home_folder unless user_enter_home_folder.empty?
|
|
||||||
|
|
||||||
logrotate_setting = ERB.new(File.new("lib/template/setting/rulingcom_log.erb").read)
|
|
||||||
File.open("#{@project_loc}/tmp/logrotate_setting", 'w') { |file| file.write(logrotate_setting.result) }
|
|
||||||
|
|
||||||
`sudo cp #{@project_loc}/tmp/logrotate_setting /etc/logrotate.d/rulingcom`
|
|
||||||
`logrotate -v -f /etc/logrotate.conf`
|
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,14 +0,0 @@
|
||||||
# encoding: utf-8
|
|
||||||
namespace :system_check do
|
|
||||||
task :god_can_start => :environment do
|
|
||||||
unless File.directory? "/var/log/rulingcom"
|
|
||||||
puts "Creating Rulingcom log folder"
|
|
||||||
`sudo mkdir -p /var/log/rulingcom`
|
|
||||||
end
|
|
||||||
end
|
|
||||||
task :set_resque_namespace,[:namespace] => :environment do |t,args|
|
|
||||||
site = Site.first
|
|
||||||
site.resque_namespace = args[:namespace]
|
|
||||||
site.save
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -1,59 +0,0 @@
|
||||||
rails_env = ENV['RAILS_ENV'] || "production"
|
|
||||||
rails_root = ENV['RAILS_ROOT'] || File.dirname(__FILE__) + '/..'
|
|
||||||
user_home = ENV['HOME'] || File.dirname(__FILE__) + '/../..'
|
|
||||||
development_uid = ''
|
|
||||||
development_gid = ''
|
|
||||||
|
|
||||||
God.watch do |w|
|
|
||||||
w.dir = rails_root
|
|
||||||
w.name = "<%= @resque_namespace.nil? ? "" : "#{@resque_namespace}-" %>resque-scheduler"
|
|
||||||
w.group = 'rulingcom'
|
|
||||||
w.interval = 10.seconds
|
|
||||||
w.pid_file = "#{rails_root}/tmp/#{w.name}.pid"
|
|
||||||
|
|
||||||
w.env = {"QUEUE"=>"*", "RAILS_ENV"=>rails_env,"HOME"=>user_home, "RAILS_ENV"=>rails_env}
|
|
||||||
w.start = "rake -f #{rails_root}/Rakefile resque:scheduler"
|
|
||||||
w.stop = "sudo kill -KILL $(cat #{w.pid_file})"
|
|
||||||
w.uid = (rails_env == 'production' )? "root" : development_uid
|
|
||||||
w.gid = (rails_env == 'production' )? "root" : development_gid
|
|
||||||
|
|
||||||
w.log = (rails_env == 'production' )? "/var/log/#{w.group}/#{w.name}.log":"#{rails_root}/log/dev-#{w.name}.log"
|
|
||||||
|
|
||||||
# restart if memory gets too high
|
|
||||||
w.transition(:up, :restart) do |on|
|
|
||||||
on.condition(:memory_usage) do |c|
|
|
||||||
c.above = 350.megabytes
|
|
||||||
c.times = 2
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
# determine the state on startup
|
|
||||||
w.transition(:init, { true => :up, false => :start }) do |on|
|
|
||||||
on.condition(:process_running) do |c|
|
|
||||||
c.running = true
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
# determine when process has finished starting
|
|
||||||
w.transition([:start, :restart], :up) do |on|
|
|
||||||
on.condition(:process_running) do |c|
|
|
||||||
c.running = true
|
|
||||||
c.interval = 5.seconds
|
|
||||||
end
|
|
||||||
|
|
||||||
# failsafe
|
|
||||||
on.condition(:tries) do |c|
|
|
||||||
c.times = 5
|
|
||||||
c.transition = :start
|
|
||||||
c.interval = 5.seconds
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
# start if process is not running
|
|
||||||
w.transition(:up, :start) do |on|
|
|
||||||
on.condition(:process_running) do |c|
|
|
||||||
c.running = false
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
|
@ -1,33 +0,0 @@
|
||||||
/var/log/rulingcom/*.log {
|
|
||||||
daily
|
|
||||||
dateext
|
|
||||||
compress
|
|
||||||
rotate 30
|
|
||||||
}
|
|
||||||
|
|
||||||
#Resque
|
|
||||||
<%= "#{@project_folder}/nginx/logs/access.log" %>{
|
|
||||||
daily
|
|
||||||
dateext
|
|
||||||
compress
|
|
||||||
rotate 30
|
|
||||||
}
|
|
||||||
|
|
||||||
#DB log
|
|
||||||
/var/log/mongodb{
|
|
||||||
daily
|
|
||||||
dateext
|
|
||||||
compress
|
|
||||||
rotate 30
|
|
||||||
}
|
|
||||||
|
|
||||||
#Orbit
|
|
||||||
<%= "#{@project_folder}/log/*production.log" %>{
|
|
||||||
daily
|
|
||||||
dateext
|
|
||||||
compress
|
|
||||||
rotate 30
|
|
||||||
}
|
|
||||||
# end of Orbit,EXTEND IF NEEDED
|
|
||||||
|
|
||||||
#Remember to save this file as /etc/logrotate.d/rulingcom
|
|
|
@ -1,31 +0,0 @@
|
||||||
<!--
|
|
||||||
Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
contributor license agreements. See the NOTICE file distributed with
|
|
||||||
this work for additional information regarding copyright ownership.
|
|
||||||
The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
(the "License"); you may not use this file except in compliance with
|
|
||||||
the License. You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
-->
|
|
||||||
|
|
||||||
<!-- The content of this page will be statically included into the top
|
|
||||||
of the admin page. Uncomment this as an example to see there the content
|
|
||||||
will show up.
|
|
||||||
|
|
||||||
<hr>
|
|
||||||
<i>This line will appear before the first table</i>
|
|
||||||
<tr>
|
|
||||||
<td colspan="2">
|
|
||||||
This row will be appended to the end of the first table
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<hr>
|
|
||||||
|
|
||||||
-->
|
|
|
@ -1,36 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
|
||||||
<!--
|
|
||||||
Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
contributor license agreements. See the NOTICE file distributed with
|
|
||||||
this work for additional information regarding copyright ownership.
|
|
||||||
The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
(the "License"); you may not use this file except in compliance with
|
|
||||||
the License. You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
-->
|
|
||||||
|
|
||||||
<!-- If this file is found in the config directory, it will only be
|
|
||||||
loaded once at startup. If it is found in Solr's data
|
|
||||||
directory, it will be re-loaded every commit.
|
|
||||||
-->
|
|
||||||
|
|
||||||
<elevate>
|
|
||||||
<query text="foo bar">
|
|
||||||
<doc id="1" />
|
|
||||||
<doc id="2" />
|
|
||||||
<doc id="3" />
|
|
||||||
</query>
|
|
||||||
|
|
||||||
<query text="ipod">
|
|
||||||
<doc id="MA147LL/A" /> <!-- put the actual ipod at the top -->
|
|
||||||
<doc id="IW-02" exclude="true" /> <!-- exclude this cable -->
|
|
||||||
</query>
|
|
||||||
|
|
||||||
</elevate>
|
|
|
@ -1,246 +0,0 @@
|
||||||
# The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
# (the "License"); you may not use this file except in compliance with
|
|
||||||
# the License. You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# Syntax:
|
|
||||||
# "source" => "target"
|
|
||||||
# "source".length() > 0 (source cannot be empty.)
|
|
||||||
# "target".length() >= 0 (target can be empty.)
|
|
||||||
|
|
||||||
# example:
|
|
||||||
# "À" => "A"
|
|
||||||
# "\u00C0" => "A"
|
|
||||||
# "\u00C0" => "\u0041"
|
|
||||||
# "ß" => "ss"
|
|
||||||
# "\t" => " "
|
|
||||||
# "\n" => ""
|
|
||||||
|
|
||||||
# À => A
|
|
||||||
"\u00C0" => "A"
|
|
||||||
|
|
||||||
# Á => A
|
|
||||||
"\u00C1" => "A"
|
|
||||||
|
|
||||||
# Â => A
|
|
||||||
"\u00C2" => "A"
|
|
||||||
|
|
||||||
# Ã => A
|
|
||||||
"\u00C3" => "A"
|
|
||||||
|
|
||||||
# Ä => A
|
|
||||||
"\u00C4" => "A"
|
|
||||||
|
|
||||||
# Å => A
|
|
||||||
"\u00C5" => "A"
|
|
||||||
|
|
||||||
# Æ => AE
|
|
||||||
"\u00C6" => "AE"
|
|
||||||
|
|
||||||
# Ç => C
|
|
||||||
"\u00C7" => "C"
|
|
||||||
|
|
||||||
# È => E
|
|
||||||
"\u00C8" => "E"
|
|
||||||
|
|
||||||
# É => E
|
|
||||||
"\u00C9" => "E"
|
|
||||||
|
|
||||||
# Ê => E
|
|
||||||
"\u00CA" => "E"
|
|
||||||
|
|
||||||
# Ë => E
|
|
||||||
"\u00CB" => "E"
|
|
||||||
|
|
||||||
# Ì => I
|
|
||||||
"\u00CC" => "I"
|
|
||||||
|
|
||||||
# Í => I
|
|
||||||
"\u00CD" => "I"
|
|
||||||
|
|
||||||
# Î => I
|
|
||||||
"\u00CE" => "I"
|
|
||||||
|
|
||||||
# Ï => I
|
|
||||||
"\u00CF" => "I"
|
|
||||||
|
|
||||||
# IJ => IJ
|
|
||||||
"\u0132" => "IJ"
|
|
||||||
|
|
||||||
# Ð => D
|
|
||||||
"\u00D0" => "D"
|
|
||||||
|
|
||||||
# Ñ => N
|
|
||||||
"\u00D1" => "N"
|
|
||||||
|
|
||||||
# Ò => O
|
|
||||||
"\u00D2" => "O"
|
|
||||||
|
|
||||||
# Ó => O
|
|
||||||
"\u00D3" => "O"
|
|
||||||
|
|
||||||
# Ô => O
|
|
||||||
"\u00D4" => "O"
|
|
||||||
|
|
||||||
# Õ => O
|
|
||||||
"\u00D5" => "O"
|
|
||||||
|
|
||||||
# Ö => O
|
|
||||||
"\u00D6" => "O"
|
|
||||||
|
|
||||||
# Ø => O
|
|
||||||
"\u00D8" => "O"
|
|
||||||
|
|
||||||
# Œ => OE
|
|
||||||
"\u0152" => "OE"
|
|
||||||
|
|
||||||
# Þ
|
|
||||||
"\u00DE" => "TH"
|
|
||||||
|
|
||||||
# Ù => U
|
|
||||||
"\u00D9" => "U"
|
|
||||||
|
|
||||||
# Ú => U
|
|
||||||
"\u00DA" => "U"
|
|
||||||
|
|
||||||
# Û => U
|
|
||||||
"\u00DB" => "U"
|
|
||||||
|
|
||||||
# Ü => U
|
|
||||||
"\u00DC" => "U"
|
|
||||||
|
|
||||||
# Ý => Y
|
|
||||||
"\u00DD" => "Y"
|
|
||||||
|
|
||||||
# Ÿ => Y
|
|
||||||
"\u0178" => "Y"
|
|
||||||
|
|
||||||
# à => a
|
|
||||||
"\u00E0" => "a"
|
|
||||||
|
|
||||||
# á => a
|
|
||||||
"\u00E1" => "a"
|
|
||||||
|
|
||||||
# â => a
|
|
||||||
"\u00E2" => "a"
|
|
||||||
|
|
||||||
# ã => a
|
|
||||||
"\u00E3" => "a"
|
|
||||||
|
|
||||||
# ä => a
|
|
||||||
"\u00E4" => "a"
|
|
||||||
|
|
||||||
# å => a
|
|
||||||
"\u00E5" => "a"
|
|
||||||
|
|
||||||
# æ => ae
|
|
||||||
"\u00E6" => "ae"
|
|
||||||
|
|
||||||
# ç => c
|
|
||||||
"\u00E7" => "c"
|
|
||||||
|
|
||||||
# è => e
|
|
||||||
"\u00E8" => "e"
|
|
||||||
|
|
||||||
# é => e
|
|
||||||
"\u00E9" => "e"
|
|
||||||
|
|
||||||
# ê => e
|
|
||||||
"\u00EA" => "e"
|
|
||||||
|
|
||||||
# ë => e
|
|
||||||
"\u00EB" => "e"
|
|
||||||
|
|
||||||
# ì => i
|
|
||||||
"\u00EC" => "i"
|
|
||||||
|
|
||||||
# í => i
|
|
||||||
"\u00ED" => "i"
|
|
||||||
|
|
||||||
# î => i
|
|
||||||
"\u00EE" => "i"
|
|
||||||
|
|
||||||
# ï => i
|
|
||||||
"\u00EF" => "i"
|
|
||||||
|
|
||||||
# ij => ij
|
|
||||||
"\u0133" => "ij"
|
|
||||||
|
|
||||||
# ð => d
|
|
||||||
"\u00F0" => "d"
|
|
||||||
|
|
||||||
# ñ => n
|
|
||||||
"\u00F1" => "n"
|
|
||||||
|
|
||||||
# ò => o
|
|
||||||
"\u00F2" => "o"
|
|
||||||
|
|
||||||
# ó => o
|
|
||||||
"\u00F3" => "o"
|
|
||||||
|
|
||||||
# ô => o
|
|
||||||
"\u00F4" => "o"
|
|
||||||
|
|
||||||
# õ => o
|
|
||||||
"\u00F5" => "o"
|
|
||||||
|
|
||||||
# ö => o
|
|
||||||
"\u00F6" => "o"
|
|
||||||
|
|
||||||
# ø => o
|
|
||||||
"\u00F8" => "o"
|
|
||||||
|
|
||||||
# œ => oe
|
|
||||||
"\u0153" => "oe"
|
|
||||||
|
|
||||||
# ß => ss
|
|
||||||
"\u00DF" => "ss"
|
|
||||||
|
|
||||||
# þ => th
|
|
||||||
"\u00FE" => "th"
|
|
||||||
|
|
||||||
# ù => u
|
|
||||||
"\u00F9" => "u"
|
|
||||||
|
|
||||||
# ú => u
|
|
||||||
"\u00FA" => "u"
|
|
||||||
|
|
||||||
# û => u
|
|
||||||
"\u00FB" => "u"
|
|
||||||
|
|
||||||
# ü => u
|
|
||||||
"\u00FC" => "u"
|
|
||||||
|
|
||||||
# ý => y
|
|
||||||
"\u00FD" => "y"
|
|
||||||
|
|
||||||
# ÿ => y
|
|
||||||
"\u00FF" => "y"
|
|
||||||
|
|
||||||
# ff => ff
|
|
||||||
"\uFB00" => "ff"
|
|
||||||
|
|
||||||
# fi => fi
|
|
||||||
"\uFB01" => "fi"
|
|
||||||
|
|
||||||
# fl => fl
|
|
||||||
"\uFB02" => "fl"
|
|
||||||
|
|
||||||
# ffi => ffi
|
|
||||||
"\uFB03" => "ffi"
|
|
||||||
|
|
||||||
# ffl => ffl
|
|
||||||
"\uFB04" => "ffl"
|
|
||||||
|
|
||||||
# ſt => ft
|
|
||||||
"\uFB05" => "ft"
|
|
||||||
|
|
||||||
# st => st
|
|
||||||
"\uFB06" => "st"
|
|
|
@ -1,21 +0,0 @@
|
||||||
# The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
# (the "License"); you may not use this file except in compliance with
|
|
||||||
# the License. You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
#-----------------------------------------------------------------------
|
|
||||||
# Use a protected word file to protect against the stemmer reducing two
|
|
||||||
# unrelated words to the same base word.
|
|
||||||
|
|
||||||
# Some non-words that normally won't be encountered,
|
|
||||||
# just to test that they won't be stemmed.
|
|
||||||
dontstems
|
|
||||||
zwhacky
|
|
||||||
|
|
|
@ -1,238 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!--
|
|
||||||
Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
contributor license agreements. See the NOTICE file distributed with
|
|
||||||
this work for additional information regarding copyright ownership.
|
|
||||||
The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
(the "License"); you may not use this file except in compliance with
|
|
||||||
the License. You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
-->
|
|
||||||
<!--
|
|
||||||
This is the Solr schema file. This file should be named "schema.xml" and
|
|
||||||
should be in the conf directory under the solr home
|
|
||||||
(i.e. ./solr/conf/schema.xml by default)
|
|
||||||
or located where the classloader for the Solr webapp can find it.
|
|
||||||
|
|
||||||
This example schema is the recommended starting point for users.
|
|
||||||
It should be kept correct and concise, usable out-of-the-box.
|
|
||||||
|
|
||||||
For more information, on how to customize this file, please see
|
|
||||||
http://wiki.apache.org/solr/SchemaXml
|
|
||||||
|
|
||||||
PERFORMANCE NOTE: this schema includes many optional features and should not
|
|
||||||
be used for benchmarking. To improve performance one could
|
|
||||||
- set stored="false" for all fields possible (esp large fields) when you
|
|
||||||
only need to search on the field but don't need to return the original
|
|
||||||
value.
|
|
||||||
- set indexed="false" if you don't need to search on the field, but only
|
|
||||||
return the field as a result of searching on other indexed fields.
|
|
||||||
- remove all unneeded copyField statements
|
|
||||||
- for best index size and searching performance, set "index" to false
|
|
||||||
for all general text fields, use copyField to copy them to the
|
|
||||||
catchall "text" field, and use that for searching.
|
|
||||||
- For maximum indexing performance, use the StreamingUpdateSolrServer
|
|
||||||
java client.
|
|
||||||
- Remember to run the JVM in server mode, and use a higher logging level
|
|
||||||
that avoids logging every request
|
|
||||||
-->
|
|
||||||
<schema name="sunspot" version="1.0">
|
|
||||||
<types>
|
|
||||||
<!-- field type definitions. The "name" attribute is
|
|
||||||
just a label to be used by field definitions. The "class"
|
|
||||||
attribute and any other attributes determine the real
|
|
||||||
behavior of the fieldType.
|
|
||||||
Class names starting with "solr" refer to java classes in the
|
|
||||||
org.apache.solr.analysis package.
|
|
||||||
-->
|
|
||||||
<!-- *** This fieldType is used by Sunspot! *** -->
|
|
||||||
<fieldType name="string" class="solr.StrField" omitNorms="true"/>
|
|
||||||
<!-- *** This fieldType is used by Sunspot! *** -->
|
|
||||||
<fieldType name="tdouble" class="solr.TrieDoubleField" omitNorms="true"/>
|
|
||||||
<!-- *** This fieldType is used by Sunspot! *** -->
|
|
||||||
<fieldType name="rand" class="solr.RandomSortField" omitNorms="true"/>
|
|
||||||
<!-- *** This fieldType is used by Sunspot! *** -->
|
|
||||||
<fieldType name="text" class="solr.TextField" omitNorms="false">
|
|
||||||
<analyzer>
|
|
||||||
<tokenizer class="solr.CJKTokenizerFactory"/>
|
|
||||||
<filter class="solr.StandardFilterFactory"/>
|
|
||||||
<filter class="solr.LowerCaseFilterFactory"/>
|
|
||||||
</analyzer>
|
|
||||||
</fieldType>
|
|
||||||
<!-- *** This fieldType is used by Sunspot! *** -->
|
|
||||||
<fieldType name="boolean" class="solr.BoolField" omitNorms="true"/>
|
|
||||||
<!-- *** This fieldType is used by Sunspot! *** -->
|
|
||||||
<fieldType name="date" class="solr.DateField" omitNorms="true"/>
|
|
||||||
<!-- *** This fieldType is used by Sunspot! *** -->
|
|
||||||
<fieldType name="sdouble" class="solr.SortableDoubleField" omitNorms="true"/>
|
|
||||||
<!-- *** This fieldType is used by Sunspot! *** -->
|
|
||||||
<fieldType name="sfloat" class="solr.SortableFloatField" omitNorms="true"/>
|
|
||||||
<!-- *** This fieldType is used by Sunspot! *** -->
|
|
||||||
<fieldType name="sint" class="solr.SortableIntField" omitNorms="true"/>
|
|
||||||
<!-- *** This fieldType is used by Sunspot! *** -->
|
|
||||||
<fieldType name="slong" class="solr.SortableLongField" omitNorms="true"/>
|
|
||||||
<!-- *** This fieldType is used by Sunspot! *** -->
|
|
||||||
<fieldType name="tint" class="solr.TrieIntField" omitNorms="true"/>
|
|
||||||
<!-- *** This fieldType is used by Sunspot! *** -->
|
|
||||||
<fieldType name="tfloat" class="solr.TrieFloatField" omitNorms="true"/>
|
|
||||||
<!-- *** This fieldType is used by Sunspot! *** -->
|
|
||||||
<fieldType name="tdate" class="solr.TrieDateField" omitNorms="true"/>
|
|
||||||
</types>
|
|
||||||
<fields>
|
|
||||||
<!-- Valid attributes for fields:
|
|
||||||
name: mandatory - the name for the field
|
|
||||||
type: mandatory - the name of a previously defined type from the
|
|
||||||
<types> section
|
|
||||||
indexed: true if this field should be indexed (searchable or sortable)
|
|
||||||
stored: true if this field should be retrievable
|
|
||||||
compressed: [false] if this field should be stored using gzip compression
|
|
||||||
(this will only apply if the field type is compressable; among
|
|
||||||
the standard field types, only TextField and StrField are)
|
|
||||||
multiValued: true if this field may contain multiple values per document
|
|
||||||
omitNorms: (expert) set to true to omit the norms associated with
|
|
||||||
this field (this disables length normalization and index-time
|
|
||||||
boosting for the field, and saves some memory). Only full-text
|
|
||||||
fields or fields that need an index-time boost need norms.
|
|
||||||
termVectors: [false] set to true to store the term vector for a
|
|
||||||
given field.
|
|
||||||
When using MoreLikeThis, fields used for similarity should be
|
|
||||||
stored for best performance.
|
|
||||||
termPositions: Store position information with the term vector.
|
|
||||||
This will increase storage costs.
|
|
||||||
termOffsets: Store offset information with the term vector. This
|
|
||||||
will increase storage costs.
|
|
||||||
default: a value that should be used if no value is specified
|
|
||||||
when adding a document.
|
|
||||||
-->
|
|
||||||
<!-- *** This field is used by Sunspot! *** -->
|
|
||||||
<field name="id" stored="true" type="string" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This field is used by Sunspot! *** -->
|
|
||||||
<field name="type" stored="false" type="string" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This field is used by Sunspot! *** -->
|
|
||||||
<field name="class_name" stored="false" type="string" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This field is used by Sunspot! *** -->
|
|
||||||
<field name="text" stored="false" type="string" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This field is used by Sunspot! *** -->
|
|
||||||
<field name="lat" stored="true" type="tdouble" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This field is used by Sunspot! *** -->
|
|
||||||
<field name="lng" stored="true" type="tdouble" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="random_*" stored="false" type="rand" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="_local*" stored="false" type="tdouble" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_text" stored="false" type="text" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_texts" stored="true" type="text" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_b" stored="false" type="boolean" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_bm" stored="false" type="boolean" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_bs" stored="true" type="boolean" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_bms" stored="true" type="boolean" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_d" stored="false" type="date" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_dm" stored="false" type="date" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_ds" stored="true" type="date" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_dms" stored="true" type="date" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_e" stored="false" type="sdouble" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_em" stored="false" type="sdouble" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_es" stored="true" type="sdouble" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_ems" stored="true" type="sdouble" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_f" stored="false" type="sfloat" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_fm" stored="false" type="sfloat" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_fs" stored="true" type="sfloat" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_fms" stored="true" type="sfloat" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_i" stored="false" type="sint" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_im" stored="false" type="sint" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_is" stored="true" type="sint" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_ims" stored="true" type="sint" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_l" stored="false" type="slong" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_lm" stored="false" type="slong" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_ls" stored="true" type="slong" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_lms" stored="true" type="slong" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_s" stored="false" type="string" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_sm" stored="false" type="string" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_ss" stored="true" type="string" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_sms" stored="true" type="string" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_it" stored="false" type="tint" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_itm" stored="false" type="tint" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_its" stored="true" type="tint" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_itms" stored="true" type="tint" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_ft" stored="false" type="tfloat" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_ftm" stored="false" type="tfloat" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_fts" stored="true" type="tfloat" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_ftms" stored="true" type="tfloat" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_dt" stored="false" type="tdate" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_dtm" stored="false" type="tdate" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_dts" stored="true" type="tdate" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_dtms" stored="true" type="tdate" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_textv" stored="false" termVectors="true" type="text" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_textsv" stored="true" termVectors="true" type="text" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_et" stored="false" termVectors="true" type="tdouble" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_etm" stored="false" termVectors="true" type="tdouble" multiValued="true" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_ets" stored="true" termVectors="true" type="tdouble" multiValued="false" indexed="true"/>
|
|
||||||
<!-- *** This dynamicField is used by Sunspot! *** -->
|
|
||||||
<dynamicField name="*_etms" stored="true" termVectors="true" type="tdouble" multiValued="true" indexed="true"/>
|
|
||||||
</fields>
|
|
||||||
<!-- Field to use to determine and enforce document uniqueness.
|
|
||||||
Unless this field is marked with required="false", it will be a required field
|
|
||||||
-->
|
|
||||||
<uniqueKey>id</uniqueKey>
|
|
||||||
<!-- field for the QueryParser to use when an explicit fieldname is absent -->
|
|
||||||
<defaultSearchField>text</defaultSearchField>
|
|
||||||
<!-- SolrQueryParser configuration: defaultOperator="AND|OR" -->
|
|
||||||
<solrQueryParser defaultOperator="AND"/>
|
|
||||||
<!-- copyField commands copy one field to another at the time a document
|
|
||||||
is added to the index. It's used either to index the same field differently,
|
|
||||||
or to add multiple fields to the same field for easier/faster searching. -->
|
|
||||||
</schema>
|
|
|
@ -1,24 +0,0 @@
|
||||||
# Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
# contributor license agreements. See the NOTICE file distributed with
|
|
||||||
# this work for additional information regarding copyright ownership.
|
|
||||||
# The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
# (the "License"); you may not use this file except in compliance with
|
|
||||||
# the License. You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
user=
|
|
||||||
solr_hostname=localhost
|
|
||||||
solr_port=8983
|
|
||||||
rsyncd_port=18983
|
|
||||||
data_dir=
|
|
||||||
webapp_name=solr
|
|
||||||
master_host=
|
|
||||||
master_data_dir=
|
|
||||||
master_status_dir=
|
|
|
@ -1,934 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!--
|
|
||||||
Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
contributor license agreements. See the NOTICE file distributed with
|
|
||||||
this work for additional information regarding copyright ownership.
|
|
||||||
The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
(the "License"); you may not use this file except in compliance with
|
|
||||||
the License. You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
-->
|
|
||||||
<!--
|
|
||||||
For more details about configurations options that may appear in this
|
|
||||||
file, see http://wiki.apache.org/solr/SolrConfigXml.
|
|
||||||
|
|
||||||
Specifically, the Solr Config can support XInclude, which may make it easier to manage
|
|
||||||
the configuration. See https://issues.apache.org/jira/browse/SOLR-1167
|
|
||||||
-->
|
|
||||||
<config>
|
|
||||||
<!-- Set this to 'false' if you want solr to continue working after it has
|
|
||||||
encountered an severe configuration error. In a production environment,
|
|
||||||
you may want solr to keep working even if one handler is mis-configured.
|
|
||||||
|
|
||||||
You may also set this to false using by setting the system property:
|
|
||||||
-Dsolr.abortOnConfigurationError=false
|
|
||||||
-->
|
|
||||||
<abortOnConfigurationError>${solr.abortOnConfigurationError:true}</abortOnConfigurationError>
|
|
||||||
<!-- lib directives can be used to instruct Solr to load an Jars identified
|
|
||||||
and use them to resolve any "plugins" specified in your solrconfig.xml or
|
|
||||||
schema.xml (ie: Analyzers, Request Handlers, etc...).
|
|
||||||
|
|
||||||
All directories and paths are resolved relative the instanceDir.
|
|
||||||
|
|
||||||
If a "./lib" directory exists in your instanceDir, all files found in it
|
|
||||||
are included as if you had used the following syntax...
|
|
||||||
|
|
||||||
<lib dir="./lib" />
|
|
||||||
-->
|
|
||||||
<!-- A dir option by itself adds any files found in the directory to the
|
|
||||||
classpath, this is useful for including all jars in a directory.
|
|
||||||
-->
|
|
||||||
<lib dir="../../contrib/extraction/lib"/>
|
|
||||||
<!-- When a regex is specified in addition to a directory, only the files in that
|
|
||||||
directory which completely match the regex (anchored on both ends)
|
|
||||||
will be included.
|
|
||||||
-->
|
|
||||||
<lib dir="../../dist/" regex="apache-solr-cell-\d.*\.jar"/>
|
|
||||||
<lib dir="../../dist/" regex="apache-solr-clustering-\d.*\.jar"/>
|
|
||||||
<!-- If a dir option (with or without a regex) is used and nothing is found
|
|
||||||
that matches, it will be ignored
|
|
||||||
-->
|
|
||||||
<lib dir="../../contrib/clustering/lib/downloads/"/>
|
|
||||||
<lib dir="../../contrib/clustering/lib/"/>
|
|
||||||
<lib dir="/total/crap/dir/ignored"/>
|
|
||||||
<!-- an exact path can be used to specify a specific file. This will cause
|
|
||||||
a serious error to be logged if it can't be loaded.
|
|
||||||
<lib path="../a-jar-that-does-not-exist.jar" />
|
|
||||||
-->
|
|
||||||
<!-- Used to specify an alternate directory to hold all index data
|
|
||||||
other than the default ./data under the Solr home.
|
|
||||||
If replication is in use, this should match the replication configuration. -->
|
|
||||||
<dataDir>${solr.data.dir:./solr/data}</dataDir>
|
|
||||||
<!-- WARNING: this <indexDefaults> section only provides defaults for index writers
|
|
||||||
in general. See also the <mainIndex> section after that when changing parameters
|
|
||||||
for Solr's main Lucene index. -->
|
|
||||||
<indexDefaults>
|
|
||||||
<!-- Values here affect all index writers and act as a default unless overridden. -->
|
|
||||||
<useCompoundFile>false</useCompoundFile>
|
|
||||||
<mergeFactor>10</mergeFactor>
|
|
||||||
<!-- If both ramBufferSizeMB and maxBufferedDocs is set, then Lucene will flush
|
|
||||||
based on whichever limit is hit first. -->
|
|
||||||
<!--<maxBufferedDocs>1000</maxBufferedDocs>-->
|
|
||||||
<!-- Sets the amount of RAM that may be used by Lucene indexing
|
|
||||||
for buffering added documents and deletions before they are
|
|
||||||
flushed to the Directory. -->
|
|
||||||
<ramBufferSizeMB>32</ramBufferSizeMB>
|
|
||||||
<!-- <maxMergeDocs>2147483647</maxMergeDocs> -->
|
|
||||||
<maxFieldLength>10000</maxFieldLength>
|
|
||||||
<writeLockTimeout>1000</writeLockTimeout>
|
|
||||||
<commitLockTimeout>10000</commitLockTimeout>
|
|
||||||
<!--
|
|
||||||
Expert: Turn on Lucene's auto commit capability. This causes intermediate
|
|
||||||
segment flushes to write a new lucene index descriptor, enabling it to be
|
|
||||||
opened by an external IndexReader. This can greatly slow down indexing
|
|
||||||
speed. NOTE: Despite the name, this value does not have any relation to
|
|
||||||
Solr's autoCommit functionality
|
|
||||||
-->
|
|
||||||
<!--<luceneAutoCommit>false</luceneAutoCommit>-->
|
|
||||||
<!--
|
|
||||||
Expert: The Merge Policy in Lucene controls how merging is handled by
|
|
||||||
Lucene. The default in 2.3 is the LogByteSizeMergePolicy, previous
|
|
||||||
versions used LogDocMergePolicy.
|
|
||||||
|
|
||||||
LogByteSizeMergePolicy chooses segments to merge based on their size. The
|
|
||||||
Lucene 2.2 default, LogDocMergePolicy chose when to merge based on number
|
|
||||||
of documents
|
|
||||||
|
|
||||||
Other implementations of MergePolicy must have a no-argument constructor
|
|
||||||
-->
|
|
||||||
<!--<mergePolicy class="org.apache.lucene.index.LogByteSizeMergePolicy"/>-->
|
|
||||||
<!--
|
|
||||||
Expert:
|
|
||||||
The Merge Scheduler in Lucene controls how merges are performed. The
|
|
||||||
ConcurrentMergeScheduler (Lucene 2.3 default) can perform merges in the
|
|
||||||
background using separate threads. The SerialMergeScheduler (Lucene 2.2
|
|
||||||
default) does not.
|
|
||||||
-->
|
|
||||||
<!--<mergeScheduler class="org.apache.lucene.index.ConcurrentMergeScheduler"/>-->
|
|
||||||
<!--
|
|
||||||
This option specifies which Lucene LockFactory implementation to use.
|
|
||||||
|
|
||||||
single = SingleInstanceLockFactory - suggested for a read-only index
|
|
||||||
or when there is no possibility of another process trying
|
|
||||||
to modify the index.
|
|
||||||
native = NativeFSLockFactory - uses OS native file locking
|
|
||||||
simple = SimpleFSLockFactory - uses a plain file for locking
|
|
||||||
|
|
||||||
(For backwards compatibility with Solr 1.2, 'simple' is the default
|
|
||||||
if not specified.)
|
|
||||||
-->
|
|
||||||
<lockType>native</lockType>
|
|
||||||
<!--
|
|
||||||
Expert:
|
|
||||||
Controls how often Lucene loads terms into memory -->
|
|
||||||
<!--<termIndexInterval>256</termIndexInterval>-->
|
|
||||||
</indexDefaults>
|
|
||||||
<mainIndex>
|
|
||||||
<!-- options specific to the main on-disk lucene index -->
|
|
||||||
<useCompoundFile>false</useCompoundFile>
|
|
||||||
<ramBufferSizeMB>32</ramBufferSizeMB>
|
|
||||||
<mergeFactor>10</mergeFactor>
|
|
||||||
<!-- Deprecated -->
|
|
||||||
<!--<maxBufferedDocs>1000</maxBufferedDocs>-->
|
|
||||||
<!--<maxMergeDocs>2147483647</maxMergeDocs>-->
|
|
||||||
<!-- inherit from indexDefaults <maxFieldLength>10000</maxFieldLength> -->
|
|
||||||
<!-- If true, unlock any held write or commit locks on startup.
|
|
||||||
This defeats the locking mechanism that allows multiple
|
|
||||||
processes to safely access a lucene index, and should be
|
|
||||||
used with care.
|
|
||||||
This is not needed if lock type is 'none' or 'single'
|
|
||||||
-->
|
|
||||||
<unlockOnStartup>false</unlockOnStartup>
|
|
||||||
<!-- If true, IndexReaders will be reopened (often more efficient) instead
|
|
||||||
of closed and then opened. -->
|
|
||||||
<reopenReaders>true</reopenReaders>
|
|
||||||
<!--
|
|
||||||
Expert:
|
|
||||||
Controls how often Lucene loads terms into memory. Default is 128 and is likely good for most everyone. -->
|
|
||||||
<!--<termIndexInterval>256</termIndexInterval>-->
|
|
||||||
<!--
|
|
||||||
Custom deletion policies can specified here. The class must
|
|
||||||
implement org.apache.lucene.index.IndexDeletionPolicy.
|
|
||||||
|
|
||||||
http://lucene.apache.org/java/2_3_2/api/org/apache/lucene/index/IndexDeletionPolicy.html
|
|
||||||
|
|
||||||
The standard Solr IndexDeletionPolicy implementation supports deleting
|
|
||||||
index commit points on number of commits, age of commit point and
|
|
||||||
optimized status.
|
|
||||||
|
|
||||||
The latest commit point should always be preserved regardless
|
|
||||||
of the criteria.
|
|
||||||
-->
|
|
||||||
<deletionPolicy class="solr.SolrDeletionPolicy">
|
|
||||||
<!-- The number of commit points to be kept -->
|
|
||||||
<str name="maxCommitsToKeep">1</str>
|
|
||||||
<!-- The number of optimized commit points to be kept -->
|
|
||||||
<str name="maxOptimizedCommitsToKeep">0</str>
|
|
||||||
<!--
|
|
||||||
Delete all commit points once they have reached the given age.
|
|
||||||
Supports DateMathParser syntax e.g.
|
|
||||||
|
|
||||||
<str name="maxCommitAge">30MINUTES</str>
|
|
||||||
<str name="maxCommitAge">1DAY</str>
|
|
||||||
-->
|
|
||||||
</deletionPolicy>
|
|
||||||
<!-- To aid in advanced debugging, you may turn on IndexWriter debug logging.
|
|
||||||
Setting to true will set the file that the underlying Lucene IndexWriter
|
|
||||||
will write its debug infostream to. -->
|
|
||||||
<infoStream file="INFOSTREAM.txt">false</infoStream>
|
|
||||||
</mainIndex>
|
|
||||||
<!-- Enables JMX if and only if an existing MBeanServer is found, use this
|
|
||||||
if you want to configure JMX through JVM parameters. Remove this to disable
|
|
||||||
exposing Solr configuration and statistics to JMX.
|
|
||||||
|
|
||||||
If you want to connect to a particular server, specify the agentId
|
|
||||||
e.g. <jmx agentId="myAgent" />
|
|
||||||
|
|
||||||
If you want to start a new MBeanServer, specify the serviceUrl
|
|
||||||
e.g <jmx serviceUrl="service:jmx:rmi:///jndi/rmi://localhost:9999/solr"/>
|
|
||||||
|
|
||||||
For more details see http://wiki.apache.org/solr/SolrJmx
|
|
||||||
-->
|
|
||||||
<jmx/>
|
|
||||||
<!-- the default high-performance update handler -->
|
|
||||||
<updateHandler class="solr.DirectUpdateHandler2">
|
|
||||||
<!-- A prefix of "solr." for class names is an alias that
|
|
||||||
causes solr to search appropriate packages, including
|
|
||||||
org.apache.solr.(search|update|request|core|analysis)
|
|
||||||
-->
|
|
||||||
<!-- Perform a <commit/> automatically under certain conditions:
|
|
||||||
maxDocs - number of updates since last commit is greater than this
|
|
||||||
maxTime - oldest uncommited update (in ms) is this long ago
|
|
||||||
Instead of enabling autoCommit, consider using "commitWithin"
|
|
||||||
when adding documents. http://wiki.apache.org/solr/UpdateXmlMessages
|
|
||||||
<autoCommit>
|
|
||||||
<maxDocs>10000</maxDocs>
|
|
||||||
<maxTime>1000</maxTime>
|
|
||||||
</autoCommit>
|
|
||||||
-->
|
|
||||||
<!-- The RunExecutableListener executes an external command from a
|
|
||||||
hook such as postCommit or postOptimize.
|
|
||||||
exe - the name of the executable to run
|
|
||||||
dir - dir to use as the current working directory. default="."
|
|
||||||
wait - the calling thread waits until the executable returns. default="true"
|
|
||||||
args - the arguments to pass to the program. default=nothing
|
|
||||||
env - environment variables to set. default=nothing
|
|
||||||
-->
|
|
||||||
<!-- A postCommit event is fired after every commit or optimize command
|
|
||||||
<listener event="postCommit" class="solr.RunExecutableListener">
|
|
||||||
<str name="exe">solr/bin/snapshooter</str>
|
|
||||||
<str name="dir">.</str>
|
|
||||||
<bool name="wait">true</bool>
|
|
||||||
<arr name="args"> <str>arg1</str> <str>arg2</str> </arr>
|
|
||||||
<arr name="env"> <str>MYVAR=val1</str> </arr>
|
|
||||||
</listener>
|
|
||||||
-->
|
|
||||||
<!-- A postOptimize event is fired only after every optimize command
|
|
||||||
<listener event="postOptimize" class="solr.RunExecutableListener">
|
|
||||||
<str name="exe">snapshooter</str>
|
|
||||||
<str name="dir">solr/bin</str>
|
|
||||||
<bool name="wait">true</bool>
|
|
||||||
</listener>
|
|
||||||
-->
|
|
||||||
</updateHandler>
|
|
||||||
<!-- Use the following format to specify a custom IndexReaderFactory - allows for alternate
|
|
||||||
IndexReader implementations.
|
|
||||||
|
|
||||||
** Experimental Feature **
|
|
||||||
Please note - Using a custom IndexReaderFactory may prevent certain other features
|
|
||||||
from working. The API to IndexReaderFactory may change without warning or may even
|
|
||||||
be removed from future releases if the problems cannot be resolved.
|
|
||||||
|
|
||||||
** Features that may not work with custom IndexReaderFactory **
|
|
||||||
The ReplicationHandler assumes a disk-resident index. Using a custom
|
|
||||||
IndexReader implementation may cause incompatibility with ReplicationHandler and
|
|
||||||
may cause replication to not work correctly. See SOLR-1366 for details.
|
|
||||||
|
|
||||||
<indexReaderFactory name="IndexReaderFactory" class="package.class">
|
|
||||||
Parameters as required by the implementation
|
|
||||||
</indexReaderFactory >
|
|
||||||
-->
|
|
||||||
<!-- To set the termInfosIndexDivisor, do this: -->
|
|
||||||
<!--<indexReaderFactory name="IndexReaderFactory" class="org.apache.solr.core.StandardIndexReaderFactory">
|
|
||||||
<int name="termInfosIndexDivisor">12</int>
|
|
||||||
</indexReaderFactory >-->
|
|
||||||
<query>
|
|
||||||
<!-- Maximum number of clauses in a boolean query... in the past, this affected
|
|
||||||
range or prefix queries that expanded to big boolean queries - built in Solr
|
|
||||||
query parsers no longer create queries with this limitation.
|
|
||||||
An exception is thrown if exceeded. -->
|
|
||||||
<maxBooleanClauses>1024</maxBooleanClauses>
|
|
||||||
<!-- There are two implementations of cache available for Solr,
|
|
||||||
LRUCache, based on a synchronized LinkedHashMap, and
|
|
||||||
FastLRUCache, based on a ConcurrentHashMap. FastLRUCache has faster gets
|
|
||||||
and slower puts in single threaded operation and thus is generally faster
|
|
||||||
than LRUCache when the hit ratio of the cache is high (> 75%), and may be
|
|
||||||
faster under other scenarios on multi-cpu systems. -->
|
|
||||||
<!-- Cache used by SolrIndexSearcher for filters (DocSets),
|
|
||||||
unordered sets of *all* documents that match a query.
|
|
||||||
When a new searcher is opened, its caches may be prepopulated
|
|
||||||
or "autowarmed" using data from caches in the old searcher.
|
|
||||||
autowarmCount is the number of items to prepopulate. For LRUCache,
|
|
||||||
the autowarmed items will be the most recently accessed items.
|
|
||||||
Parameters:
|
|
||||||
class - the SolrCache implementation LRUCache or FastLRUCache
|
|
||||||
size - the maximum number of entries in the cache
|
|
||||||
initialSize - the initial capacity (number of entries) of
|
|
||||||
the cache. (seel java.util.HashMap)
|
|
||||||
autowarmCount - the number of entries to prepopulate from
|
|
||||||
and old cache.
|
|
||||||
-->
|
|
||||||
<filterCache class="solr.FastLRUCache" size="512" initialSize="512" autowarmCount="0"/>
|
|
||||||
<!-- Cache used to hold field values that are quickly accessible
|
|
||||||
by document id. The fieldValueCache is created by default
|
|
||||||
even if not configured here.
|
|
||||||
<fieldValueCache
|
|
||||||
class="solr.FastLRUCache"
|
|
||||||
size="512"
|
|
||||||
autowarmCount="128"
|
|
||||||
showItems="32"
|
|
||||||
/>
|
|
||||||
-->
|
|
||||||
<!-- queryResultCache caches results of searches - ordered lists of
|
|
||||||
document ids (DocList) based on a query, a sort, and the range
|
|
||||||
of documents requested. -->
|
|
||||||
<queryResultCache class="solr.LRUCache" size="512" initialSize="512" autowarmCount="0"/>
|
|
||||||
<!-- documentCache caches Lucene Document objects (the stored fields for each document).
|
|
||||||
Since Lucene internal document ids are transient, this cache will not be autowarmed. -->
|
|
||||||
<documentCache class="solr.LRUCache" size="512" initialSize="512" autowarmCount="0"/>
|
|
||||||
<!-- If true, stored fields that are not requested will be loaded lazily.
|
|
||||||
This can result in a significant speed improvement if the usual case is to
|
|
||||||
not load all stored fields, especially if the skipped fields are large
|
|
||||||
compressed text fields.
|
|
||||||
-->
|
|
||||||
<enableLazyFieldLoading>true</enableLazyFieldLoading>
|
|
||||||
<!-- Example of a generic cache. These caches may be accessed by name
|
|
||||||
through SolrIndexSearcher.getCache(),cacheLookup(), and cacheInsert().
|
|
||||||
The purpose is to enable easy caching of user/application level data.
|
|
||||||
The regenerator argument should be specified as an implementation
|
|
||||||
of solr.search.CacheRegenerator if autowarming is desired. -->
|
|
||||||
<!--
|
|
||||||
<cache name="myUserCache"
|
|
||||||
class="solr.LRUCache"
|
|
||||||
size="4096"
|
|
||||||
initialSize="1024"
|
|
||||||
autowarmCount="1024"
|
|
||||||
regenerator="org.mycompany.mypackage.MyRegenerator"
|
|
||||||
/>
|
|
||||||
-->
|
|
||||||
<!-- An optimization that attempts to use a filter to satisfy a search.
|
|
||||||
If the requested sort does not include score, then the filterCache
|
|
||||||
will be checked for a filter matching the query. If found, the filter
|
|
||||||
will be used as the source of document ids, and then the sort will be
|
|
||||||
applied to that.
|
|
||||||
<useFilterForSortedQuery>true</useFilterForSortedQuery>
|
|
||||||
-->
|
|
||||||
<!-- An optimization for use with the queryResultCache. When a search
|
|
||||||
is requested, a superset of the requested number of document ids
|
|
||||||
are collected. For example, if a search for a particular query
|
|
||||||
requests matching documents 10 through 19, and queryWindowSize is 50,
|
|
||||||
then documents 0 through 49 will be collected and cached. Any further
|
|
||||||
requests in that range can be satisfied via the cache. -->
|
|
||||||
<queryResultWindowSize>20</queryResultWindowSize>
|
|
||||||
<!-- Maximum number of documents to cache for any entry in the
|
|
||||||
queryResultCache. -->
|
|
||||||
<queryResultMaxDocsCached>200</queryResultMaxDocsCached>
|
|
||||||
<!-- a newSearcher event is fired whenever a new searcher is being prepared
|
|
||||||
and there is a current searcher handling requests (aka registered).
|
|
||||||
It can be used to prime certain caches to prevent long request times for
|
|
||||||
certain requests.
|
|
||||||
-->
|
|
||||||
<!-- QuerySenderListener takes an array of NamedList and executes a
|
|
||||||
local query request for each NamedList in sequence. -->
|
|
||||||
<listener event="newSearcher" class="solr.QuerySenderListener">
|
|
||||||
<arr name="queries">
|
|
||||||
<!--
|
|
||||||
<lst> <str name="q">solr</str> <str name="start">0</str> <str name="rows">10</str> </lst>
|
|
||||||
<lst> <str name="q">rocks</str> <str name="start">0</str> <str name="rows">10</str> </lst>
|
|
||||||
<lst><str name="q">static newSearcher warming query from solrconfig.xml</str></lst>
|
|
||||||
-->
|
|
||||||
</arr>
|
|
||||||
</listener>
|
|
||||||
<!-- a firstSearcher event is fired whenever a new searcher is being
|
|
||||||
prepared but there is no current registered searcher to handle
|
|
||||||
requests or to gain autowarming data from. -->
|
|
||||||
<listener event="firstSearcher" class="solr.QuerySenderListener">
|
|
||||||
<arr name="queries">
|
|
||||||
<lst>
|
|
||||||
<str name="q">solr rocks</str>
|
|
||||||
<str name="start">0</str>
|
|
||||||
<str name="rows">10</str>
|
|
||||||
</lst>
|
|
||||||
<lst>
|
|
||||||
<str name="q">static firstSearcher warming query from solrconfig.xml</str>
|
|
||||||
</lst>
|
|
||||||
</arr>
|
|
||||||
</listener>
|
|
||||||
<!-- If a search request comes in and there is no current registered searcher,
|
|
||||||
then immediately register the still warming searcher and use it. If
|
|
||||||
"false" then all requests will block until the first searcher is done
|
|
||||||
warming. -->
|
|
||||||
<useColdSearcher>false</useColdSearcher>
|
|
||||||
<!-- Maximum number of searchers that may be warming in the background
|
|
||||||
concurrently. An error is returned if this limit is exceeded. Recommend
|
|
||||||
1-2 for read-only slaves, higher for masters w/o cache warming. -->
|
|
||||||
<maxWarmingSearchers>2</maxWarmingSearchers>
|
|
||||||
</query>
|
|
||||||
<!--
|
|
||||||
Let the dispatch filter handler /select?qt=XXX
|
|
||||||
handleSelect=true will use consistent error handling for /select and /update
|
|
||||||
handleSelect=false will use solr1.1 style error formatting
|
|
||||||
-->
|
|
||||||
<requestDispatcher handleSelect="true">
|
|
||||||
<!--Make sure your system has some authentication before enabling remote streaming! -->
|
|
||||||
<requestParsers enableRemoteStreaming="true" multipartUploadLimitInKB="2048000"/>
|
|
||||||
<!-- Set HTTP caching related parameters (for proxy caches and clients).
|
|
||||||
|
|
||||||
To get the behaviour of Solr 1.2 (ie: no caching related headers)
|
|
||||||
use the never304="true" option and do not specify a value for
|
|
||||||
<cacheControl>
|
|
||||||
-->
|
|
||||||
<!-- <httpCaching never304="true"> -->
|
|
||||||
<httpCaching lastModifiedFrom="openTime" etagSeed="Solr">
|
|
||||||
<!-- lastModFrom="openTime" is the default, the Last-Modified value
|
|
||||||
(and validation against If-Modified-Since requests) will all be
|
|
||||||
relative to when the current Searcher was opened.
|
|
||||||
You can change it to lastModFrom="dirLastMod" if you want the
|
|
||||||
value to exactly corrispond to when the physical index was last
|
|
||||||
modified.
|
|
||||||
|
|
||||||
etagSeed="..." is an option you can change to force the ETag
|
|
||||||
header (and validation against If-None-Match requests) to be
|
|
||||||
differnet even if the index has not changed (ie: when making
|
|
||||||
significant changes to your config file)
|
|
||||||
|
|
||||||
lastModifiedFrom and etagSeed are both ignored if you use the
|
|
||||||
never304="true" option.
|
|
||||||
-->
|
|
||||||
<!-- If you include a <cacheControl> directive, it will be used to
|
|
||||||
generate a Cache-Control header, as well as an Expires header
|
|
||||||
if the value contains "max-age="
|
|
||||||
|
|
||||||
By default, no Cache-Control header is generated.
|
|
||||||
|
|
||||||
You can use the <cacheControl> option even if you have set
|
|
||||||
never304="true"
|
|
||||||
-->
|
|
||||||
<!-- <cacheControl>max-age=30, public</cacheControl> -->
|
|
||||||
</httpCaching>
|
|
||||||
</requestDispatcher>
|
|
||||||
<!-- requestHandler plugins... incoming queries will be dispatched to the
|
|
||||||
correct handler based on the path or the qt (query type) param.
|
|
||||||
Names starting with a '/' are accessed with the a path equal to the
|
|
||||||
registered name. Names without a leading '/' are accessed with:
|
|
||||||
http://host/app/select?qt=name
|
|
||||||
If no qt is defined, the requestHandler that declares default="true"
|
|
||||||
will be used.
|
|
||||||
-->
|
|
||||||
<requestHandler name="standard" class="solr.SearchHandler" default="true">
|
|
||||||
<!-- default values for query parameters -->
|
|
||||||
<lst name="defaults">
|
|
||||||
<str name="echoParams">explicit</str>
|
|
||||||
<!--
|
|
||||||
<int name="rows">10</int>
|
|
||||||
<str name="fl">*</str>
|
|
||||||
<str name="version">2.1</str>
|
|
||||||
-->
|
|
||||||
</lst>
|
|
||||||
</requestHandler>
|
|
||||||
<!-- Please refer to http://wiki.apache.org/solr/SolrReplication for details on configuring replication -->
|
|
||||||
<!-- remove the <lst name="master"> section if this is just a slave -->
|
|
||||||
<!-- remove the <lst name="slave"> section if this is just a master -->
|
|
||||||
<!--
|
|
||||||
<requestHandler name="/replication" class="solr.ReplicationHandler" >
|
|
||||||
<lst name="master">
|
|
||||||
<str name="replicateAfter">commit</str>
|
|
||||||
<str name="replicateAfter">startup</str>
|
|
||||||
<str name="confFiles">schema.xml,stopwords.txt</str>
|
|
||||||
</lst>
|
|
||||||
<lst name="slave">
|
|
||||||
<str name="masterUrl">http://localhost:8983/solr/replication</str>
|
|
||||||
<str name="pollInterval">00:00:60</str>
|
|
||||||
</lst>
|
|
||||||
</requestHandler>-->
|
|
||||||
<!-- DisMaxRequestHandler allows easy searching across multiple fields
|
|
||||||
for simple user-entered phrases. It's implementation is now
|
|
||||||
just the standard SearchHandler with a default query type
|
|
||||||
of "dismax".
|
|
||||||
see http://wiki.apache.org/solr/DisMaxRequestHandler
|
|
||||||
-->
|
|
||||||
<requestHandler name="dismax" class="solr.SearchHandler">
|
|
||||||
<lst name="defaults">
|
|
||||||
<str name="defType">dismax</str>
|
|
||||||
<str name="echoParams">explicit</str>
|
|
||||||
<float name="tie">0.01</float>
|
|
||||||
<str name="qf">
|
|
||||||
text^0.5 features^1.0 name^1.2 sku^1.5 id^10.0 manu^1.1 cat^1.4
|
|
||||||
</str>
|
|
||||||
<str name="pf">
|
|
||||||
text^0.2 features^1.1 name^1.5 manu^1.4 manu_exact^1.9
|
|
||||||
</str>
|
|
||||||
<str name="bf">
|
|
||||||
popularity^0.5 recip(price,1,1000,1000)^0.3
|
|
||||||
</str>
|
|
||||||
<str name="fl">
|
|
||||||
id,name,price,score
|
|
||||||
</str>
|
|
||||||
<str name="mm">
|
|
||||||
2<-1 5<-2 6<90%
|
|
||||||
</str>
|
|
||||||
<int name="ps">100</int>
|
|
||||||
<str name="q.alt">*:*</str>
|
|
||||||
<!-- example highlighter config, enable per-query with hl=true -->
|
|
||||||
<str name="hl.fl">text features name</str>
|
|
||||||
<!-- for this field, we want no fragmenting, just highlighting -->
|
|
||||||
<str name="f.name.hl.fragsize">0</str>
|
|
||||||
<!-- instructs Solr to return the field itself if no query terms are
|
|
||||||
found -->
|
|
||||||
<str name="f.name.hl.alternateField">name</str>
|
|
||||||
<str name="f.text.hl.fragmenter">regex</str>
|
|
||||||
<!-- defined below -->
|
|
||||||
</lst>
|
|
||||||
</requestHandler>
|
|
||||||
<!-- Note how you can register the same handler multiple times with
|
|
||||||
different names (and different init parameters)
|
|
||||||
-->
|
|
||||||
<requestHandler name="partitioned" class="solr.SearchHandler">
|
|
||||||
<lst name="defaults">
|
|
||||||
<str name="defType">dismax</str>
|
|
||||||
<str name="echoParams">explicit</str>
|
|
||||||
<str name="qf">text^0.5 features^1.0 name^1.2 sku^1.5 id^10.0</str>
|
|
||||||
<str name="mm">2<-1 5<-2 6<90%</str>
|
|
||||||
<!-- This is an example of using Date Math to specify a constantly
|
|
||||||
moving date range in a config...
|
|
||||||
-->
|
|
||||||
<str name="bq">incubationdate_dt:[* TO NOW/DAY-1MONTH]^2.2</str>
|
|
||||||
</lst>
|
|
||||||
<!-- In addition to defaults, "appends" params can be specified
|
|
||||||
to identify values which should be appended to the list of
|
|
||||||
multi-val params from the query (or the existing "defaults").
|
|
||||||
|
|
||||||
In this example, the param "fq=instock:true" will be appended to
|
|
||||||
any query time fq params the user may specify, as a mechanism for
|
|
||||||
partitioning the index, independent of any user selected filtering
|
|
||||||
that may also be desired (perhaps as a result of faceted searching).
|
|
||||||
|
|
||||||
NOTE: there is *absolutely* nothing a client can do to prevent these
|
|
||||||
"appends" values from being used, so don't use this mechanism
|
|
||||||
unless you are sure you always want it.
|
|
||||||
-->
|
|
||||||
<lst name="appends">
|
|
||||||
<str name="fq">inStock:true</str>
|
|
||||||
</lst>
|
|
||||||
<!-- "invariants" are a way of letting the Solr maintainer lock down
|
|
||||||
the options available to Solr clients. Any params values
|
|
||||||
specified here are used regardless of what values may be specified
|
|
||||||
in either the query, the "defaults", or the "appends" params.
|
|
||||||
|
|
||||||
In this example, the facet.field and facet.query params are fixed,
|
|
||||||
limiting the facets clients can use. Faceting is not turned on by
|
|
||||||
default - but if the client does specify facet=true in the request,
|
|
||||||
these are the only facets they will be able to see counts for;
|
|
||||||
regardless of what other facet.field or facet.query params they
|
|
||||||
may specify.
|
|
||||||
|
|
||||||
NOTE: there is *absolutely* nothing a client can do to prevent these
|
|
||||||
"invariants" values from being used, so don't use this mechanism
|
|
||||||
unless you are sure you always want it.
|
|
||||||
-->
|
|
||||||
<lst name="invariants">
|
|
||||||
<str name="facet.field">cat</str>
|
|
||||||
<str name="facet.field">manu_exact</str>
|
|
||||||
<str name="facet.query">price:[* TO 500]</str>
|
|
||||||
<str name="facet.query">price:[500 TO *]</str>
|
|
||||||
</lst>
|
|
||||||
</requestHandler>
|
|
||||||
<!--
|
|
||||||
Search components are registered to SolrCore and used by Search Handlers
|
|
||||||
|
|
||||||
By default, the following components are avaliable:
|
|
||||||
|
|
||||||
<searchComponent name="query" class="org.apache.solr.handler.component.QueryComponent" />
|
|
||||||
<searchComponent name="facet" class="org.apache.solr.handler.component.FacetComponent" />
|
|
||||||
<searchComponent name="mlt" class="org.apache.solr.handler.component.MoreLikeThisComponent" />
|
|
||||||
<searchComponent name="highlight" class="org.apache.solr.handler.component.HighlightComponent" />
|
|
||||||
<searchComponent name="stats" class="org.apache.solr.handler.component.StatsComponent" />
|
|
||||||
<searchComponent name="debug" class="org.apache.solr.handler.component.DebugComponent" />
|
|
||||||
|
|
||||||
Default configuration in a requestHandler would look like:
|
|
||||||
<arr name="components">
|
|
||||||
<str>query</str>
|
|
||||||
<str>facet</str>
|
|
||||||
<str>mlt</str>
|
|
||||||
<str>highlight</str>
|
|
||||||
<str>stats</str>
|
|
||||||
<str>debug</str>
|
|
||||||
</arr>
|
|
||||||
|
|
||||||
If you register a searchComponent to one of the standard names, that will be used instead.
|
|
||||||
To insert components before or after the 'standard' components, use:
|
|
||||||
|
|
||||||
<arr name="first-components">
|
|
||||||
<str>myFirstComponentName</str>
|
|
||||||
</arr>
|
|
||||||
|
|
||||||
<arr name="last-components">
|
|
||||||
<str>myLastComponentName</str>
|
|
||||||
</arr>
|
|
||||||
-->
|
|
||||||
<!-- The spell check component can return a list of alternative spelling
|
|
||||||
suggestions. -->
|
|
||||||
<searchComponent name="spellcheck" class="solr.SpellCheckComponent">
|
|
||||||
<str name="queryAnalyzerFieldType">textSpell</str>
|
|
||||||
<lst name="spellchecker">
|
|
||||||
<str name="name">default</str>
|
|
||||||
<str name="field">name</str>
|
|
||||||
<str name="spellcheckIndexDir">./spellchecker</str>
|
|
||||||
</lst>
|
|
||||||
<!-- a spellchecker that uses a different distance measure
|
|
||||||
<lst name="spellchecker">
|
|
||||||
<str name="name">jarowinkler</str>
|
|
||||||
<str name="field">spell</str>
|
|
||||||
<str name="distanceMeasure">org.apache.lucene.search.spell.JaroWinklerDistance</str>
|
|
||||||
<str name="spellcheckIndexDir">./spellchecker2</str>
|
|
||||||
</lst>
|
|
||||||
-->
|
|
||||||
<!-- a file based spell checker
|
|
||||||
<lst name="spellchecker">
|
|
||||||
<str name="classname">solr.FileBasedSpellChecker</str>
|
|
||||||
<str name="name">file</str>
|
|
||||||
<str name="sourceLocation">spellings.txt</str>
|
|
||||||
<str name="characterEncoding">UTF-8</str>
|
|
||||||
<str name="spellcheckIndexDir">./spellcheckerFile</str>
|
|
||||||
</lst>
|
|
||||||
-->
|
|
||||||
</searchComponent>
|
|
||||||
<!-- A request handler utilizing the spellcheck component.
|
|
||||||
#############################################################################
|
|
||||||
NOTE: This is purely as an example. The whole purpose of the
|
|
||||||
SpellCheckComponent is to hook it into the request handler that handles (i.e.
|
|
||||||
the standard or dismax SearchHandler) queries such that a separate request is
|
|
||||||
not needed to get suggestions.
|
|
||||||
|
|
||||||
IN OTHER WORDS, THERE IS REALLY GOOD CHANCE THE SETUP BELOW IS NOT WHAT YOU
|
|
||||||
WANT FOR YOUR PRODUCTION SYSTEM!
|
|
||||||
#############################################################################
|
|
||||||
-->
|
|
||||||
<requestHandler name="/spell" class="solr.SearchHandler" lazy="true">
|
|
||||||
<lst name="defaults">
|
|
||||||
<!-- omp = Only More Popular -->
|
|
||||||
<str name="spellcheck.onlyMorePopular">false</str>
|
|
||||||
<!-- exr = Extended Results -->
|
|
||||||
<str name="spellcheck.extendedResults">false</str>
|
|
||||||
<!-- The number of suggestions to return -->
|
|
||||||
<str name="spellcheck.count">1</str>
|
|
||||||
</lst>
|
|
||||||
<arr name="last-components">
|
|
||||||
<str>spellcheck</str>
|
|
||||||
</arr>
|
|
||||||
</requestHandler>
|
|
||||||
<searchComponent name="tvComponent" class="org.apache.solr.handler.component.TermVectorComponent"/>
|
|
||||||
<!-- A Req Handler for working with the tvComponent. This is purely as an example.
|
|
||||||
You will likely want to add the component to your already specified request handlers. -->
|
|
||||||
<requestHandler name="tvrh" class="org.apache.solr.handler.component.SearchHandler">
|
|
||||||
<lst name="defaults">
|
|
||||||
<bool name="tv">true</bool>
|
|
||||||
</lst>
|
|
||||||
<arr name="last-components">
|
|
||||||
<str>tvComponent</str>
|
|
||||||
</arr>
|
|
||||||
</requestHandler>
|
|
||||||
<!-- Clustering Component
|
|
||||||
http://wiki.apache.org/solr/ClusteringComponent
|
|
||||||
This relies on third party jars which are not included in the release.
|
|
||||||
To use this component (and the "/clustering" handler)
|
|
||||||
Those jars will need to be downloaded, and you'll need to set the
|
|
||||||
solr.cluster.enabled system property when running solr...
|
|
||||||
java -Dsolr.clustering.enabled=true -jar start.jar
|
|
||||||
-->
|
|
||||||
<searchComponent name="clusteringComponent" enable="${solr.clustering.enabled:false}" class="org.apache.solr.handler.clustering.ClusteringComponent">
|
|
||||||
<!-- Declare an engine -->
|
|
||||||
<lst name="engine">
|
|
||||||
<!-- The name, only one can be named "default" -->
|
|
||||||
<str name="name">default</str>
|
|
||||||
<!--
|
|
||||||
Class name of Carrot2 clustering algorithm. Currently available algorithms are:
|
|
||||||
|
|
||||||
* org.carrot2.clustering.lingo.LingoClusteringAlgorithm
|
|
||||||
* org.carrot2.clustering.stc.STCClusteringAlgorithm
|
|
||||||
|
|
||||||
See http://project.carrot2.org/algorithms.html for the algorithm's characteristics.
|
|
||||||
-->
|
|
||||||
<str name="carrot.algorithm">org.carrot2.clustering.lingo.LingoClusteringAlgorithm</str>
|
|
||||||
<!--
|
|
||||||
Overriding values for Carrot2 default algorithm attributes. For a description
|
|
||||||
of all available attributes, see: http://download.carrot2.org/stable/manual/#chapter.components.
|
|
||||||
Use attribute key as name attribute of str elements below. These can be further
|
|
||||||
overridden for individual requests by specifying attribute key as request
|
|
||||||
parameter name and attribute value as parameter value.
|
|
||||||
-->
|
|
||||||
<str name="LingoClusteringAlgorithm.desiredClusterCountBase">20</str>
|
|
||||||
</lst>
|
|
||||||
<lst name="engine">
|
|
||||||
<str name="name">stc</str>
|
|
||||||
<str name="carrot.algorithm">org.carrot2.clustering.stc.STCClusteringAlgorithm</str>
|
|
||||||
</lst>
|
|
||||||
</searchComponent>
|
|
||||||
<requestHandler name="/clustering" enable="${solr.clustering.enabled:false}" class="solr.SearchHandler">
|
|
||||||
<lst name="defaults">
|
|
||||||
<bool name="clustering">true</bool>
|
|
||||||
<str name="clustering.engine">default</str>
|
|
||||||
<bool name="clustering.results">true</bool>
|
|
||||||
<!-- The title field -->
|
|
||||||
<str name="carrot.title">name</str>
|
|
||||||
<str name="carrot.url">id</str>
|
|
||||||
<!-- The field to cluster on -->
|
|
||||||
<str name="carrot.snippet">features</str>
|
|
||||||
<!-- produce summaries -->
|
|
||||||
<bool name="carrot.produceSummary">true</bool>
|
|
||||||
<!-- the maximum number of labels per cluster -->
|
|
||||||
<!--<int name="carrot.numDescriptions">5</int>-->
|
|
||||||
<!-- produce sub clusters -->
|
|
||||||
<bool name="carrot.outputSubClusters">false</bool>
|
|
||||||
</lst>
|
|
||||||
<arr name="last-components">
|
|
||||||
<str>clusteringComponent</str>
|
|
||||||
</arr>
|
|
||||||
</requestHandler>
|
|
||||||
<!-- Solr Cell: http://wiki.apache.org/solr/ExtractingRequestHandler -->
|
|
||||||
<requestHandler name="/update/extract" class="org.apache.solr.handler.extraction.ExtractingRequestHandler" startup="lazy">
|
|
||||||
<lst name="defaults">
|
|
||||||
<!-- All the main content goes into "text"... if you need to return
|
|
||||||
the extracted text or do highlighting, use a stored field. -->
|
|
||||||
<str name="fmap.content">text</str>
|
|
||||||
<str name="lowernames">true</str>
|
|
||||||
<str name="uprefix">ignored_</str>
|
|
||||||
<!-- capture link hrefs but ignore div attributes -->
|
|
||||||
<str name="captureAttr">true</str>
|
|
||||||
<str name="fmap.a">links</str>
|
|
||||||
<str name="fmap.div">ignored_</str>
|
|
||||||
</lst>
|
|
||||||
</requestHandler>
|
|
||||||
<!-- A component to return terms and document frequency of those terms.
|
|
||||||
This component does not yet support distributed search. -->
|
|
||||||
<searchComponent name="termsComponent" class="org.apache.solr.handler.component.TermsComponent"/>
|
|
||||||
<requestHandler name="/terms" class="org.apache.solr.handler.component.SearchHandler">
|
|
||||||
<lst name="defaults">
|
|
||||||
<bool name="terms">true</bool>
|
|
||||||
</lst>
|
|
||||||
<arr name="components">
|
|
||||||
<str>termsComponent</str>
|
|
||||||
</arr>
|
|
||||||
</requestHandler>
|
|
||||||
<!-- a search component that enables you to configure the top results for
|
|
||||||
a given query regardless of the normal lucene scoring.-->
|
|
||||||
<searchComponent name="elevator" class="solr.QueryElevationComponent">
|
|
||||||
<!-- pick a fieldType to analyze queries -->
|
|
||||||
<str name="queryFieldType">string</str>
|
|
||||||
<str name="config-file">elevate.xml</str>
|
|
||||||
</searchComponent>
|
|
||||||
<!-- a request handler utilizing the elevator component -->
|
|
||||||
<requestHandler name="/elevate" class="solr.SearchHandler" startup="lazy">
|
|
||||||
<lst name="defaults">
|
|
||||||
<str name="echoParams">explicit</str>
|
|
||||||
</lst>
|
|
||||||
<arr name="last-components">
|
|
||||||
<str>elevator</str>
|
|
||||||
</arr>
|
|
||||||
</requestHandler>
|
|
||||||
<!-- Update request handler.
|
|
||||||
|
|
||||||
Note: Since solr1.1 requestHandlers requires a valid content type header if posted in
|
|
||||||
the body. For example, curl now requires: -H 'Content-type:text/xml; charset=utf-8'
|
|
||||||
The response format differs from solr1.1 formatting and returns a standard error code.
|
|
||||||
To enable solr1.1 behavior, remove the /update handler or change its path
|
|
||||||
-->
|
|
||||||
<requestHandler name="/update" class="solr.XmlUpdateRequestHandler"/>
|
|
||||||
<requestHandler name="/update/javabin" class="solr.BinaryUpdateRequestHandler"/>
|
|
||||||
<!--
|
|
||||||
Analysis request handler. Since Solr 1.3. Use to return how a document is analyzed. Useful
|
|
||||||
for debugging and as a token server for other types of applications.
|
|
||||||
|
|
||||||
This is deprecated in favor of the improved DocumentAnalysisRequestHandler and FieldAnalysisRequestHandler
|
|
||||||
|
|
||||||
<requestHandler name="/analysis" class="solr.AnalysisRequestHandler" />
|
|
||||||
-->
|
|
||||||
<!--
|
|
||||||
An analysis handler that provides a breakdown of the analysis process of provided docuemnts. This handler expects a
|
|
||||||
(single) content stream with the following format:
|
|
||||||
|
|
||||||
<docs>
|
|
||||||
<doc>
|
|
||||||
<field name="id">1</field>
|
|
||||||
<field name="name">The Name</field>
|
|
||||||
<field name="text">The Text Value</field>
|
|
||||||
<doc>
|
|
||||||
<doc>...</doc>
|
|
||||||
<doc>...</doc>
|
|
||||||
...
|
|
||||||
</docs>
|
|
||||||
|
|
||||||
Note: Each document must contain a field which serves as the unique key. This key is used in the returned
|
|
||||||
response to assoicate an analysis breakdown to the analyzed document.
|
|
||||||
|
|
||||||
Like the FieldAnalysisRequestHandler, this handler also supports query analysis by
|
|
||||||
sending either an "analysis.query" or "q" request paraemter that holds the query text to be analyized. It also
|
|
||||||
supports the "analysis.showmatch" parameter which when set to true, all field tokens that match the query
|
|
||||||
tokens will be marked as a "match".
|
|
||||||
-->
|
|
||||||
<requestHandler name="/analysis/document" class="solr.DocumentAnalysisRequestHandler"/>
|
|
||||||
<!--
|
|
||||||
RequestHandler that provides much the same functionality as analysis.jsp. Provides the ability
|
|
||||||
to specify multiple field types and field names in the same request and outputs index-time and
|
|
||||||
query-time analysis for each of them.
|
|
||||||
|
|
||||||
Request parameters are:
|
|
||||||
analysis.fieldname - The field name whose analyzers are to be used
|
|
||||||
analysis.fieldtype - The field type whose analyzers are to be used
|
|
||||||
analysis.fieldvalue - The text for index-time analysis
|
|
||||||
q (or analysis.q) - The text for query time analysis
|
|
||||||
analysis.showmatch (true|false) - When set to true and when query analysis is performed, the produced
|
|
||||||
tokens of the field value analysis will be marked as "matched" for every
|
|
||||||
token that is produces by the query analysis
|
|
||||||
-->
|
|
||||||
<requestHandler name="/analysis/field" class="solr.FieldAnalysisRequestHandler"/>
|
|
||||||
<!-- CSV update handler, loaded on demand -->
|
|
||||||
<requestHandler name="/update/csv" class="solr.CSVRequestHandler" startup="lazy"/>
|
|
||||||
<!--
|
|
||||||
Admin Handlers - This will register all the standard admin RequestHandlers. Adding
|
|
||||||
this single handler is equivalent to registering:
|
|
||||||
|
|
||||||
<requestHandler name="/admin/luke" class="org.apache.solr.handler.admin.LukeRequestHandler" />
|
|
||||||
<requestHandler name="/admin/system" class="org.apache.solr.handler.admin.SystemInfoHandler" />
|
|
||||||
<requestHandler name="/admin/plugins" class="org.apache.solr.handler.admin.PluginInfoHandler" />
|
|
||||||
<requestHandler name="/admin/threads" class="org.apache.solr.handler.admin.ThreadDumpHandler" />
|
|
||||||
<requestHandler name="/admin/properties" class="org.apache.solr.handler.admin.PropertiesRequestHandler" />
|
|
||||||
<requestHandler name="/admin/file" class="org.apache.solr.handler.admin.ShowFileRequestHandler" >
|
|
||||||
|
|
||||||
If you wish to hide files under ${solr.home}/conf, explicitly register the ShowFileRequestHandler using:
|
|
||||||
<requestHandler name="/admin/file" class="org.apache.solr.handler.admin.ShowFileRequestHandler" >
|
|
||||||
<lst name="invariants">
|
|
||||||
<str name="hidden">synonyms.txt</str>
|
|
||||||
<str name="hidden">anotherfile.txt</str>
|
|
||||||
</lst>
|
|
||||||
</requestHandler>
|
|
||||||
-->
|
|
||||||
<requestHandler name="/admin/" class="org.apache.solr.handler.admin.AdminHandlers"/>
|
|
||||||
<!-- ping/healthcheck -->
|
|
||||||
<requestHandler name="/admin/ping" class="PingRequestHandler">
|
|
||||||
<lst name="defaults">
|
|
||||||
<str name="qt">standard</str>
|
|
||||||
<str name="q">solrpingquery</str>
|
|
||||||
<str name="echoParams">all</str>
|
|
||||||
</lst>
|
|
||||||
</requestHandler>
|
|
||||||
<!-- Echo the request contents back to the client -->
|
|
||||||
<requestHandler name="/debug/dump" class="solr.DumpRequestHandler">
|
|
||||||
<lst name="defaults">
|
|
||||||
<str name="echoParams">explicit</str>
|
|
||||||
<!-- for all params (including the default etc) use: 'all' -->
|
|
||||||
<str name="echoHandler">true</str>
|
|
||||||
</lst>
|
|
||||||
</requestHandler>
|
|
||||||
<highlighting>
|
|
||||||
<!-- Configure the standard fragmenter -->
|
|
||||||
<!-- This could most likely be commented out in the "default" case -->
|
|
||||||
<fragmenter name="gap" class="org.apache.solr.highlight.GapFragmenter" default="true">
|
|
||||||
<lst name="defaults">
|
|
||||||
<int name="hl.fragsize">100</int>
|
|
||||||
</lst>
|
|
||||||
</fragmenter>
|
|
||||||
<!-- A regular-expression-based fragmenter (f.i., for sentence extraction) -->
|
|
||||||
<fragmenter name="regex" class="org.apache.solr.highlight.RegexFragmenter">
|
|
||||||
<lst name="defaults">
|
|
||||||
<!-- slightly smaller fragsizes work better because of slop -->
|
|
||||||
<int name="hl.fragsize">70</int>
|
|
||||||
<!-- allow 50% slop on fragment sizes -->
|
|
||||||
<float name="hl.regex.slop">0.5</float>
|
|
||||||
<!-- a basic sentence pattern -->
|
|
||||||
<str name="hl.regex.pattern">[-\w ,/\n\"']{20,200}</str>
|
|
||||||
</lst>
|
|
||||||
</fragmenter>
|
|
||||||
<!-- Configure the standard formatter -->
|
|
||||||
<formatter name="html" class="org.apache.solr.highlight.HtmlFormatter" default="true">
|
|
||||||
<lst name="defaults">
|
|
||||||
<str name="hl.simple.pre"><![CDATA[<em>]]></str>
|
|
||||||
<str name="hl.simple.post"><![CDATA[</em>]]></str>
|
|
||||||
</lst>
|
|
||||||
</formatter>
|
|
||||||
</highlighting>
|
|
||||||
<!-- An example dedup update processor that creates the "id" field on the fly
|
|
||||||
based on the hash code of some other fields. This example has overwriteDupes
|
|
||||||
set to false since we are using the id field as the signatureField and Solr
|
|
||||||
will maintain uniqueness based on that anyway.
|
|
||||||
|
|
||||||
You have to link the chain to an update handler above to use it ie:
|
|
||||||
<requestHandler name="/update "class="solr.XmlUpdateRequestHandler">
|
|
||||||
<lst name="defaults">
|
|
||||||
<str name="update.processor">dedupe</str>
|
|
||||||
</lst>
|
|
||||||
</requestHandler>
|
|
||||||
-->
|
|
||||||
<!--
|
|
||||||
<updateRequestProcessorChain name="dedupe">
|
|
||||||
<processor class="org.apache.solr.update.processor.SignatureUpdateProcessorFactory">
|
|
||||||
<bool name="enabled">true</bool>
|
|
||||||
<str name="signatureField">id</str>
|
|
||||||
<bool name="overwriteDupes">false</bool>
|
|
||||||
<str name="fields">name,features,cat</str>
|
|
||||||
<str name="signatureClass">org.apache.solr.update.processor.Lookup3Signature</str>
|
|
||||||
</processor>
|
|
||||||
<processor class="solr.LogUpdateProcessorFactory" />
|
|
||||||
<processor class="solr.RunUpdateProcessorFactory" />
|
|
||||||
</updateRequestProcessorChain>
|
|
||||||
-->
|
|
||||||
<!-- queryResponseWriter plugins... query responses will be written using the
|
|
||||||
writer specified by the 'wt' request parameter matching the name of a registered
|
|
||||||
writer.
|
|
||||||
The "default" writer is the default and will be used if 'wt' is not specified
|
|
||||||
in the request. XMLResponseWriter will be used if nothing is specified here.
|
|
||||||
The json, python, and ruby writers are also available by default.
|
|
||||||
|
|
||||||
<queryResponseWriter name="xml" class="org.apache.solr.request.XMLResponseWriter" default="true"/>
|
|
||||||
<queryResponseWriter name="json" class="org.apache.solr.request.JSONResponseWriter"/>
|
|
||||||
<queryResponseWriter name="python" class="org.apache.solr.request.PythonResponseWriter"/>
|
|
||||||
<queryResponseWriter name="ruby" class="org.apache.solr.request.RubyResponseWriter"/>
|
|
||||||
<queryResponseWriter name="php" class="org.apache.solr.request.PHPResponseWriter"/>
|
|
||||||
<queryResponseWriter name="phps" class="org.apache.solr.request.PHPSerializedResponseWriter"/>
|
|
||||||
|
|
||||||
<queryResponseWriter name="custom" class="com.example.MyResponseWriter"/>
|
|
||||||
-->
|
|
||||||
<!-- XSLT response writer transforms the XML output by any xslt file found
|
|
||||||
in Solr's conf/xslt directory. Changes to xslt files are checked for
|
|
||||||
every xsltCacheLifetimeSeconds.
|
|
||||||
-->
|
|
||||||
<queryResponseWriter name="xslt" class="org.apache.solr.request.XSLTResponseWriter">
|
|
||||||
<int name="xsltCacheLifetimeSeconds">5</int>
|
|
||||||
</queryResponseWriter>
|
|
||||||
<!-- example of registering a query parser
|
|
||||||
<queryParser name="lucene" class="org.apache.solr.search.LuceneQParserPlugin"/>
|
|
||||||
-->
|
|
||||||
<!-- example of registering a custom function parser
|
|
||||||
<valueSourceParser name="myfunc" class="com.mycompany.MyValueSourceParser" />
|
|
||||||
-->
|
|
||||||
<!-- config for the admin interface -->
|
|
||||||
<admin>
|
|
||||||
<defaultQuery>solr</defaultQuery>
|
|
||||||
<!-- configure a healthcheck file for servers behind a loadbalancer
|
|
||||||
<healthcheck type="file">server-enabled</healthcheck>
|
|
||||||
-->
|
|
||||||
</admin>
|
|
||||||
<requestHandler class="solr.MoreLikeThisHandler" name="/mlt">
|
|
||||||
<lst name="defaults">
|
|
||||||
<str name="mlt.mintf">1</str>
|
|
||||||
<str name="mlt.mindf">2</str>
|
|
||||||
</lst>
|
|
||||||
</requestHandler>
|
|
||||||
</config>
|
|
|
@ -1,2 +0,0 @@
|
||||||
pizza
|
|
||||||
history
|
|
|
@ -1,58 +0,0 @@
|
||||||
# Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
# contributor license agreements. See the NOTICE file distributed with
|
|
||||||
# this work for additional information regarding copyright ownership.
|
|
||||||
# The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
# (the "License"); you may not use this file except in compliance with
|
|
||||||
# the License. You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
#-----------------------------------------------------------------------
|
|
||||||
# a couple of test stopwords to test that the words are really being
|
|
||||||
# configured from this file:
|
|
||||||
stopworda
|
|
||||||
stopwordb
|
|
||||||
|
|
||||||
#Standard english stop words taken from Lucene's StopAnalyzer
|
|
||||||
a
|
|
||||||
an
|
|
||||||
and
|
|
||||||
are
|
|
||||||
as
|
|
||||||
at
|
|
||||||
be
|
|
||||||
but
|
|
||||||
by
|
|
||||||
for
|
|
||||||
if
|
|
||||||
in
|
|
||||||
into
|
|
||||||
is
|
|
||||||
it
|
|
||||||
no
|
|
||||||
not
|
|
||||||
of
|
|
||||||
on
|
|
||||||
or
|
|
||||||
s
|
|
||||||
such
|
|
||||||
t
|
|
||||||
that
|
|
||||||
the
|
|
||||||
their
|
|
||||||
then
|
|
||||||
there
|
|
||||||
these
|
|
||||||
they
|
|
||||||
this
|
|
||||||
to
|
|
||||||
was
|
|
||||||
will
|
|
||||||
with
|
|
||||||
|
|
|
@ -1,31 +0,0 @@
|
||||||
# The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
# (the "License"); you may not use this file except in compliance with
|
|
||||||
# the License. You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
#-----------------------------------------------------------------------
|
|
||||||
#some test synonym mappings unlikely to appear in real input text
|
|
||||||
aaa => aaaa
|
|
||||||
bbb => bbbb1 bbbb2
|
|
||||||
ccc => cccc1,cccc2
|
|
||||||
a\=>a => b\=>b
|
|
||||||
a\,a => b\,b
|
|
||||||
fooaaa,baraaa,bazaaa
|
|
||||||
|
|
||||||
# Some synonym groups specific to this example
|
|
||||||
GB,gib,gigabyte,gigabytes
|
|
||||||
MB,mib,megabyte,megabytes
|
|
||||||
Television, Televisions, TV, TVs
|
|
||||||
#notice we use "gib" instead of "GiB" so any WordDelimiterFilter coming
|
|
||||||
#after us won't split it into two words.
|
|
||||||
|
|
||||||
# Synonym mappings can be used for spelling correction too
|
|
||||||
pixima => pixma
|
|
||||||
|
|
|
@ -1,78 +0,0 @@
|
||||||
|
|
||||||
.mega_tab_block {
|
|
||||||
clear: both;
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mega_tab_block h3 {
|
|
||||||
font: 22px/100% 'arial',sans-serif;
|
|
||||||
margin: 0 0 10px;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mega_tab_block .pagination {
|
|
||||||
float: left;
|
|
||||||
height: auto;
|
|
||||||
margin: 10px 0 0;
|
|
||||||
width: auto;
|
|
||||||
}
|
|
||||||
.mega_tab_block .pagination a {
|
|
||||||
background: none repeat scroll 0 0 #EEEEEE;
|
|
||||||
display: block;
|
|
||||||
float: left;
|
|
||||||
margin: 0 5px 0 0;
|
|
||||||
padding: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
.tag_block {
|
|
||||||
clear: both;
|
|
||||||
margin: 0 0 20px;
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
.mega_tab_block .tag_list {
|
|
||||||
background: none repeat scroll 0 0 #EEEEEE;
|
|
||||||
margin: 0;
|
|
||||||
overflow: hidden;
|
|
||||||
padding: 0 0 0 5px;
|
|
||||||
}
|
|
||||||
.mega_tab_block .tag_list li {
|
|
||||||
float: left;
|
|
||||||
list-style: none outside none;
|
|
||||||
}
|
|
||||||
.mega_tab_block .tag_list li a {
|
|
||||||
background: none repeat scroll 0 0 #DDDDDD;
|
|
||||||
float: left;
|
|
||||||
margin: 0 5px 0 0;
|
|
||||||
padding: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.news_block {
|
|
||||||
clear: both;
|
|
||||||
margin: 0 0 20px;
|
|
||||||
overflow: hidden;
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
.mega_tab_block .news_list {
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
.mega_tab_block .news_list li {
|
|
||||||
list-style: none outside none;
|
|
||||||
padding: 5px 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
.links_block {
|
|
||||||
clear: both;
|
|
||||||
overflow: hidden;
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
.mega_tab_block .links_list {
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
.mega_tab_block .links_list li {
|
|
||||||
list-style: none outside none;
|
|
||||||
padding: 5px 0;
|
|
||||||
}
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
class Panel::Announcement::BackEnd::BulletinVersionsController < OrbitBackendController
|
||||||
|
include OrbitControllerLib::DivisionForDisable
|
||||||
|
|
||||||
|
def index
|
||||||
|
@bulletin = Bulletin.find(params[:bulletin_id])
|
||||||
|
end
|
||||||
|
|
||||||
|
def show
|
||||||
|
@bulletin = Bulletin.find(params[:bulletin_id])
|
||||||
|
@version = @bulletin.versions.where(version: params[:id]).first
|
||||||
|
end
|
||||||
|
end
|
|
@ -26,7 +26,6 @@ class Panel::Announcement::FrontEnd::BulletinsController < OrbitWidgetController
|
||||||
end
|
end
|
||||||
|
|
||||||
def index
|
def index
|
||||||
|
|
||||||
@item = Page.find(params[:page_id]) rescue nil
|
@item = Page.find(params[:page_id]) rescue nil
|
||||||
if @item
|
if @item
|
||||||
if @item.frontend_data_count
|
if @item.frontend_data_count
|
||||||
|
@ -61,11 +60,7 @@ class Panel::Announcement::FrontEnd::BulletinsController < OrbitWidgetController
|
||||||
else
|
else
|
||||||
@bulletins = Bulletin.all.available_for_lang(I18n.locale).can_display.any_of( {deadline: nil,:postdate.lte => date_now} , {:deadline.gte => date_now,:postdate.lte => date_now} ).desc( :is_top, :postdate).page( params[:page_main]).per(@page_num)
|
@bulletins = Bulletin.all.available_for_lang(I18n.locale).can_display.any_of( {deadline: nil,:postdate.lte => date_now} , {:deadline.gte => date_now,:postdate.lte => date_now} ).desc( :is_top, :postdate).page( params[:page_main]).per(@page_num)
|
||||||
end
|
end
|
||||||
if params["tag_id"]
|
delayed_impressionist(@tag) if @tag
|
||||||
params["tag_id"].each do |tag_id|
|
|
||||||
delayed_impressionist(Tag.find tag_id) rescue nil
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -66,75 +66,14 @@ class Panel::Announcement::Widget::BulletinsController < OrbitWidgetController
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def bulletins_and_web_links
|
|
||||||
|
|
||||||
@part = PagePart.find(params[:part_id]) if !params[:part_id].blank?
|
|
||||||
|
|
||||||
@title = @part.title_translations[I18n.locale.to_s]
|
|
||||||
|
|
||||||
if !@part.blank? and @part.widget_data_count
|
|
||||||
@page_num = @part.widget_data_count
|
|
||||||
else
|
|
||||||
@page_num = 5
|
|
||||||
end
|
|
||||||
|
|
||||||
date_now = Time.now
|
|
||||||
|
|
||||||
if !params[:tag_id].blank?
|
|
||||||
@tags = Tag.any_in(:_id => params[:tag_id]).asc(:created_at)
|
|
||||||
elsif params[:tag_id].blank? and !@part.tag.blank?
|
|
||||||
@tags = Tag.any_in(:_id => @part.tag).asc(:created_at)
|
|
||||||
else
|
|
||||||
@ModuleApp_b = ModuleApp.first(:conditions => {:key=>'announcement'})
|
|
||||||
@tags = Tag.where(:module_tag_id => @ModuleApp_b.id).asc(:created_at)
|
|
||||||
end
|
|
||||||
|
|
||||||
@selected_tag = Tag.find(params[:id]).first rescue @tags[0]
|
|
||||||
|
|
||||||
@bulletins = Bulletin.available_for_lang(I18n.locale).can_display.where(:tagged_ids => @selected_tag.id.to_s, :is_hidden => false).any_of( {deadline: nil,:postdate.lte => date_now} , {:deadline.gte => date_now,:postdate.lte => date_now} ).desc(:is_top, :postdate).page(params[:page]).per(@page_num) rescue nil
|
|
||||||
|
|
||||||
if @part.widget_style == 'bulletins_and_web_links'
|
|
||||||
@ModuleApp_w = ModuleApp.first(:conditions => {:key=>'web_resource'})
|
|
||||||
@link_selected_tag = Tag.first(:conditions => {:name => @selected_tag.name, :module_tag_id => @ModuleApp_w.id})
|
|
||||||
@web_links = WebLink.where(:tagged_ids => @link_selected_tag.id.to_s, :is_hidden => false).desc(:is_top,:created_at).available_for_lang(I18n.locale).page(params[:page]).per(@page_num) rescue nil
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
def reload_bulletins
|
def reload_bulletins
|
||||||
|
@selected_tag = Tag.find(params[:tag_id])
|
||||||
@part = PagePart.find(params[:part_id]) if !params[:part_id].blank?
|
@bulletins = Bulletin.available_for_lang(I18n.locale).can_display.where(:tagged_ids => params[:tag_id]).where(:is_hidden => false).any_of( {deadline: nil,:postdate.lte => date_now} , {:deadline.gte => date_now,:postdate.lte => date_now} ).desc(:is_top, sort).page(params[:page]).per(5) rescue nil
|
||||||
|
|
||||||
@title = @part.title_translations[I18n.locale.to_s]
|
|
||||||
|
|
||||||
if !@part.blank? and @part.widget_data_count
|
|
||||||
@page_num = @part.widget_data_count
|
|
||||||
else
|
|
||||||
@page_num = 5
|
|
||||||
end
|
|
||||||
|
|
||||||
date_now = Time.now
|
|
||||||
|
|
||||||
@selected_tag = Tag.find(params[:tag_id]).first
|
|
||||||
@bulletins = Bulletin.available_for_lang(I18n.locale).can_display.where(:tagged_ids => @selected_tag.id.to_s, :is_hidden => false).any_of( {deadline: nil,:postdate.lte => date_now} , {:deadline.gte => date_now,:postdate.lte => date_now} ).desc(:is_top, :postdate).page(params[:page]).per(@page_num) rescue nil
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def reload_web_links
|
def reload_web_links
|
||||||
|
@selected_tag = Tag.find(params[:tag_id])
|
||||||
@part = PagePart.find(params[:part_id]) if !params[:part_id].blank?
|
@web_links = WebLink.where(:name => @selected_tag.name).where(:is_hidden => false).desc(:is_top, sort).available_for_lang(I18n.locale).page(params[:page]).per(5) rescue nil
|
||||||
|
|
||||||
if !@part.blank? and @part.widget_data_count
|
|
||||||
@page_num = @part.widget_data_count
|
|
||||||
else
|
|
||||||
@page_num = 5
|
|
||||||
end
|
|
||||||
|
|
||||||
date_now = Time.now
|
|
||||||
|
|
||||||
@selected_tag = Tag.find(params[:tag_id]).first
|
|
||||||
@ModuleApp = ModuleApp.first(:conditions => {:key=>'web_resource'})
|
|
||||||
@link_selected_tag = Tag.first(:conditions => {:name => @selected_tag.name, :module_tag_id => @ModuleApp.id})
|
|
||||||
@web_links = WebLink.where(:tagged_ids => @link_selected_tag.id.to_s, :is_hidden => false).desc(:is_top,:created_at).available_for_lang(I18n.locale).page(params[:page]).per(@page_num) rescue nil
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def bulletins_side_bar
|
def bulletins_side_bar
|
||||||
|
|
|
@ -6,6 +6,7 @@ class Bulletin
|
||||||
include Mongoid::MultiParameterAttributes
|
include Mongoid::MultiParameterAttributes
|
||||||
include Sunspot::Mongo
|
include Sunspot::Mongo
|
||||||
include Impressionist::Impressionable
|
include Impressionist::Impressionable
|
||||||
|
include Mongoid::Versioning
|
||||||
|
|
||||||
BelongsToCategory = :bulletin_category
|
BelongsToCategory = :bulletin_category
|
||||||
include OrbitCoreLib::BelongsToCategoryMayDisable
|
include OrbitCoreLib::BelongsToCategoryMayDisable
|
||||||
|
@ -14,7 +15,7 @@ class Bulletin
|
||||||
include OrbitTag::Taggable
|
include OrbitTag::Taggable
|
||||||
taggable
|
taggable
|
||||||
|
|
||||||
is_impressionable #:counter_cache => { :column_name => :view_count }
|
is_impressionable :counter_cache => { :column_name => :view_count }
|
||||||
|
|
||||||
field :title, localize: true
|
field :title, localize: true
|
||||||
field :subtitle, localize: true
|
field :subtitle, localize: true
|
||||||
|
|
|
@ -0,0 +1,25 @@
|
||||||
|
<table class="table main-list">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="span7 select"><%= t(:name) %></th>
|
||||||
|
<th class="span1-2"><%= t(:version) %></th>
|
||||||
|
<th class="span1-2"><%= t(:update_at) %></th>
|
||||||
|
<th class="span1-2"><%= t(:last_modified) %></th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<% @bulletin.versions.reverse.each do |version| %>
|
||||||
|
<tr class="with_action">
|
||||||
|
<td>
|
||||||
|
<%= version.title %>
|
||||||
|
<div class="quick-edit">
|
||||||
|
<%= link_to '顯示', panel_announcement_back_end_bulletin_bulletin_version_path(@bulletin, version.version) %>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
<td><%= version.version %></td>
|
||||||
|
<td><%= display_date(version.updated_at) %></td>
|
||||||
|
<td><%= User.from_id(version.update_user_id).name rescue ''%></td>
|
||||||
|
</tr>
|
||||||
|
<% end %>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue