1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-10 00:46:15 +01:00
fab-manager/lib/tasks/fablab/es.rake

181 lines
5.4 KiB
Ruby
Raw Normal View History

2019-02-13 12:59:28 +01:00
# frozen_string_literal: true
# ElasticSearch relative tasks
namespace :fablab do
namespace :es do
desc '(re)Build ElasticSearch fablab base for stats'
task build_stats: :environment do
exit unless Setting.get('statistics_module')
2019-02-13 12:59:28 +01:00
delete_stats_index
create_stats_index
create_stats_mappings
add_event_filters
2023-02-01 17:56:14 +01:00
add_machine_filters
add_space_filters
2019-02-13 12:59:28 +01:00
end
def delete_stats_index
puts 'DELETE stats'
2023-02-01 17:56:14 +01:00
`curl -XDELETE http://#{ENV.fetch('ELASTICSEARCH_HOST')}:9200/stats`
2019-02-13 12:59:28 +01:00
end
def create_stats_index
puts 'PUT index stats'
2023-02-01 17:56:14 +01:00
`curl -XPUT http://#{ENV.fetch('ELASTICSEARCH_HOST')}:9200/stats -d'
2019-02-13 12:59:28 +01:00
{
"settings" : {
"index" : {
"number_of_replicas" : 0
}
}
}
'`
end
def create_stats_mappings
%w[account event machine project subscription training user space].each do |stat|
puts "PUT Mapping stats/#{stat}"
2023-02-01 17:56:14 +01:00
`curl -XPUT http://#{ENV.fetch('ELASTICSEARCH_HOST')}:9200/stats/#{stat}/_mapping -d '
2019-02-13 12:59:28 +01:00
{
"properties": {
"type": {
"type": "string",
"index" : "not_analyzed"
},
"subType": {
"type": "string",
"index" : "not_analyzed"
},
"date": {
"type": "date"
},
"name": {
"type": "string",
"index" : "not_analyzed"
}
}
}';`
end
end
desc 'add event filters to statistics'
task add_event_filters: :environment do
add_event_filters
end
def add_event_filters
2023-02-01 17:56:14 +01:00
`curl -XPUT http://#{ENV.fetch('ELASTICSEARCH_HOST')}:9200/stats/event/_mapping -d '
2019-02-13 12:59:28 +01:00
{
"properties": {
"ageRange": {
"type": "string",
"index" : "not_analyzed"
},
"eventTheme": {
"type": "string",
"index" : "not_analyzed"
}
}
}';`
end
2023-02-01 17:56:14 +01:00
def add_machine_filters
`curl -XPUT http://#{ENV.fetch('ELASTICSEARCH_HOST')}:9200/stats/machine/_mapping -d '
{
"properties": {
"machineDates": {
"properties": {
"type": "date",
}
}
}
}';`
end
def add_space_filters
`curl -XPUT http://#{ENV.fetch('ELASTICSEARCH_HOST')}:9200/stats/space/_mapping -d '
{
"properties": {
"spaceDates": {
"properties": {
"type": "date",
}
}
}
}';`
end
2019-02-13 12:59:28 +01:00
desc 'add spaces reservations to statistics'
task add_spaces: :environment do
2023-02-01 17:56:14 +01:00
`curl -XPUT http://#{ENV.fetch('ELASTICSEARCH_HOST')}:9200/stats/space/_mapping -d '
2019-02-13 12:59:28 +01:00
{
"properties": {
"type": {
"type": "string",
"index" : "not_analyzed"
},
"subType": {
"type": "string",
"index" : "not_analyzed"
},
"date": {
"type": "date"
},
"name": {
"type": "string",
"index" : "not_analyzed"
}
}
}';`
end
desc 'sync all/one availabilities in ElasticSearch index'
task :build_availabilities_index, [:id] => :environment do |_task, args|
client = Availability.__elasticsearch__.client
# create index if not exists
Availability.__elasticsearch__.create_index! force: true unless client.indices.exists? index: Availability.index_name
# delete doctype if exists
if client.indices.exists_type? index: Availability.index_name, type: Availability.document_type
client.indices.delete_mapping index: Availability.index_name, type: Availability.document_type
end
# create doctype
client.indices.put_mapping index: Availability.index_name,
type: Availability.document_type,
body: Availability.mappings.to_hash
# verify doctype creation was successful
if client.indices.exists_type? index: Availability.index_name, type: Availability.document_type
puts "[ElasticSearch] #{Availability.index_name}/#{Availability.document_type} successfully created with its mapping."
# index requested documents
if args.id
AvailabilityIndexerWorker.perform_async(:index, id)
else
Availability.pluck(:id).each do |availability_id|
AvailabilityIndexerWorker.perform_async(:index, availability_id)
end
end
else
puts "[ElasticSearch] An error occurred while creating #{Availability.index_name}/#{Availability.document_type}. " \
2023-02-01 17:56:14 +01:00
'Please check your ElasticSearch configuration.'
2019-02-13 12:59:28 +01:00
puts "\nCancelling..."
end
end
2019-06-12 12:40:43 +02:00
desc '(re)generate statistics in ElasticSearch for the past period. Use 0 to generate for today'
2019-02-13 12:59:28 +01:00
task :generate_stats, [:period] => :environment do |_task, args|
raise 'FATAL ERROR: You must pass a number of days (=> past period) OR a date to generate statistics' unless args.period
2019-02-13 12:59:28 +01:00
unless Setting.get('statistics_module')
print 'Statistics are disabled. Do you still want to generate? (y/N) '
2023-02-01 17:56:14 +01:00
confirm = $stdin.gets.chomp
raise 'Interrupted by user' unless confirm == 'y'
2019-02-13 12:59:28 +01:00
end
2020-06-24 15:25:17 +02:00
worker = PeriodStatisticsWorker.new
worker.perform(args.period)
end
2019-02-13 12:59:28 +01:00
end
end