seatsio 25.0.0 → 26.1.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 2f529ad3f22b668701740d0e1c0a290025c386df2ae6f50b312f44e0e10b6ac1
4
- data.tar.gz: bcd5cfd74a16f1f2cd9c3cc73492654ac26835d6e897ec9859312ad0dc6f2b95
3
+ metadata.gz: 88ee98c7b310f64dc09c357d9f52d18d0438751b35db4c121228a76503b71c3e
4
+ data.tar.gz: 90211a4df7b4ee70999ef223d07179b5618c99704c94b299c64e174788371be0
5
5
  SHA512:
6
- metadata.gz: 280bb413c66869065fe17710c15cb5f2c2ec0c88b38f4ddb839f10da62ca4e84328f57fccf755c341fd5ba8684d2495dd1c8ecf881270881ce295b011c1f9981
7
- data.tar.gz: 5499e767237ca7a9aeefe9a4767677f601a024958f2fe6e40537777f11a4ecac968227f4753a10872523499c62aac5def2153c44ec20ad823114c4fe243a0de8
6
+ metadata.gz: 2365ccc24f348c702c3c6fd5605af42db1f22e7d9b4ffbbd179b83f2fe673998f1745cff5a7536f95f7d064150c2c00fbfab9e253b116230744c21f0a5dfa571
7
+ data.tar.gz: 7d9ae6eeae803f450055262b02cfaaa839d4048a793b0eb72c912558887b708f054b2a047ef10ebe3d9efa022126db464ef1c50227843fd66a26647f900eba9d
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- seatsio (25.0.0)
4
+ seatsio (26.1.0)
5
5
 
6
6
  GEM
7
7
  remote: https://rubygems.org/
data/README.md CHANGED
@@ -40,7 +40,7 @@ client.events.release(event.key, ["A-1", "A-2"])
40
40
  ```ruby
41
41
  require('seatsio')
42
42
  client = Seatsio::Client.new("my-workspace-secret-key")
43
- client.events.book(event.key, ["A-1", "A-2"], "a-hold-token")
43
+ client.events.book(event.key, ["A-1", "A-2"], hold_token: "a-hold-token")
44
44
  ```
45
45
 
46
46
  ### Changing object status
@@ -24,6 +24,7 @@ module Seatsio::Domain
24
24
  @social_distancing_rulesets = data['socialDistancingRulesets'].map {
25
25
  |key, r| [key, SocialDistancingRuleset.new(r['name'], r['numberOfDisabledSeatsToTheSides'], r['disableSeatsInFrontAndBehind'],
26
26
  r['numberOfDisabledAisleSeats'], r['maxGroupSize'],
27
+ r['maxOccupancyAbsolute'], r['maxOccupancyPercentage'], r['oneGroupPerTable'], r['fixedGroupLayout'],
27
28
  r['disabledSeats'], r['enabledSeats'], r['index'])]
28
29
  }.to_h
29
30
  end
@@ -286,7 +287,7 @@ module Seatsio::Domain
286
287
  :category_key, :entrance, :object_type, :hold_token, :category_label,
287
288
  :ticket_type, :num_booked, :num_free, :num_held, :for_sale, :section,
288
289
  :is_accessible, :is_companion_seat, :has_restricted_view, :displayed_object_type,
289
- :left_neighbour, :right_neighbour, :is_selectable, :is_disabled_by_social_distancing
290
+ :left_neighbour, :right_neighbour, :is_selectable, :is_disabled_by_social_distancing, :channel
290
291
 
291
292
  def initialize(data)
292
293
  @status = data['status']
@@ -314,6 +315,7 @@ module Seatsio::Domain
314
315
  @right_neighbour = data['rightNeighbour']
315
316
  @is_selectable = data['isSelectable']
316
317
  @is_disabled_by_social_distancing = data['isDisabledBySocialDistancing']
318
+ @channel = data['channel']
317
319
  end
318
320
  end
319
321
 
@@ -473,31 +475,52 @@ module Seatsio::Domain
473
475
 
474
476
  class SocialDistancingRuleset
475
477
  attr_reader :name, :number_of_disabled_seats_to_the_sides, :disable_seats_in_front_and_behind,
476
- :number_of_disabled_aisle_seats, :max_group_size, :disabled_seats, :enabled_seats, :index
478
+ :number_of_disabled_aisle_seats, :max_group_size, :max_occupancy_absolute,
479
+ :max_occupancy_percentage, :one_group_per_table, :fixed_group_layout, :disabled_seats, :enabled_seats, :index
477
480
 
478
481
  def initialize(name, number_of_disabled_seats_to_the_sides = 0, disable_seats_in_front_and_behind = false, number_of_disabled_aisle_seats = 0,
479
- max_group_size = 0, disabled_seats = [], enabled_seats = [], index = 0)
482
+ max_group_size = 0, max_occupancy_absolute = 0, max_occupancy_percentage = 0, one_group_per_table = false,
483
+ fixed_group_layout = false, disabled_seats = [], enabled_seats = [], index = 0)
480
484
  @name = name
481
485
  @number_of_disabled_seats_to_the_sides = number_of_disabled_seats_to_the_sides
482
486
  @disable_seats_in_front_and_behind = disable_seats_in_front_and_behind
483
487
  @number_of_disabled_aisle_seats = number_of_disabled_aisle_seats
484
488
  @max_group_size = max_group_size
489
+ @max_occupancy_absolute = max_occupancy_absolute
490
+ @max_occupancy_percentage = max_occupancy_percentage
491
+ @one_group_per_table = one_group_per_table
492
+ @fixed_group_layout = fixed_group_layout
485
493
  @disabled_seats = disabled_seats
486
494
  @enabled_seats = enabled_seats
487
495
  @index = index
488
496
  end
489
497
 
498
+ def self.fixed(name, disabled_seats = [], index = 0)
499
+ SocialDistancingRuleset.new(name, 0, false, 0, 0, 0, 0, false, true, disabled_seats, [], index)
500
+ end
501
+
502
+ def self.rule_based(name, number_of_disabled_seats_to_the_sides = 0, disable_seats_in_front_and_behind = false, number_of_disabled_aisle_seats = 0,
503
+ max_group_size = 0, max_occupancy_absolute = 0, max_occupancy_percentage = 0, one_group_per_table = false,
504
+ disabled_seats = [], enabled_seats = [], index = 0)
505
+ SocialDistancingRuleset.new(name, number_of_disabled_seats_to_the_sides, disable_seats_in_front_and_behind, number_of_disabled_aisle_seats,
506
+ max_group_size, max_occupancy_absolute, max_occupancy_percentage,
507
+ one_group_per_table, false, disabled_seats, enabled_seats, index)
508
+ end
509
+
490
510
  def == (other)
491
511
  self.name == other.name &&
492
512
  self.number_of_disabled_seats_to_the_sides == other.number_of_disabled_seats_to_the_sides &&
493
513
  self.disable_seats_in_front_and_behind == other.disable_seats_in_front_and_behind &&
494
514
  self.number_of_disabled_aisle_seats == other.number_of_disabled_aisle_seats &&
495
515
  self.max_group_size == other.max_group_size &&
516
+ self.max_occupancy_absolute == other.max_occupancy_absolute &&
517
+ self.max_occupancy_percentage == other.max_occupancy_percentage &&
518
+ self.one_group_per_table == other.one_group_per_table &&
519
+ self.fixed_group_layout == other.fixed_group_layout &&
496
520
  self.disabled_seats == other.disabled_seats &&
497
521
  self.enabled_seats == other.enabled_seats &&
498
522
  self.index == other.index
499
523
  end
500
-
501
524
  end
502
525
 
503
526
  end
@@ -31,6 +31,10 @@ module Seatsio
31
31
  fetch_summary_report('bySelectability', event_key)
32
32
  end
33
33
 
34
+ def summary_by_channel(event_key)
35
+ fetch_summary_report('byChannel', event_key)
36
+ end
37
+
34
38
  def by_label(event_key, label = nil)
35
39
  fetch_report('byLabel', event_key, label)
36
40
  end
@@ -59,6 +63,10 @@ module Seatsio
59
63
  fetch_report('bySelectability', event_key, selectability)
60
64
  end
61
65
 
66
+ def by_channel(event_key, channelKey = nil)
67
+ fetch_report('byChannel', event_key, channelKey)
68
+ end
69
+
62
70
  private
63
71
 
64
72
  def fetch_summary_report(report_type, event_key)
@@ -76,18 +76,18 @@ module Seatsio
76
76
  change_object_status(event_key_or_keys, object_or_objects, Domain::ObjectStatus::HELD, hold_token: hold_token, order_id: order_id, keep_extra_data: keep_extra_data, ignore_channels: ignore_channels, channel_keys: channel_keys)
77
77
  end
78
78
 
79
- def change_best_available_object_status(key, number, status, categories: nil, hold_token: nil, extra_data: nil, order_id: nil, keep_extra_data: nil, ignore_channels: nil, channel_keys: nil)
80
- request = create_change_best_available_object_status_request(number, status, categories, extra_data, hold_token, order_id, keep_extra_data, ignore_channels, channel_keys)
79
+ def change_best_available_object_status(key, number, status, categories: nil, hold_token: nil, extra_data: nil, ticket_types: nil, order_id: nil, keep_extra_data: nil, ignore_channels: nil, channel_keys: nil)
80
+ request = create_change_best_available_object_status_request(number, status, categories, extra_data, ticket_types, hold_token, order_id, keep_extra_data, ignore_channels, channel_keys)
81
81
  response = @http_client.post("events/#{key}/actions/change-object-status", request)
82
82
  Domain::BestAvailableObjects.new(response)
83
83
  end
84
84
 
85
- def book_best_available(key, number, categories: nil, hold_token: nil, order_id: nil, keep_extra_data: nil, extra_data: nil, ignore_channels: nil, channel_keys: nil)
86
- change_best_available_object_status(key, number, Domain::ObjectStatus::BOOKED, categories: categories, hold_token: hold_token, order_id: order_id, keep_extra_data: keep_extra_data, extra_data: extra_data, ignore_channels: ignore_channels, channel_keys: channel_keys)
85
+ def book_best_available(key, number, categories: nil, hold_token: nil, order_id: nil, keep_extra_data: nil, extra_data: nil, ticket_types: nil, ignore_channels: nil, channel_keys: nil)
86
+ change_best_available_object_status(key, number, Domain::ObjectStatus::BOOKED, categories: categories, hold_token: hold_token, order_id: order_id, keep_extra_data: keep_extra_data, extra_data: extra_data, ticket_types: ticket_types, ignore_channels: ignore_channels, channel_keys: channel_keys)
87
87
  end
88
88
 
89
- def hold_best_available(key, number, hold_token, categories: nil, order_id: nil, keep_extra_data: nil, extra_data: nil, ignore_channels: nil, channel_keys: nil)
90
- change_best_available_object_status(key, number, Domain::ObjectStatus::HELD, categories: categories, hold_token: hold_token, order_id: order_id, keep_extra_data: keep_extra_data, extra_data: extra_data, ignore_channels: ignore_channels, channel_keys: channel_keys)
89
+ def hold_best_available(key, number, hold_token, categories: nil, order_id: nil, keep_extra_data: nil, extra_data: nil, ticket_types: nil, ignore_channels: nil, channel_keys: nil)
90
+ change_best_available_object_status(key, number, Domain::ObjectStatus::HELD, categories: categories, hold_token: hold_token, order_id: order_id, keep_extra_data: keep_extra_data, extra_data: extra_data, ticket_types: ticket_types, ignore_channels: ignore_channels, channel_keys: channel_keys)
91
91
  end
92
92
 
93
93
  def release(event_key_or_keys, object_or_objects, hold_token: nil, order_id: nil, keep_extra_data: nil, ignore_channels: nil, channel_keys: nil)
@@ -1,8 +1,9 @@
1
- def create_change_best_available_object_status_request(number, status, categories, extra_data, hold_token, order_id, keep_extra_data, ignore_channels, channel_keys)
1
+ def create_change_best_available_object_status_request(number, status, categories, extra_data, ticket_types, hold_token, order_id, keep_extra_data, ignore_channels, channel_keys)
2
2
  result = {}
3
3
  best_available = {'number': number}
4
4
  best_available[:categories] = categories if categories != nil
5
5
  best_available[:extraData] = extra_data if extra_data != nil
6
+ best_available[:ticketTypes] = ticket_types if ticket_types != nil
6
7
  result[:status] = status
7
8
  result[:bestAvailable] = best_available
8
9
  result[:holdToken] = hold_token if hold_token != nil
@@ -1,5 +1,5 @@
1
- def create_change_object_status_in_batch_request(event_key, object_or_objects, status, hold_token = nil , order_id = nil, keep_extra_data = nil)
2
- result = create_change_object_status_request(object_or_objects, status, hold_token, order_id, '', keep_extra_data)
1
+ def create_change_object_status_in_batch_request(event_key, object_or_objects, status, hold_token = nil , order_id = nil, keep_extra_data = nil, ignore_channels = nil, channel_keys = nil)
2
+ result = create_change_object_status_request(object_or_objects, status, hold_token, order_id, '', keep_extra_data, ignore_channels, channel_keys)
3
3
  result.delete(:events)
4
4
  result[:event] = event_key
5
5
  result
@@ -1,3 +1,3 @@
1
1
  module Seatsio
2
- VERSION = "25.0.0"
2
+ VERSION = "26.1.0"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: seatsio
3
3
  version: !ruby/object:Gem::Version
4
- version: 25.0.0
4
+ version: 26.1.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Seats.io
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2020-07-24 00:00:00.000000000 Z
11
+ date: 2020-10-19 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler