centaman 5.0.5 → 5.0.6

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: 3859d3bdf6f59b7de33fefac98a2d5dedc65d0493aca8353a2a87b0c5a740ea8
4
- data.tar.gz: 02f33057ced046dab323ae8db5464d8497e351dc2a3fa95027b672489fb3b46d
3
+ metadata.gz: d4c875300722d1b1c5a2c741eb6fc5e137ddb1947d01bcf855b05953b9feeba4
4
+ data.tar.gz: 0753fb84fbe45dc6478fea4c00d8ae7eb7d7075e229e130601582da42d6bd698
5
5
  SHA512:
6
- metadata.gz: 7e6a7d09e3a37f41e530a5eb06a7f38648ae219cabbe4e4b971e1b71b0e8e7ac29aa288499cb9dbcef5a23375ef90192a74bc6b951c52f3b5bc2e3b49b882cdc
7
- data.tar.gz: d0ca8e4ede5f338f30b8e2f1b816fda40070a3078cb24ddb38b12b0973c5f08f22f83ff1d1741c77eae0a6ccb1aeddbfaf4f3c8803a171850b067428b7e6a148
6
+ metadata.gz: e8da370a1b01e0b6e4ec0083b3c6b82a9bb652c9caf37ab144a26c8bdadb3cbdac1e9599620c20950efa099cade004733ffd6587d87bff282098cb76d2aae445
7
+ data.tar.gz: 152a98997a4bd30106cab924ec6528589db5e330ca8705f567da6597438c665729a4bc2246dc6063e07e34441bd577df8267860828538cccce7b36aee4365d01
@@ -12,6 +12,7 @@ require 'centaman/service/authenticate_member'
12
12
  require 'centaman/service/booking_time'
13
13
  require 'centaman/service/booking_type'
14
14
  require 'centaman/service/capacity'
15
+ require 'centaman/service/cost_rate'
15
16
  require 'centaman/service/coupon_check'
16
17
  require 'centaman/service/create_customer'
17
18
  require 'centaman/service/create_primary_member'
@@ -30,6 +31,7 @@ require 'centaman/service/ticket_type'
30
31
  require 'centaman/object/booking_time'
31
32
  require 'centaman/object/booking_type'
32
33
  require 'centaman/object/capacity'
34
+ require 'centaman/object/cost_rate'
33
35
  require 'centaman/object/coupon_check'
34
36
  require 'centaman/object/customer'
35
37
  require 'centaman/object/effect'
@@ -44,7 +46,7 @@ require 'centaman/object/ticket_type'
44
46
  require 'centaman/configuration'
45
47
 
46
48
  module Centaman
47
- class << self
49
+ class << self
48
50
  def configuration
49
51
  @config ||= Centaman::Configuration.new
50
52
  end
@@ -0,0 +1,33 @@
1
+ module Centaman
2
+ class Object::CostRate < Centaman::Object
3
+ def attributes
4
+ [
5
+ Centaman::Attribute.new(
6
+ centaman_key: 'FirstName',
7
+ app_key: :first_name,
8
+ type: :string
9
+ ),
10
+ Centaman::Attribute.new(
11
+ centaman_key: 'LastName',
12
+ app_key: :last_name,
13
+ type: :string
14
+ ),
15
+ Centaman::Attribute.new(
16
+ centaman_key: 'Email',
17
+ app_key: :email,
18
+ type: :string
19
+ ),
20
+ Centaman::Attribute.new(
21
+ centaman_key: 'ContactID',
22
+ app_key: :contact_id,
23
+ type: :integer
24
+ ),
25
+ Centaman::Attribute.new(
26
+ centaman_key: 'ContactCostRateID',
27
+ app_key: :cost_rate_id,
28
+ type: :integer
29
+ )
30
+ ]
31
+ end
32
+ end
33
+ end
@@ -22,7 +22,7 @@ module Centaman
22
22
  def build_object(resp)
23
23
  return build_objects(resp) if resp.respond_to?(:map)
24
24
 
25
- return auth_error(resp) unless resp.respond_to?(:merge)
25
+ return auth_error unless resp.respond_to?(:merge)
26
26
  @build_object ||= object_class.new(resp.merge(additional_hash_to_serialize_after_response))
27
27
  end
28
28
 
@@ -37,9 +37,8 @@ module Centaman
37
37
 
38
38
  private
39
39
 
40
- def auth_error(resp)
41
- message = { error: 'Invalid authentication request. Card/Member Number and Lastname not found .' }
42
- raise message[:error]
40
+ def auth_error
41
+ raise 'Invalid authentication request. Card/Member Number and Lastname not found.'
43
42
  end
44
43
  end
45
44
  end
@@ -0,0 +1,37 @@
1
+ module Centaman
2
+ class Service::CostRate < Centaman::Service
3
+ include Centaman::JsonWrapper
4
+ attr_reader :first_name, :last_name, :email, :primary_member_id
5
+
6
+ def after_init(args={})
7
+ @first_name = args.fetch(:first_name, nil)
8
+ @last_name = args.fetch(:last_name, nil)
9
+ @email = args.fetch(:email, nil)
10
+ @primary_member_id = args.fetch(:primary_member_id, nil)
11
+ end
12
+
13
+ def object_class
14
+ Centaman::Object::CostRate
15
+ end
16
+
17
+ def endpoint
18
+ '/ticket_services/TimedTicket'
19
+ end
20
+
21
+ def options
22
+ super + [
23
+ { key: 'FirstName', value: first_name },
24
+ { key: 'LastName', value: last_name },
25
+ { key: 'Email', value: email }
26
+ ]
27
+ end
28
+
29
+ def build_objects(resp)
30
+ return [] unless resp.respond_to?(:map)
31
+ return build_object(resp) if resp.respond_to?(:merge)
32
+ @tickets = resp.map do |ticket_hash|
33
+ object_class.new(ticket_hash.merge(additional_hash_to_serialize_after_response))
34
+ end
35
+ end
36
+ end
37
+ end
@@ -1,3 +1,3 @@
1
1
  module Centaman
2
- VERSION = "5.0.5"
2
+ VERSION = "5.0.6"
3
3
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: centaman
3
3
  version: !ruby/object:Gem::Version
4
- version: 5.0.5
4
+ version: 5.0.6
5
5
  platform: ruby
6
6
  authors:
7
7
  - francirp
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: exe
11
11
  cert_chain: []
12
- date: 2018-06-20 00:00:00.000000000 Z
12
+ date: 2018-07-19 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: bundler
@@ -97,6 +97,7 @@ files:
97
97
  - lib/centaman/object/booking_time.rb
98
98
  - lib/centaman/object/booking_type.rb
99
99
  - lib/centaman/object/capacity.rb
100
+ - lib/centaman/object/cost_rate.rb
100
101
  - lib/centaman/object/coupon_check.rb
101
102
  - lib/centaman/object/customer.rb
102
103
  - lib/centaman/object/effect.rb
@@ -113,6 +114,7 @@ files:
113
114
  - lib/centaman/service/booking_time.rb
114
115
  - lib/centaman/service/booking_type.rb
115
116
  - lib/centaman/service/capacity.rb
117
+ - lib/centaman/service/cost_rate.rb
116
118
  - lib/centaman/service/coupon_check.rb
117
119
  - lib/centaman/service/create_customer.rb
118
120
  - lib/centaman/service/create_primary_member.rb