spree_cm_commissioner 2.8.3.pre6 → 2.8.3.pre.pre7
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 +4 -4
- data/.github/workflows/test_and_build_gem.yml +2 -1
- data/.gitignore +6 -0
- data/Gemfile.lock +1 -1
- data/app/controllers/concerns/spree_cm_commissioner/content_cachable.rb +2 -0
- data/app/controllers/spree/admin/homepage_section_controller.rb +4 -1
- data/app/controllers/spree/admin/taxons_controller_decorator.rb +19 -0
- data/app/controllers/spree/api/v2/storefront/homepage_sections_controller.rb +1 -0
- data/app/controllers/spree/api/v2/storefront/preview_products_controller.rb +48 -0
- data/app/controllers/spree/api/v2/storefront/preview_sections_controller.rb +27 -0
- data/app/controllers/spree/api/v2/storefront/preview_taxons_controller.rb +18 -0
- data/app/controllers/spree/api/v2/storefront/products_controller_decorator.rb +15 -0
- data/app/controllers/spree/api/v2/storefront/taxons_controller_decorator.rb +15 -0
- data/app/controllers/spree/api/v2/tenant/advertisements_controller.rb +24 -0
- data/app/controllers/spree/api/v2/tenant/base_controller.rb +4 -0
- data/app/controllers/spree/api/v2/tenant/episodes_controller.rb +38 -0
- data/app/controllers/spree/api/v2/tenant/free_vote_claims_controller.rb +37 -0
- data/app/controllers/spree/api/v2/tenant/homepage_sections_controller.rb +1 -0
- data/app/controllers/spree/api/v2/tenant/preview_products_controller.rb +47 -0
- data/app/controllers/spree/api/v2/tenant/preview_sections_controller.rb +26 -0
- data/app/controllers/spree/api/v2/tenant/preview_shows_controller.rb +19 -0
- data/app/controllers/spree/api/v2/tenant/preview_taxons_controller.rb +19 -0
- data/app/controllers/spree/api/v2/tenant/products_controller.rb +1 -1
- data/app/controllers/spree/api/v2/tenant/show_contestants_controller.rb +52 -0
- data/app/controllers/spree/api/v2/tenant/show_elimination_sessions_controller.rb +57 -0
- data/app/controllers/spree/api/v2/tenant/show_people_controller.rb +49 -0
- data/app/controllers/spree/api/v2/tenant/show_person_assignments_controller.rb +36 -0
- data/app/controllers/spree/api/v2/tenant/shows_controller.rb +36 -0
- data/app/controllers/spree/api/v2/tenant/taxons_controller.rb +1 -1
- data/app/controllers/spree/api/v2/tenant/votes_controller.rb +94 -0
- data/app/controllers/spree/api/v2/tenant/voting_contestants_controller.rb +43 -0
- data/app/controllers/spree/api/v2/tenant/voting_credit_transactions_controller.rb +41 -0
- data/app/controllers/spree/api/v2/tenant/voting_credits_controller.rb +31 -0
- data/app/controllers/spree_cm_commissioner/admin/products_controller_decorator.rb +19 -0
- data/app/finders/spree_cm_commissioner/accommodations/find_variant.rb +2 -2
- data/app/finders/spree_cm_commissioner/events/find_matches.rb +1 -0
- data/app/helpers/spree_cm_commissioner/admin/homepage_segment_helper.rb +2 -0
- data/app/jobs/spree_cm_commissioner/show_contestants/import_job.rb +9 -0
- data/app/jobs/spree_cm_commissioner/vote_fraud_event_job.rb +9 -0
- data/app/jobs/spree_cm_commissioner/voting_credit_allocation_job.rb +10 -0
- data/app/jobs/spree_cm_commissioner/voting_credit_de_allocation_job.rb +10 -0
- data/app/models/concerns/spree_cm_commissioner/homepage_section_bitwise.rb +2 -1
- data/app/models/concerns/spree_cm_commissioner/option_type_attr_type.rb +2 -1
- data/app/models/concerns/spree_cm_commissioner/order_state_machine.rb +10 -0
- data/app/models/concerns/spree_cm_commissioner/product_type.rb +1 -1
- data/app/models/concerns/spree_cm_commissioner/taxon_kind.rb +3 -1
- data/app/models/concerns/spree_cm_commissioner/vehicle_kind.rb +1 -1
- data/app/models/concerns/spree_cm_commissioner/voting_session_live_stream_concern.rb +41 -0
- data/app/models/spree_cm_commissioner/import.rb +1 -1
- data/app/models/spree_cm_commissioner/imports/import_contestant.rb +7 -0
- data/app/models/spree_cm_commissioner/integration.rb +0 -31
- data/app/models/spree_cm_commissioner/integrations/stadium_x_v1.rb +10 -4
- data/app/models/spree_cm_commissioner/inventory_item.rb +0 -6
- data/app/models/spree_cm_commissioner/maintenance_tasks/voting_session.rb +36 -0
- data/app/models/spree_cm_commissioner/order_decorator.rb +0 -1
- data/app/models/spree_cm_commissioner/place.rb +0 -2
- data/app/models/spree_cm_commissioner/preview_role.rb +8 -0
- data/app/models/spree_cm_commissioner/product_decorator.rb +50 -0
- data/app/models/spree_cm_commissioner/role_decorator.rb +4 -1
- data/app/models/spree_cm_commissioner/role_user_decorator.rb +8 -0
- data/app/models/spree_cm_commissioner/route.rb +0 -1
- data/app/models/spree_cm_commissioner/seat_layout.rb +0 -2
- data/app/models/spree_cm_commissioner/show.rb +163 -0
- data/app/models/spree_cm_commissioner/show_contestant.rb +39 -0
- data/app/models/spree_cm_commissioner/show_contestant_image.rb +11 -0
- data/app/models/spree_cm_commissioner/show_contestant_video.rb +15 -0
- data/app/models/spree_cm_commissioner/show_episode.rb +108 -0
- data/app/models/spree_cm_commissioner/show_person.rb +15 -0
- data/app/models/spree_cm_commissioner/show_person_assignment.rb +21 -0
- data/app/models/spree_cm_commissioner/show_person_image.rb +11 -0
- data/app/models/spree_cm_commissioner/stock_item_decorator.rb +0 -4
- data/app/models/spree_cm_commissioner/taxon_decorator.rb +22 -0
- data/app/models/spree_cm_commissioner/taxonomy_decorator.rb +19 -1
- data/app/models/spree_cm_commissioner/tenant.rb +9 -0
- data/app/models/spree_cm_commissioner/trip.rb +1 -2
- data/app/models/spree_cm_commissioner/trip_stop.rb +0 -2
- data/app/models/spree_cm_commissioner/user_decorator.rb +5 -0
- data/app/models/spree_cm_commissioner/variant_decorator.rb +4 -1
- data/app/models/spree_cm_commissioner/variant_options.rb +4 -0
- data/app/models/spree_cm_commissioner/vehicle.rb +0 -3
- data/app/models/spree_cm_commissioner/vehicle_type.rb +0 -1
- data/app/models/spree_cm_commissioner/vendor_decorator.rb +4 -17
- data/app/models/spree_cm_commissioner/vendor_place.rb +0 -2
- data/app/models/spree_cm_commissioner/vote.rb +16 -0
- data/app/models/spree_cm_commissioner/vote_fraud_event.rb +20 -0
- data/app/models/spree_cm_commissioner/voting_contestant.rb +100 -0
- data/app/models/spree_cm_commissioner/voting_credit.rb +72 -0
- data/app/models/spree_cm_commissioner/voting_credit_transaction.rb +55 -0
- data/app/models/spree_cm_commissioner/voting_session.rb +216 -0
- data/app/models/spree_cm_commissioner/voting_session_stat.rb +8 -0
- data/app/overrides/spree/admin/products/_form/preview_checkbox.html.erb.deface +9 -0
- data/app/overrides/spree/admin/taxons/_form/preview_checkbox.html.erb.deface +7 -0
- data/app/serializers/spree/v2/storefront/homepage_section_serializer.rb +1 -1
- data/app/serializers/spree/v2/storefront/product_serializer_decorator.rb +1 -1
- data/app/serializers/spree/v2/storefront/role_serializer.rb +1 -1
- data/app/serializers/spree/v2/storefront/taxon_serializer_decorator.rb +2 -1
- data/app/serializers/spree/v2/tenant/advertisement_serializer.rb +11 -0
- data/app/serializers/spree/v2/tenant/campaign_serializer.rb +13 -0
- data/app/serializers/spree/v2/tenant/homepage_section_serializer.rb +1 -1
- data/app/serializers/spree/v2/tenant/role_serializer.rb +1 -1
- data/app/serializers/spree/v2/tenant/show_contestant_serializer.rb +21 -0
- data/app/serializers/spree/v2/tenant/show_episode_serializer.rb +20 -0
- data/app/serializers/spree/v2/tenant/show_person_assignment_serializer.rb +16 -0
- data/app/serializers/spree/v2/tenant/show_person_serializer.rb +13 -0
- data/app/serializers/spree/v2/tenant/show_serializer.rb +21 -0
- data/app/serializers/spree/v2/tenant/video_serializer.rb +9 -0
- data/app/serializers/spree/v2/tenant/vote_package_serializer.rb +9 -0
- data/app/serializers/spree/v2/tenant/vote_serializer.rb +14 -0
- data/app/serializers/spree/v2/tenant/voting_contestant_serializer.rb +23 -0
- data/app/serializers/spree/v2/tenant/voting_credit_serializer.rb +10 -0
- data/app/serializers/spree/v2/tenant/voting_credit_transaction_serializer.rb +14 -0
- data/app/serializers/spree/v2/tenant/voting_session_serializer.rb +21 -0
- data/app/services/spree_cm_commissioner/advertisements/sorted_advertisements.rb +61 -0
- data/app/services/spree_cm_commissioner/advertisements/update_campaign_sorted_ads_ids.rb +33 -0
- data/app/services/spree_cm_commissioner/api_caches/invalidate.rb +12 -0
- data/app/services/spree_cm_commissioner/fraud_check.rb +299 -0
- data/app/services/spree_cm_commissioner/imports/contestants/create.rb +153 -0
- data/app/services/spree_cm_commissioner/integrations/base/sync_manager.rb +2 -1
- data/app/services/spree_cm_commissioner/integrations/base/sync_result.rb +0 -11
- data/app/services/spree_cm_commissioner/integrations/stadium_x_v1/external_client/client.rb +15 -14
- data/app/services/spree_cm_commissioner/integrations/stadium_x_v1/polling/sync_matches.rb +4 -7
- data/app/services/spree_cm_commissioner/integrations/stadium_x_v1/polling/sync_zones.rb +3 -6
- data/app/services/spree_cm_commissioner/integrations/stadium_x_v1/sync_manager.rb +3 -0
- data/app/services/spree_cm_commissioner/integrations/stadium_x_v1/sync_strategies/full_sync_strategy.rb +3 -1
- data/app/services/spree_cm_commissioner/integrations/stadium_x_v1/sync_strategies/incremental_sync_strategy.rb +3 -1
- data/app/services/spree_cm_commissioner/integrations/stadium_x_v1/sync_strategies/webhook_sync_strategy.rb +2 -1
- data/app/services/spree_cm_commissioner/order_holds/hold.rb +0 -17
- data/app/services/spree_cm_commissioner/order_holds/release.rb +0 -17
- data/app/services/spree_cm_commissioner/show_contestants/normalize_video_highlights.rb +57 -0
- data/app/services/spree_cm_commissioner/show_persons/contestant_assigner.rb +51 -0
- data/app/services/spree_cm_commissioner/url_embed/youtube_embed.rb +44 -0
- data/app/services/spree_cm_commissioner/vote_counters/audit_counters.rb +43 -0
- data/app/services/spree_cm_commissioner/vote_counters/base.rb +31 -0
- data/app/services/spree_cm_commissioner/vote_counters/increment.rb +44 -0
- data/app/services/spree_cm_commissioner/vote_counters/per_contestant_counter.rb +68 -0
- data/app/services/spree_cm_commissioner/vote_counters/rebuild_from_db.rb +70 -0
- data/app/services/spree_cm_commissioner/vote_counters/snapshot_to_db.rb +113 -0
- data/app/services/spree_cm_commissioner/vote_credit_deductor.rb +68 -0
- data/app/services/spree_cm_commissioner/vote_package/create.rb +145 -0
- data/app/services/spree_cm_commissioner/vote_package/update.rb +91 -0
- data/app/services/spree_cm_commissioner/vote_processor.rb +144 -0
- data/app/services/spree_cm_commissioner/voting_contestants/advancer.rb +335 -0
- data/app/services/spree_cm_commissioner/voting_contestants/assigner.rb +40 -0
- data/app/services/spree_cm_commissioner/voting_contestants/bulk_updater.rb +106 -0
- data/app/services/spree_cm_commissioner/voting_credits/allocate.rb +77 -0
- data/app/services/spree_cm_commissioner/voting_credits/claim_free_votes.rb +119 -0
- data/app/services/spree_cm_commissioner/voting_credits/credit_calculator.rb +35 -0
- data/app/services/spree_cm_commissioner/voting_credits/de_allocate.rb +87 -0
- data/app/services/spree_cm_commissioner/voting_leaderboards/calculate_score.rb +67 -0
- data/app/services/spree_cm_commissioner/voting_leaderboards/combined_result.rb +190 -0
- data/app/services/spree_cm_commissioner/voting_sessions/finalize.rb +106 -0
- data/app/views/spree/admin/homepage_section/_form.html.erb +5 -0
- data/app/views/spree/admin/integrations/_form.html.erb +0 -12
- data/app/views/spree/admin/integrations/index.html.erb +1 -1
- data/config/initializers/spree_permitted_attributes.rb +8 -0
- data/config/locales/en.yml +43 -3
- data/config/locales/km.yml +73 -1
- data/config/routes.rb +28 -1
- data/db/migrate/20260309230148_create_cm_show_people.rb +14 -0
- data/db/migrate/20260309230149_create_cm_show_people_assignments.rb +16 -0
- data/db/migrate/20260310082711_create_cm_show_contestants.rb +28 -0
- data/db/migrate/20260310082720_create_cm_voting_sessions.rb +21 -0
- data/db/migrate/20260310082721_create_cm_voting_contestants.rb +23 -0
- data/db/migrate/20260310082734_add_voting_fields_to_spree_taxons.rb +9 -0
- data/db/migrate/20260310082735_add_type_to_spree_products.rb +6 -0
- data/db/migrate/20260310082749_create_cm_voting_credits.rb +27 -0
- data/db/migrate/20260326080200_create_cm_voting_credit_transactions.rb +27 -0
- data/db/migrate/20260330160000_create_cm_votes.rb +25 -0
- data/db/migrate/20260401072500_add_advanced_from_to_cm_voting_contestants.rb +7 -0
- data/db/migrate/20260402000001_add_voting_credit_scope_to_spree_taxons.rb +6 -0
- data/db/migrate/20260402000002_rename_scopeable_to_votable_in_cm_voting_credits.rb +12 -0
- data/db/migrate/20260403070000_add_name_to_cm_voting_sessions.rb +5 -0
- data/db/migrate/20260406000001_add_vendor_id_to_voting_tables.rb +6 -0
- data/db/migrate/20260406000001_rename_votes_remaining_to_amount_in_cm_voting_credits.rb +11 -0
- data/db/migrate/20260408085255_add_show_id_and_vendor_id_to_cm_voting_sessions.rb +9 -0
- data/db/migrate/20260420000001_rename_type_to_credit_type_in_cm_voting_credits.rb +25 -0
- data/db/migrate/20260422000001_create_cm_vote_fraud_events.rb +23 -0
- data/db/migrate/20260423000001_add_preview_to_taxons_products_and_sections.rb +11 -0
- data/db/migrate/20260423000002_create_preview_roles.rb +24 -0
- data/db/migrate/20260515120000_add_public_metadata_to_cm_voting_sessions.rb +5 -0
- data/db/migrate/20260518090920_add_unique_voter_count_to_voting_contestants.rb +5 -0
- data/db/migrate/20260518094322_create_cm_voting_session_stats.rb +17 -0
- data/db/migrate/20260520000001_add_scoring_model_to_cm_voting_sessions.rb +5 -0
- data/db/migrate/20260520000001_optimize_cm_votes_indexes.rb +22 -0
- data/db/migrate/20260525042257_add_vote_number_to_cm_voting_contestants.rb +18 -0
- data/db/migrate/20260527035430_add_confirmed_rank_to_cm_voting_contestants.rb +5 -0
- data/db/migrate/20260527062005_add_eliminated_at_to_cm_show_contestants.rb +5 -0
- data/db/migrate/20260603063652_add_parent_to_voting_sessions.rb +9 -0
- data/db/migrate/20260603090000_add_session_type_to_cm_voting_sessions.rb +6 -0
- data/db/migrate/20260608000000_add_display_to_cm_voting_sessions.rb +5 -0
- data/docs/sql/jsonb_query_guide.md +57 -0
- data/lib/spree_cm_commissioner/test_helper/factories/integration_factory.rb +0 -11
- data/lib/spree_cm_commissioner/test_helper/factories/show_episode_factory.rb +12 -0
- data/lib/spree_cm_commissioner/test_helper/factories/show_factory.rb +120 -0
- data/lib/spree_cm_commissioner/test_helper/factories/vote_credit_factory.rb +37 -0
- data/lib/spree_cm_commissioner/test_helper/factories/vote_factory.rb +28 -0
- data/lib/spree_cm_commissioner/test_helper/factories/voting_credit_transaction_factory.rb +11 -0
- data/lib/spree_cm_commissioner/test_helper/factories/voting_session_factory.rb +11 -0
- data/lib/spree_cm_commissioner/version.rb +1 -1
- data/lib/spree_cm_commissioner.rb +7 -1
- data/spree_cm_commissioner.gemspec +1 -1
- metadata +130 -116
- data/app/controllers/spree/api/v2/storefront/transit/item_availabilities_controller.rb +0 -66
- data/app/jobs/spree_cm_commissioner/audit_event_job.rb +0 -29
- data/app/models/concerns/spree_cm_commissioner/audit_wrapper.rb +0 -139
- data/app/models/concerns/spree_cm_commissioner/integrations/inventory_sync_cachable.rb +0 -9
- data/app/models/concerns/spree_cm_commissioner/variant_metadata.rb +0 -24
- data/app/models/spree_cm_commissioner/audit_event.rb +0 -11
- data/app/models/spree_cm_commissioner/currency_rate.rb +0 -15
- data/app/models/spree_cm_commissioner/integrations/book_me_bus_v1.rb +0 -56
- data/app/models/spree_cm_commissioner/integrations/larryta.rb +0 -81
- data/app/models/spree_cm_commissioner/integrations/vireak_buntham.rb +0 -82
- data/app/serializables/spree_cm_commissioner/item_availability_sync.rb +0 -10
- data/app/serializers/spree_cm_commissioner/v2/storefront/item_availability_sync_serializer.rb +0 -10
- data/app/services/spree_cm_commissioner/audit_logger.rb +0 -59
- data/app/services/spree_cm_commissioner/currency_converter/create.rb +0 -27
- data/app/services/spree_cm_commissioner/currency_rates/manage.rb +0 -99
- data/app/services/spree_cm_commissioner/google_maps_geocoder.rb +0 -41
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/external_client/client.rb +0 -261
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/external_client/connection.rb +0 -147
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/inventory/external_inventory_item_status.rb +0 -52
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/inventory/external_inventory_items.rb +0 -91
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/inventory/unstock_inventory.rb +0 -140
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/polling/sync_inventory.rb +0 -52
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/polling/sync_item_availability.rb +0 -249
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/polling/sync_locations.rb +0 -103
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/polling/sync_product.rb +0 -66
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/polling/sync_route_stops.rb +0 -113
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/polling/sync_routes.rb +0 -128
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/polling/sync_seat_layout.rb +0 -345
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/polling/sync_service_calendars.rb +0 -59
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/polling/sync_trip_stop.rb +0 -179
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/polling/sync_trips.rb +0 -597
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/polling/sync_variant.rb +0 -58
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/polling/sync_vehicle_types.rb +0 -87
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/polling/time_parser.rb +0 -19
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/resources/base.rb +0 -40
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/resources/branch.rb +0 -65
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/resources/direction.rb +0 -51
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/resources/inventory_item_status.rb +0 -148
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/resources/location.rb +0 -55
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/resources/operator.rb +0 -17
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/resources/reservation_cart.rb +0 -85
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/resources/seat.rb +0 -128
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/resources/seat_layout.rb +0 -363
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/resources/stop.rb +0 -84
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/resources/trip.rb +0 -199
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/resources/wallet_payment.rb +0 -40
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/sync_manager.rb +0 -22
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/sync_strategies/full_sync_strategy.rb +0 -117
- data/app/services/spree_cm_commissioner/integrations/book_me_bus_v1/sync_strategies/incremental_sync_strategy.rb +0 -64
- data/app/services/spree_cm_commissioner/integrations/larryta/external_client/client.rb +0 -344
- data/app/services/spree_cm_commissioner/integrations/larryta/external_client/connection.rb +0 -74
- data/app/services/spree_cm_commissioner/integrations/larryta/inventory/external_inventory_item_status.rb +0 -53
- data/app/services/spree_cm_commissioner/integrations/larryta/inventory/external_inventory_items.rb +0 -106
- data/app/services/spree_cm_commissioner/integrations/larryta/inventory/hold_seats.rb +0 -143
- data/app/services/spree_cm_commissioner/integrations/larryta/inventory/release_seats.rb +0 -90
- data/app/services/spree_cm_commissioner/integrations/larryta/inventory/unstock_inventory.rb +0 -113
- data/app/services/spree_cm_commissioner/integrations/larryta/polling/sync_item_availability.rb +0 -261
- data/app/services/spree_cm_commissioner/integrations/larryta/polling/sync_product.rb +0 -72
- data/app/services/spree_cm_commissioner/integrations/larryta/polling/sync_routes.rb +0 -142
- data/app/services/spree_cm_commissioner/integrations/larryta/polling/sync_seat_layout.rb +0 -255
- data/app/services/spree_cm_commissioner/integrations/larryta/polling/sync_stock_item.rb +0 -55
- data/app/services/spree_cm_commissioner/integrations/larryta/polling/sync_trip_stop.rb +0 -167
- data/app/services/spree_cm_commissioner/integrations/larryta/polling/sync_trips.rb +0 -319
- data/app/services/spree_cm_commissioner/integrations/larryta/polling/sync_variant.rb +0 -63
- data/app/services/spree_cm_commissioner/integrations/larryta/polling/sync_vehicle_type.rb +0 -79
- data/app/services/spree_cm_commissioner/integrations/larryta/resources/base.rb +0 -39
- data/app/services/spree_cm_commissioner/integrations/larryta/resources/booking.rb +0 -113
- data/app/services/spree_cm_commissioner/integrations/larryta/resources/booking_session.rb +0 -43
- data/app/services/spree_cm_commissioner/integrations/larryta/resources/booking_transaction.rb +0 -238
- data/app/services/spree_cm_commissioner/integrations/larryta/resources/direction.rb +0 -71
- data/app/services/spree_cm_commissioner/integrations/larryta/resources/passenger.rb +0 -48
- data/app/services/spree_cm_commissioner/integrations/larryta/resources/schedule.rb +0 -150
- data/app/services/spree_cm_commissioner/integrations/larryta/resources/seat.rb +0 -31
- data/app/services/spree_cm_commissioner/integrations/larryta/resources/seat_availability.rb +0 -49
- data/app/services/spree_cm_commissioner/integrations/larryta/resources/seat_layout.rb +0 -211
- data/app/services/spree_cm_commissioner/integrations/larryta/sync_manager.rb +0 -17
- data/app/services/spree_cm_commissioner/integrations/larryta/sync_strategies/full_sync_strategy.rb +0 -79
- data/app/services/spree_cm_commissioner/integrations/larryta/sync_strategies/incremental_sync_strategy.rb +0 -58
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/external_client/client.rb +0 -206
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/external_client/connection.rb +0 -59
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/inventory/external_inventory_item_status.rb +0 -48
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/inventory/external_inventory_items.rb +0 -97
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/inventory/unstock_inventory.rb +0 -208
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/polling/sync_item_availability.rb +0 -270
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/polling/sync_locations.rb +0 -96
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/polling/sync_nationality_pricing.rb +0 -76
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/polling/sync_product.rb +0 -69
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/polling/sync_routes.rb +0 -110
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/polling/sync_seat_layout.rb +0 -207
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/polling/sync_stock_item.rb +0 -43
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/polling/sync_trip_stop.rb +0 -187
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/polling/sync_trips.rb +0 -300
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/polling/sync_variant.rb +0 -56
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/polling/sync_vehicle_type.rb +0 -51
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/resources/base.rb +0 -32
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/resources/booking.rb +0 -48
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/resources/booking_transaction.rb +0 -46
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/resources/cell.rb +0 -53
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/resources/confirm_booking_request.rb +0 -43
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/resources/location.rb +0 -37
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/resources/schedule.rb +0 -138
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/resources/seat.rb +0 -48
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/resources/seat_layout.rb +0 -79
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/sync_manager.rb +0 -17
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/sync_strategies/full_sync_strategy.rb +0 -87
- data/app/services/spree_cm_commissioner/integrations/vireak_buntham/sync_strategies/incremental_sync_strategy.rb +0 -53
- data/app/services/spree_cm_commissioner/inventory_items/generate_permanent_item.rb +0 -48
- data/app/services/spree_cm_commissioner/place_resolver.rb +0 -95
- data/app/views/spree/admin/integrations/_book_me_bus_v1_fields.html.erb +0 -47
- data/app/views/spree/admin/integrations/_larryta_fields.html.erb +0 -58
- data/app/views/spree/admin/integrations/_vireak_buntham_fields.html.erb +0 -75
- data/db/migrate/20260327143200_create_cm_audit_events.rb +0 -21
- data/db/migrate/20260410045815_create_cm_currency_rates.rb +0 -23
- data/db/migrate/20260411102139_add_metadata_to_cm_inventory_items.rb +0 -6
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 6453df013c8c48c7750f2c78315a47a008d71d2d08a18a627e6f23d1cb8e0564
|
|
4
|
+
data.tar.gz: d28c67f073a707a50fe3f44a6bb6c9184fe3403ffc6909585137b73ae8305c39
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 18c051ff735f3af699821c909d430921a245cae3ba50bf798db8a5e7d20decab213b2432855d28ad22283e9fbdc17e45326a78e14e6c6a9f42d332be94a91b45
|
|
7
|
+
data.tar.gz: 37cbb8aea0043989a2eac1ade7f2184aa71d8a57349c1fd9978c2147787a65aa80134be083cf48d3e9074134eccb3e91197694dca20098140340276333b71e5a
|
|
@@ -164,7 +164,8 @@ jobs:
|
|
|
164
164
|
env:
|
|
165
165
|
DATABASE_URL: postgres://myuser:mypassword@localhost:5432/test_db
|
|
166
166
|
run: |
|
|
167
|
-
|
|
167
|
+
# Using --no-threads to bypass a known Ruby 3.2.0 GC segmentation fault in CI.
|
|
168
|
+
bundle exec brakeman --no-threads --no-exit-on-warn
|
|
168
169
|
|
|
169
170
|
test:
|
|
170
171
|
needs: [setup]
|
data/.gitignore
CHANGED
data/Gemfile.lock
CHANGED
|
@@ -16,6 +16,7 @@ module SpreeCmCommissioner
|
|
|
16
16
|
GuestCardClassesController
|
|
17
17
|
SeatLayoutController
|
|
18
18
|
CmsPagesController
|
|
19
|
+
AdvertisementsController
|
|
19
20
|
].freeze
|
|
20
21
|
|
|
21
22
|
# Priority 2: Semi-Static (1 hour)
|
|
@@ -25,6 +26,7 @@ module SpreeCmCommissioner
|
|
|
25
26
|
HomepageDataController
|
|
26
27
|
PopularRoutesController
|
|
27
28
|
RoutePlacesController
|
|
29
|
+
ShowsController
|
|
28
30
|
].freeze
|
|
29
31
|
|
|
30
32
|
# Priority 3: Moderate Freshness (30 minutes)
|
|
@@ -51,7 +51,10 @@ module Spree
|
|
|
51
51
|
def permitted_resource_params
|
|
52
52
|
segment_value = helpers.calculate_segment_value(params[:spree_cm_commissioner_homepage_section])
|
|
53
53
|
|
|
54
|
-
params
|
|
54
|
+
params
|
|
55
|
+
.require(:spree_cm_commissioner_homepage_section)
|
|
56
|
+
.permit(:title, :description, :active, :tenant_id, :preview)
|
|
57
|
+
.merge(segment: segment_value)
|
|
55
58
|
end
|
|
56
59
|
|
|
57
60
|
def load_tenants
|
|
@@ -3,6 +3,7 @@ module Spree
|
|
|
3
3
|
module TaxonsControllerDecorator
|
|
4
4
|
def self.prepended(base)
|
|
5
5
|
base.before_action :build_assets, only: %i[create update]
|
|
6
|
+
base.before_action :normalize_sti_taxon_params, only: %i[create update]
|
|
6
7
|
end
|
|
7
8
|
|
|
8
9
|
# override
|
|
@@ -50,6 +51,24 @@ module Spree
|
|
|
50
51
|
@taxon.build_home_banner(attachment: permitted_resource_params.delete(:home_banner)) if permitted_resource_params[:home_banner]
|
|
51
52
|
@taxon.build_video_banner(attachment: permitted_resource_params.delete(:video_banner)) if permitted_resource_params[:video_banner]
|
|
52
53
|
end
|
|
54
|
+
|
|
55
|
+
# Some admin forms submit STI records under their class key
|
|
56
|
+
# (e.g. :spree_cm_commissioner_show) while Spree update reads :taxon.
|
|
57
|
+
# Merge both into :taxon so all edited fields are persisted.
|
|
58
|
+
def normalize_sti_taxon_params
|
|
59
|
+
return unless @taxon
|
|
60
|
+
|
|
61
|
+
sti_key = @taxon.class.model_name.param_key.to_sym
|
|
62
|
+
sti_params = params[sti_key]
|
|
63
|
+
return unless sti_params.is_a?(::ActionController::Parameters)
|
|
64
|
+
|
|
65
|
+
base_params = params[:taxon]
|
|
66
|
+
base_hash = base_params.is_a?(::ActionController::Parameters) ? base_params.to_unsafe_h : {}
|
|
67
|
+
sti_hash = sti_params.to_unsafe_h
|
|
68
|
+
merged_params = ::ActionController::Parameters.new(base_hash.merge(sti_hash))
|
|
69
|
+
|
|
70
|
+
params[:taxon] = merged_params
|
|
71
|
+
end
|
|
53
72
|
end
|
|
54
73
|
end
|
|
55
74
|
end
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Storefront
|
|
5
|
+
class PreviewProductsController < ::Spree::Api::V2::Storefront::ProductsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
private
|
|
9
|
+
|
|
10
|
+
def scope(**args)
|
|
11
|
+
taxon_type = model_class.reflect_on_association(:taxons).klass.polymorphic_name
|
|
12
|
+
|
|
13
|
+
# IDs of products that have been explicitly assigned their own PreviewRole.
|
|
14
|
+
products_with_own_roles = SpreeCmCommissioner::PreviewRole
|
|
15
|
+
.where(previewable_type: model_class.polymorphic_name)
|
|
16
|
+
.select(:previewable_id)
|
|
17
|
+
|
|
18
|
+
# Base: all active preview products from the parent scope.
|
|
19
|
+
base = super(**args).rewhere(preview: true).where(status: :active)
|
|
20
|
+
|
|
21
|
+
# Path A: product has its own PreviewRole → user must hold that role directly.
|
|
22
|
+
# Taxon membership is irrelevant for these products.
|
|
23
|
+
via_product_role = base
|
|
24
|
+
.where(id: products_with_own_roles)
|
|
25
|
+
.where(id: spree_current_user.preview_roles
|
|
26
|
+
.where(previewable_type: model_class.polymorphic_name)
|
|
27
|
+
.select(:previewable_id)
|
|
28
|
+
)
|
|
29
|
+
|
|
30
|
+
# Path B: product has no own PreviewRole → inherit access from its taxons.
|
|
31
|
+
# Accessible if the user holds a preview role for any taxon the product belongs to.
|
|
32
|
+
via_taxon = base
|
|
33
|
+
.where.not(id: products_with_own_roles)
|
|
34
|
+
.joins(:taxons)
|
|
35
|
+
.where(spree_taxons: { id: spree_current_user.preview_roles
|
|
36
|
+
.where(previewable_type: taxon_type)
|
|
37
|
+
.select(:previewable_id)
|
|
38
|
+
}
|
|
39
|
+
)
|
|
40
|
+
|
|
41
|
+
# via_taxon uses joins(:taxons) which is incompatible with or — wrap as subquery.
|
|
42
|
+
via_product_role.or(base.where(id: via_taxon.select(:id)))
|
|
43
|
+
end
|
|
44
|
+
end
|
|
45
|
+
end
|
|
46
|
+
end
|
|
47
|
+
end
|
|
48
|
+
end
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Storefront
|
|
5
|
+
class PreviewSectionsController < HomepageSectionsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
# override
|
|
9
|
+
def collection
|
|
10
|
+
allowed_ids = spree_current_user.preview_roles.where(previewable_type: Spree::Taxon.polymorphic_name).pluck(:previewable_id)
|
|
11
|
+
|
|
12
|
+
section_ids = SpreeCmCommissioner::HomepageSectionRelatable
|
|
13
|
+
.where(relatable_type: 'Spree::Taxon', relatable_id: allowed_ids.presence || [])
|
|
14
|
+
.select(:homepage_section_id)
|
|
15
|
+
|
|
16
|
+
@collection ||= model_class.filter_by_segment(params[:homepage_id] || :general)
|
|
17
|
+
.active
|
|
18
|
+
.where(tenant_id: nil)
|
|
19
|
+
.where(preview: true)
|
|
20
|
+
.where(id: section_ids)
|
|
21
|
+
.order(position: :asc)
|
|
22
|
+
end
|
|
23
|
+
end
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
end
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Storefront
|
|
5
|
+
class PreviewTaxonsController < ::Spree::Api::V2::Storefront::TaxonsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
private
|
|
9
|
+
|
|
10
|
+
def scope(**args)
|
|
11
|
+
allowed_ids = spree_current_user.preview_roles.where(previewable_type: model_class.polymorphic_name).select(:previewable_id)
|
|
12
|
+
super(**args).rewhere(preview: true).where(id: allowed_ids)
|
|
13
|
+
end
|
|
14
|
+
end
|
|
15
|
+
end
|
|
16
|
+
end
|
|
17
|
+
end
|
|
18
|
+
end
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Storefront
|
|
5
|
+
module ProductsControllerDecorator
|
|
6
|
+
def scope
|
|
7
|
+
super.where(preview: false)
|
|
8
|
+
end
|
|
9
|
+
end
|
|
10
|
+
end
|
|
11
|
+
end
|
|
12
|
+
end
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
Spree::Api::V2::Storefront::ProductsController.prepend(Spree::Api::V2::Storefront::ProductsControllerDecorator)
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Storefront
|
|
5
|
+
module TaxonsControllerDecorator
|
|
6
|
+
def scope
|
|
7
|
+
super.where(preview: false)
|
|
8
|
+
end
|
|
9
|
+
end
|
|
10
|
+
end
|
|
11
|
+
end
|
|
12
|
+
end
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
Spree::Api::V2::Storefront::TaxonsController.prepend(Spree::Api::V2::Storefront::TaxonsControllerDecorator)
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class AdvertisementsController < BaseController
|
|
6
|
+
private
|
|
7
|
+
|
|
8
|
+
def scope
|
|
9
|
+
Spree::Taxon.campaigns
|
|
10
|
+
.joins(:vendor)
|
|
11
|
+
.where(spree_vendors: { tenant_id: @tenant.id })
|
|
12
|
+
.where('spree_taxons.from_date <= ? OR spree_taxons.from_date IS NULL', Time.current)
|
|
13
|
+
.where('spree_taxons.to_date >= ? OR spree_taxons.to_date IS NULL', Time.current)
|
|
14
|
+
.order(created_at: :asc)
|
|
15
|
+
end
|
|
16
|
+
|
|
17
|
+
def collection_serializer
|
|
18
|
+
Spree::V2::Tenant::CampaignSerializer
|
|
19
|
+
end
|
|
20
|
+
end
|
|
21
|
+
end
|
|
22
|
+
end
|
|
23
|
+
end
|
|
24
|
+
end
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class EpisodesController < BaseController
|
|
6
|
+
private
|
|
7
|
+
|
|
8
|
+
def model_class
|
|
9
|
+
SpreeCmCommissioner::ShowEpisode
|
|
10
|
+
end
|
|
11
|
+
|
|
12
|
+
def resource
|
|
13
|
+
@resource ||= scope.find(params[:id])
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
def scope
|
|
17
|
+
current_season.episodes.where(product_type: :show_episode).includes(:voting_sessions, :vote_packages)
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
def current_season
|
|
21
|
+
@current_season ||= SpreeCmCommissioner::Show
|
|
22
|
+
.where(vendor_id: @tenant.vendors.select(:id))
|
|
23
|
+
.where.not(parent_id: nil)
|
|
24
|
+
.find_by!(slug: params[:show_id])
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
def resource_serializer
|
|
28
|
+
Spree::V2::Tenant::ShowEpisodeSerializer
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
def collection_serializer
|
|
32
|
+
Spree::V2::Tenant::ShowEpisodeSerializer
|
|
33
|
+
end
|
|
34
|
+
end
|
|
35
|
+
end
|
|
36
|
+
end
|
|
37
|
+
end
|
|
38
|
+
end
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class FreeVoteClaimsController < BaseController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
def create
|
|
9
|
+
show = current_vendor.shows.find(params[:show_id])
|
|
10
|
+
|
|
11
|
+
result = SpreeCmCommissioner::VotingCredits::ClaimFreeVotes.new(
|
|
12
|
+
show: show,
|
|
13
|
+
user: spree_current_user,
|
|
14
|
+
tenant_id: MultiTenant.current_tenant_id,
|
|
15
|
+
votable_type: params[:votable_type],
|
|
16
|
+
votable_id: params[:votable_id]
|
|
17
|
+
).call
|
|
18
|
+
|
|
19
|
+
if result.failure?
|
|
20
|
+
render_error_payload(result.error.to_s)
|
|
21
|
+
elsif result.value.nil?
|
|
22
|
+
head :no_content
|
|
23
|
+
else
|
|
24
|
+
render_serialized_payload { serialize_resource(result.value) }
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
private
|
|
29
|
+
|
|
30
|
+
def resource_serializer
|
|
31
|
+
Spree::V2::Tenant::VotingCreditSerializer
|
|
32
|
+
end
|
|
33
|
+
end
|
|
34
|
+
end
|
|
35
|
+
end
|
|
36
|
+
end
|
|
37
|
+
end
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class PreviewProductsController < ProductsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
# override
|
|
9
|
+
def scope
|
|
10
|
+
taxon_type = model_class.reflect_on_association(:taxons).klass.polymorphic_name
|
|
11
|
+
|
|
12
|
+
# IDs of products that have been explicitly assigned their own PreviewRole.
|
|
13
|
+
products_with_own_roles = SpreeCmCommissioner::PreviewRole
|
|
14
|
+
.where(previewable_type: model_class.polymorphic_name)
|
|
15
|
+
.select(:previewable_id)
|
|
16
|
+
|
|
17
|
+
# Base: all active preview products from the parent scope.
|
|
18
|
+
base = super.where(status: :active, preview: true)
|
|
19
|
+
|
|
20
|
+
# Path A: product has its own PreviewRole → user must hold that role directly.
|
|
21
|
+
# Taxon membership is irrelevant for these products.
|
|
22
|
+
via_product_role = base
|
|
23
|
+
.where(id: products_with_own_roles)
|
|
24
|
+
.where(id: spree_current_user.preview_roles
|
|
25
|
+
.where(previewable_type: model_class.polymorphic_name)
|
|
26
|
+
.select(:previewable_id)
|
|
27
|
+
)
|
|
28
|
+
|
|
29
|
+
# Path B: product has no own PreviewRole → inherit access from its taxons.
|
|
30
|
+
# Accessible if the user holds a preview role for any taxon the product belongs to.
|
|
31
|
+
via_taxon = base
|
|
32
|
+
.where.not(id: products_with_own_roles)
|
|
33
|
+
.joins(:taxons)
|
|
34
|
+
.where(spree_taxons: { id: spree_current_user.preview_roles
|
|
35
|
+
.where(previewable_type: taxon_type)
|
|
36
|
+
.select(:previewable_id)
|
|
37
|
+
}
|
|
38
|
+
)
|
|
39
|
+
|
|
40
|
+
# via_taxon uses joins(:taxons) which is incompatible with or — wrap as subquery.
|
|
41
|
+
via_product_role.or(base.where(id: via_taxon.select(:id)))
|
|
42
|
+
end
|
|
43
|
+
end
|
|
44
|
+
end
|
|
45
|
+
end
|
|
46
|
+
end
|
|
47
|
+
end
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class PreviewSectionsController < HomepageSectionsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
# override
|
|
9
|
+
def collection
|
|
10
|
+
allowed_ids = spree_current_user.preview_roles.where(previewable_type: Spree::Taxon.polymorphic_name).pluck(:previewable_id)
|
|
11
|
+
|
|
12
|
+
section_ids = SpreeCmCommissioner::HomepageSectionRelatable
|
|
13
|
+
.where(relatable_type: 'Spree::Taxon', relatable_id: allowed_ids.presence || [])
|
|
14
|
+
.select(:homepage_section_id)
|
|
15
|
+
|
|
16
|
+
@collection ||= scope.filter_by_segment(params[:homepage_id] || :general)
|
|
17
|
+
.active
|
|
18
|
+
.where(preview: true)
|
|
19
|
+
.where(id: section_ids)
|
|
20
|
+
.order(position: :asc)
|
|
21
|
+
end
|
|
22
|
+
end
|
|
23
|
+
end
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
end
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class PreviewShowsController < ShowsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
# override
|
|
9
|
+
def scope
|
|
10
|
+
allowed_ids = spree_current_user.preview_roles
|
|
11
|
+
.where(previewable_type: SpreeCmCommissioner::Show.polymorphic_name)
|
|
12
|
+
.select(:previewable_id)
|
|
13
|
+
super.rewhere(preview: true).where(id: allowed_ids)
|
|
14
|
+
end
|
|
15
|
+
end
|
|
16
|
+
end
|
|
17
|
+
end
|
|
18
|
+
end
|
|
19
|
+
end
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class PreviewTaxonsController < TaxonsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
# override
|
|
9
|
+
def scope
|
|
10
|
+
allowed_ids = spree_current_user.preview_roles.where(previewable_type: model_class.polymorphic_name).select(:previewable_id)
|
|
11
|
+
MultiTenant.with(@tenant) do
|
|
12
|
+
model_class.where(preview: true, id: allowed_ids)
|
|
13
|
+
end
|
|
14
|
+
end
|
|
15
|
+
end
|
|
16
|
+
end
|
|
17
|
+
end
|
|
18
|
+
end
|
|
19
|
+
end
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class ShowContestantsController < BaseController
|
|
6
|
+
private
|
|
7
|
+
|
|
8
|
+
# override
|
|
9
|
+
def model_class
|
|
10
|
+
SpreeCmCommissioner::ShowContestant
|
|
11
|
+
end
|
|
12
|
+
|
|
13
|
+
# override
|
|
14
|
+
def scope
|
|
15
|
+
return model_class.none unless current_show
|
|
16
|
+
|
|
17
|
+
model_class
|
|
18
|
+
.where(show_id: current_show.id)
|
|
19
|
+
.includes(
|
|
20
|
+
:show_contestant_images,
|
|
21
|
+
:show_contestant_videos,
|
|
22
|
+
:current_voting_session,
|
|
23
|
+
:voting_contestants,
|
|
24
|
+
assigned_show_person: :show_person_images,
|
|
25
|
+
show: [
|
|
26
|
+
:parent,
|
|
27
|
+
{ episodes: :voting_sessions },
|
|
28
|
+
{ seasons: { episodes: :voting_sessions } }
|
|
29
|
+
]
|
|
30
|
+
)
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
def current_show
|
|
34
|
+
@current_show ||= show_scope.find_by!(slug: params[:show_id])
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
def show_scope
|
|
38
|
+
vendor_ids = @tenant.vendors.select(:id)
|
|
39
|
+
return SpreeCmCommissioner::Show.none if vendor_ids.blank?
|
|
40
|
+
|
|
41
|
+
SpreeCmCommissioner::Show.where(vendor_id: vendor_ids)
|
|
42
|
+
end
|
|
43
|
+
|
|
44
|
+
# override
|
|
45
|
+
def resource_serializer
|
|
46
|
+
Spree::V2::Tenant::ShowContestantSerializer
|
|
47
|
+
end
|
|
48
|
+
end
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
end
|
|
52
|
+
end
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class ShowEliminationSessionsController < BaseController
|
|
6
|
+
# override
|
|
7
|
+
def collection
|
|
8
|
+
@collection ||= scope
|
|
9
|
+
.includes(
|
|
10
|
+
:episode,
|
|
11
|
+
:show,
|
|
12
|
+
eliminated_voting_contestants: [
|
|
13
|
+
:show_contestant,
|
|
14
|
+
{ show_contestant: %i[show_contestant_images show_contestant_videos] }
|
|
15
|
+
]
|
|
16
|
+
)
|
|
17
|
+
.order('cm_voting_sessions.closes_at DESC')
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
# override
|
|
21
|
+
def collection_serializer
|
|
22
|
+
Spree::V2::Tenant::VotingSessionSerializer
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
private
|
|
26
|
+
|
|
27
|
+
# override
|
|
28
|
+
def model_class
|
|
29
|
+
SpreeCmCommissioner::VotingSession
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
# override
|
|
33
|
+
def scope
|
|
34
|
+
return model_class.none unless current_show
|
|
35
|
+
|
|
36
|
+
current_show.voting_sessions
|
|
37
|
+
.joins(:episode)
|
|
38
|
+
.joins(:voting_contestants)
|
|
39
|
+
.where(voting_contestants: { eliminated: true })
|
|
40
|
+
.distinct
|
|
41
|
+
end
|
|
42
|
+
|
|
43
|
+
def current_show
|
|
44
|
+
@current_show ||= show_scope.find_by!(slug: params[:show_id])
|
|
45
|
+
end
|
|
46
|
+
|
|
47
|
+
def show_scope
|
|
48
|
+
vendor_ids = @tenant.vendors.select(:id)
|
|
49
|
+
return SpreeCmCommissioner::Show.none if vendor_ids.blank?
|
|
50
|
+
|
|
51
|
+
SpreeCmCommissioner::Show.where(vendor_id: vendor_ids)
|
|
52
|
+
end
|
|
53
|
+
end
|
|
54
|
+
end
|
|
55
|
+
end
|
|
56
|
+
end
|
|
57
|
+
end
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class ShowPeopleController < BaseController
|
|
6
|
+
private
|
|
7
|
+
|
|
8
|
+
# override
|
|
9
|
+
def model_class
|
|
10
|
+
SpreeCmCommissioner::ShowPerson
|
|
11
|
+
end
|
|
12
|
+
|
|
13
|
+
# override
|
|
14
|
+
def scope
|
|
15
|
+
scope = current_show.show_people
|
|
16
|
+
.joins(:assignments)
|
|
17
|
+
.distinct
|
|
18
|
+
.includes(
|
|
19
|
+
:assignments,
|
|
20
|
+
assigned_contestants: %i[show_contestant_images current_voting_session]
|
|
21
|
+
)
|
|
22
|
+
|
|
23
|
+
role = params[:role].presence
|
|
24
|
+
return scope if role.blank?
|
|
25
|
+
|
|
26
|
+
role_value = SpreeCmCommissioner::ShowPersonAssignment.roles[role.to_s]
|
|
27
|
+
return scope.none if role_value.nil?
|
|
28
|
+
|
|
29
|
+
scope.where(cm_show_people_assignments: { role: role_value })
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
# override
|
|
33
|
+
def collection_serializer
|
|
34
|
+
Spree::V2::Tenant::ShowPersonSerializer
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
def current_show
|
|
38
|
+
@current_show ||= show_scope.find_by!(slug: params[:show_id])
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
def show_scope
|
|
42
|
+
vendor_ids = @tenant.vendors.select(:id)
|
|
43
|
+
SpreeCmCommissioner::Show.where(vendor_id: vendor_ids)
|
|
44
|
+
end
|
|
45
|
+
end
|
|
46
|
+
end
|
|
47
|
+
end
|
|
48
|
+
end
|
|
49
|
+
end
|