apidae 1.2.20 → 1.2.24
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 2a717231678597e174e817b7b690bdfc27137476e3ef781954012a149e729f08
|
4
|
+
data.tar.gz: 7a06fc98b8a238c2906bdb814d1f18a43acad992b46feba9e42b1d339d8773e2
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 62a2be17446a33688036e3fd07722d549c6f3d9659729363df005f7850b90ff63d167b05c128023b075d7a641262813044a48f3a73b09fcf5e9793bbc1f050cf
|
7
|
+
data.tar.gz: 2ebd92b9cfc5231b9cee622f0121820065870c970b9cd10b219e183f770130fec07b7711afa16fe65b11eb40a6ce7100e3feb5e13d0d1a9d703b2c0cecb9b8e8
|
@@ -113,7 +113,7 @@ module Apidae
|
|
113
113
|
short_desc: node_value(data_hash, :descriptifCourt, *locales),
|
114
114
|
long_desc: node_value(data_hash, :descriptifDetaille, *locales),
|
115
115
|
theme_desc: data_hash[:descriptifsThematises].blank? ? {} : Hash[data_hash[:descriptifsThematises].map {|th| [node_id(th, :theme), node_value(th, :description, *locales)]}],
|
116
|
-
private_desc: private_data.blank? ? {} : Hash[private_data.map {|d| [d[:nomTechnique], d[:libelleFr] || node_value(d, :descriptif, *locales)]}]
|
116
|
+
private_desc: private_data.blank? ? {} : Hash[private_data.map {|d| [d[:nomTechnique], {LOCALE_FR => d[:libelleFr]} || node_value(d, :descriptif, *locales)]}]
|
117
117
|
}
|
118
118
|
end
|
119
119
|
end
|
@@ -331,6 +331,7 @@ module Apidae
|
|
331
331
|
if visits_hash
|
332
332
|
booking_hash[:visits_allowed] = visits_hash[:visitable] == true
|
333
333
|
booking_hash[:visits_desc] = node_value(visits_hash, :complementVisite, *locales)
|
334
|
+
booking_hash[:visits_duration] = visits_hash[:dureeMoyenneVisiteIndividuelle]
|
334
335
|
end
|
335
336
|
booking_hash
|
336
337
|
end
|
@@ -44,6 +44,7 @@ module Apidae
|
|
44
44
|
end
|
45
45
|
end
|
46
46
|
end
|
47
|
+
project.cleanup_selections
|
47
48
|
create(result.except(:selections)
|
48
49
|
.merge({remote_file: (zip_file.is_a?(File) ? zip_file.path : zip_file), status: STATUS_COMPLETE, apidae_id: project_id}))
|
49
50
|
logger.info "Import results : #{result}"
|
@@ -169,7 +170,9 @@ module Apidae
|
|
169
170
|
def self.add_or_update_selections(project, selections_json, result)
|
170
171
|
selections_hashes = JSON.parse(selections_json, symbolize_names: true)
|
171
172
|
deleted_ids = Selection.where(apidae_project_id: project.id).collect {|sel| sel.apidae_id}.uniq - selections_hashes.collect {|sel| sel[:id]}
|
172
|
-
Selection.where(apidae_id: deleted_ids).
|
173
|
+
apidae_selection_ids = Selection.where(apidae_id: deleted_ids).map {|s| s.id}
|
174
|
+
SelectionObject.where(apidae_selection_id: apidae_selection_ids).delete_all
|
175
|
+
Selection.where(id: apidae_selection_ids).delete_all
|
173
176
|
selections_hashes.each do |selection_data|
|
174
177
|
logger.info "Updating selection #{selection_data[:id]}"
|
175
178
|
Selection.add_or_update(selection_data, project.id)
|
data/app/models/apidae/obj.rb
CHANGED
@@ -23,7 +23,7 @@ module Apidae
|
|
23
23
|
store_accessor :openings_data, :openings_desc, :openings_desc_mode, :openings, :time_periods, :openings_extra
|
24
24
|
store_accessor :rates_data, :rates_desc, :rates_desc_mode, :rates, :payment_methods, :includes, :excludes, :rates_extra
|
25
25
|
store_accessor :service_data, :services, :equipments, :comfort, :activities, :challenged, :languages
|
26
|
-
store_accessor :booking_data, :booking_desc, :booking_entities, :visits_allowed, :visits_desc
|
26
|
+
store_accessor :booking_data, :booking_desc, :booking_entities, :visits_allowed, :visits_desc, :visits_duration
|
27
27
|
store_accessor :tags_data, :promo, :internal, :linked
|
28
28
|
store_accessor :version_data, :versioned_fields
|
29
29
|
|
@@ -42,6 +42,20 @@ module Apidae
|
|
42
42
|
SelectionObject.where(apidae_selection_id: apidae_sel.id, apidae_object_id: removed_ids).delete_all
|
43
43
|
end
|
44
44
|
|
45
|
+
def cleanup
|
46
|
+
obsolete_count = apidae_selection_objects
|
47
|
+
.joins("LEFT JOIN apidae_objs ON apidae_objs.id = apidae_selection_objects.apidae_object_id")
|
48
|
+
.where("apidae_objs.id IS NULL")
|
49
|
+
.delete_all
|
50
|
+
logger.info "Cleaned up #{obsolete_count} obsolete selection-objects associations for selection #{apidae_id}"
|
51
|
+
|
52
|
+
dups = apidae_selection_objects.reload.group(:apidae_object_id)
|
53
|
+
.select("COUNT(id), apidae_object_id, ARRAY_AGG(id) AS so_ids")
|
54
|
+
.having("COUNT(id) > ?", 1).map {|so| so.so_ids}
|
55
|
+
dups_count = apidae_selection_objects.where(id: dups.map {|d| d.sort[1..-1]}.flatten).delete_all
|
56
|
+
logger.info "Cleaned up #{dups_count} duplicate selection-objects associations for selection #{apidae_id}"
|
57
|
+
end
|
58
|
+
|
45
59
|
def results(where_clause, offset, size)
|
46
60
|
objects.includes(:town).limit(size).offset(offset).where(where_clause)
|
47
61
|
end
|
data/lib/apidae/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: apidae
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.2.
|
4
|
+
version: 1.2.24
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Jean-Baptiste Vilain
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2021-
|
11
|
+
date: 2021-10-05 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|