redox 1.3.1 → 1.6.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: 740cc0762bcf54c65c0767f1e6254aa304a193b493babdd5993859866911a7c2
4
- data.tar.gz: df1e7871ffde6efcd565255ea17ad05a5940fa951879e30db4e152c9c78679ae
3
+ metadata.gz: f210f0ebbfb69117dba40de048d175729ba402cd3407f25f2d9fcf2cdf190bf2
4
+ data.tar.gz: 1e4242fa34e80ab3e0cd786e2217f438f45f5d13a7e8450848b0dfc0cfdb0acc
5
5
  SHA512:
6
- metadata.gz: f49cff5f2b525ff29499104f008ca393d1676d8a0963fad72154f8a8bfd0cd807fafc9017606d7d3d45c4ed81e8598d06843096b731699f972ed3143e147ad37
7
- data.tar.gz: 3dd1d039480dc5573df999aa9f74f44e6a63acef237dc8257e4bdc22f073033d75b7be6b1d9617e26dcbac22e8f6d199f5d995e019bd73e3c866cde98c9acd62
6
+ metadata.gz: ca76e75a695a38e45d0557b1b3fcb8bcd54a7f6d9128439c64a858dcce8e7beda569c454dbd366af1edc6fa8e05b81f606f6b3f4ffc548427ebef5acd350a6d1
7
+ data.tar.gz: 44e2bd01702cbbb8f035faa933d54ac6bbc2583400adfba2f466649cb0a368cb256ac31f7460a68a61d8026e8547d76d8a757d17752a7526b26957eab2ffb46e
data/CHANGELOG.md CHANGED
@@ -4,18 +4,57 @@ All notable changes to this project will be documented in this file.
4
4
  The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/)
5
5
  and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).
6
6
 
7
+ ## [1.6.0] - 2021-02-04
8
+ ### Added
9
+ - Media model
10
+ - MediaUpdate Model
11
+ - Media#create
12
+ - Visit#CancelReason
13
+ - Visit#DischargeDateTime
14
+
15
+ ## [1.5.2] - 2021-01-08
16
+ ### Added
17
+ - Visit#Type
18
+ - Visit#Status
19
+ - Visit#Reason
20
+ - Visit#Equipment
21
+
22
+ ## [1.5.1] - 2020-12-22
23
+ ### Added
24
+ - Contacts model
25
+ - Patient#contacts
26
+
27
+ ### Changed
28
+ - typo of martialstatus is now maritalstatus for Demographics model
29
+
30
+ ## [1.5.0] - 2020-12-15
31
+ ### Added
32
+ - Scheduling model
33
+ - Scheduling#create
34
+ - Scheduling#cancel
35
+ - Scheduling#reschedule
36
+ - Scheduling#modification
37
+
38
+ ## [1.4.0] - 2020-10-13
39
+ ### Added
40
+ - AbstractModel that does not add top level key
41
+ - OrderingProvider that is the base for PCP
42
+ - Provider model
43
+ - Provider#query
44
+ - Created new method that can add helpers dynamically from response
45
+
7
46
  ## [1.3.1] - 2020-10-02
8
47
  ### Added
9
48
  - Transaction#as\_json
10
49
  - Visit#as\_json
11
50
 
12
51
  ## [1.3.0] - 2020-09-17
13
- ### Added
52
+ ### Added
14
53
  - Transaction model
15
54
  - Financial#create
16
55
 
17
56
  ## [1.2.0] - 2020-07-30
18
- ### Added
57
+ ### Added
19
58
  - Visit model
20
59
  - Model#insurances helper for Patient.Insurances || Visit.Insurances
21
60
 
@@ -28,7 +67,6 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.
28
67
  - Moving to Requst classes instead of mixing in logic to models (kept backwards compatibility)
29
68
  - Added potential matches to responses and implemented for patient search
30
69
 
31
- =======
32
70
  ### Added
33
71
  - PotentialMatches class
34
72
 
@@ -113,6 +151,10 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.
113
151
  ### Added
114
152
  - Initial Release
115
153
 
154
+ [1.5.2]: https://github.com/WeInfuse/redox/compare/v1.5.1...v1.5.2
155
+ [1.5.1]: https://github.com/WeInfuse/redox/compare/v1.5.0...v1.5.1
156
+ [1.5.0]: https://github.com/WeInfuse/redox/compare/v1.4.0...v1.5.0
157
+ [1.4.0]: https://github.com/WeInfuse/redox/compare/v1.3.1...v1.4.0
116
158
  [1.3.1]: https://github.com/WeInfuse/redox/compare/v1.3.0...v1.3.1
117
159
  [1.3.0]: https://github.com/WeInfuse/redox/compare/v1.2.0...v1.3.0
118
160
  [1.2.0]: https://github.com/WeInfuse/redox/compare/v1.1.1...v1.2.0
data/lib/redox.rb CHANGED
@@ -6,19 +6,28 @@ require 'redox/connection'
6
6
  require 'redox/authentication'
7
7
  require 'redox/models/model'
8
8
  require 'redox/models/meta'
9
+ require 'redox/models/ordering_provider'
9
10
  require 'redox/models/patient'
11
+ require 'redox/models/provider'
10
12
  require 'redox/models/visit'
11
13
  require 'redox/models/transaction'
12
14
  require 'redox/models/financial'
15
+ require 'redox/models/media'
16
+ require 'redox/models/media_upload'
13
17
  require 'redox/models/patient/demographics'
18
+ require 'redox/models/patient/contacts'
14
19
  require 'redox/models/patient/identifier'
15
20
  require 'redox/models/patient/insurance'
16
21
  require 'redox/models/patient/p_c_p'
17
22
  require 'redox/models/potential_matches'
23
+ require 'redox/models/scheduling'
18
24
  require 'redox/request/request'
19
25
  require 'redox/request/financial'
20
26
  require 'redox/request/patient_admin'
21
27
  require 'redox/request/patient_search'
28
+ require 'redox/request/provider'
29
+ require 'redox/request/scheduling'
30
+ require 'redox/request/media'
22
31
 
23
32
  module Redox
24
33
  class Configuration
@@ -1,9 +1,6 @@
1
1
  module Redox
2
2
  module Models
3
- class Financial < Hashie::Trash
4
- include Hashie::Extensions::IgnoreUndeclared
5
- include Hashie::Extensions::IndifferentAccess
6
-
3
+ class Financial < AbstractModel
7
4
  property :Visit, required: false, from: :visit, default: Redox::Models::Visit.new
8
5
  property :Patient, required: false, from: :patient, default: Redox::Models::Patient.new
9
6
  property :Transactions, required: false, from: :transactions, default: []
@@ -0,0 +1,19 @@
1
+ module Redox
2
+ module Models
3
+ class Media < AbstractModel
4
+ property :FileType, from: :file_type, required: false
5
+ property :FileName, from: :file_name, required: false
6
+ property :FileContents, from: :file_contents, required: false
7
+ property :DocumentType, from: :document_type, required: false
8
+ property :DocumentID, from: :document_id, required: false
9
+ property :Availability, from: :availability, required: false
10
+
11
+ alias_method :file_type, :FileType
12
+ alias_method :file_name, :FileName
13
+ alias_method :file_contents, :FileContents
14
+ alias_method :document_type, :DocumentType
15
+ alias_method :document_id, :DocumentID
16
+ alias_method :availability, :Availability
17
+ end
18
+ end
19
+ end
@@ -0,0 +1,13 @@
1
+ module Redox
2
+ module Models
3
+ class MediaUpload < AbstractModel
4
+ property :Patient, required: false, from: :patient, default: Redox::Models::Patient.new
5
+ property :Visit, required: false, from: :visit, default: Redox::Models::Visit.new
6
+ property :Media, required: false, from: :media, default: Redox::Models::Media.new
7
+
8
+ alias_method :patient, :Patient
9
+ alias_method :visit, :Visit
10
+ alias_method :media, :Media
11
+ end
12
+ end
13
+ end
@@ -8,10 +8,12 @@ module Redox
8
8
  end
9
9
  end
10
10
 
11
- class Model < Hashie::Trash
11
+ class AbstractModel < Hashie::Trash
12
12
  include Hashie::Extensions::IgnoreUndeclared
13
13
  include Hashie::Extensions::IndifferentAccess
14
14
 
15
+ HIGH_LEVEL_KEYS = %w[Meta Patient Visit PotentialMatches]
16
+
15
17
  property :Meta, from: :meta, required: false
16
18
  property :Patient, from: :patient, required: false
17
19
  property :Visit, from: :visit, required: false
@@ -24,6 +26,70 @@ module Redox
24
26
  alias_method :visit, :Visit
25
27
  alias_method :meta, :Meta
26
28
 
29
+ def to_json(args = {})
30
+ return self.to_h.to_json
31
+ end
32
+
33
+ def insurances
34
+ (self.patient&.insurances || []) + (self.visit&.insurances || [])
35
+ end
36
+
37
+ def self.from_response(response)
38
+ model = Model.new
39
+ model.response = response
40
+
41
+ HIGH_LEVEL_KEYS.each do |k|
42
+ begin
43
+ model.send("#{k}=", Module.const_get("Redox::Models::#{k}").new(response[k])) if response[k]
44
+ rescue
45
+ end
46
+ end
47
+
48
+ return model
49
+ end
50
+
51
+ def self.from_response_inflected(response)
52
+ model = self.from_response(response)
53
+
54
+ if (model.response.ok?)
55
+ data = model.response.parsed_response
56
+
57
+ if data.respond_to?(:keys)
58
+ model_class = nil
59
+
60
+ if model.meta&.data_model
61
+ model_class = "Redox::Models::#{model.meta.data_model}"
62
+
63
+ begin
64
+ model_class = Object.const_get(model_class)
65
+ rescue NameError
66
+ model_class = nil
67
+ end
68
+ end
69
+
70
+ data.keys.each do |key|
71
+ next if HIGH_LEVEL_KEYS.include?(key.to_s)
72
+
73
+ helper_name = key.to_s.downcase.to_sym
74
+
75
+ if model_class.nil?
76
+ model.define_singleton_method(helper_name) { data[key] }
77
+ else
78
+ if data[key].is_a?(Array)
79
+ model.define_singleton_method(helper_name) { data[key].map {|obj| model_class.new(obj) } }
80
+ else
81
+ model.define_singleton_method(helper_name) { model_class.new(data[key]) }
82
+ end
83
+ end
84
+ end
85
+ end
86
+ end
87
+
88
+ return model
89
+ end
90
+ end
91
+
92
+ class Model < AbstractModel
27
93
  def initialize(data = {})
28
94
  if data.is_a?(Hash)
29
95
  if data.include?(key)
@@ -40,32 +106,7 @@ module Redox
40
106
  return { key => super.to_h }
41
107
  end
42
108
 
43
- def to_json(args = {})
44
- return self.to_h.to_json
45
- end
46
-
47
- def insurances
48
- (self.patient&.insurances || []) + (self.visit&.insurances || [])
49
- end
50
-
51
- class << self
52
- def from_response(response)
53
- model = Model.new
54
- model.response = response
55
-
56
- %w[Meta Patient Visit PotentialMatches].each do |k|
57
- begin
58
- model.send("#{k}=", Module.const_get("Redox::Models::#{k}").new(response[k])) if response[k]
59
- rescue
60
- end
61
- end
62
-
63
- return model
64
- end
65
- end
66
-
67
109
  private
68
-
69
110
  def key
70
111
  return self.class.to_s.split('::').last.to_s
71
112
  end
@@ -0,0 +1,15 @@
1
+ module Redox
2
+ module Models
3
+ class OrderingProvider < AbstractModel
4
+ property :ID, required: false, from: :id
5
+ property :IDType, required: false, from: :id_type
6
+ property :FirstName, required: false, from: :first_name
7
+ property :LastName, required: false, from: :last_name
8
+
9
+ alias_method :first_name, :FirstName
10
+ alias_method :last_name, :LastName
11
+ alias_method :id, :ID
12
+ alias_method :id_type, :IDType
13
+ end
14
+ end
15
+ end
@@ -4,10 +4,12 @@ module Redox
4
4
  property :Identifiers, from: :identifiers, required: false, default: []
5
5
  property :Insurances, from: :insurances, required: false, default: []
6
6
  property :Demographics, from: :demographics, required: false
7
+ property :Contacts, from: :contacts, required: false, default: []
7
8
  property :PCP, from: :primary_care_provider, required: false
8
9
 
9
10
  alias_method :identifiers, :Identifiers
10
11
  alias_method :insurances, :Insurances
12
+ alias_method :contacts, :Contacts
11
13
 
12
14
  def demographics
13
15
  self[:Demographics] = Demographics.new(self[:Demographics]) unless self[:Demographics].is_a?(Redox::Models::Demographics)
@@ -22,6 +24,10 @@ module Redox
22
24
  self[:PCP] ||= PCP.new
23
25
  end
24
26
 
27
+ def contacts
28
+ self[:Contacts] = self[:Contacts].map {|contact| contact.is_a?(Redox::Models::Contact) ? contact : Contact.new(contact)}
29
+ end
30
+
25
31
  def add_identifier(type: , value: )
26
32
  self[:Identifiers] << Identifier.new({'ID' => value, 'IDType' => type})
27
33
 
@@ -0,0 +1,20 @@
1
+ module Redox
2
+ module Models
3
+ class Contact < AbstractModel
4
+ property :FirstName, required: false, from: :first_name
5
+ property :MiddleName, required: false, from: :middle_name
6
+ property :LastName, required: false, from: :last_name
7
+ property :RelationToPatient, required: false
8
+ property :EmailAddresses, required: false, default: []
9
+ property :Address, required: false, default: {}
10
+ property :PhoneNumber, required: false, default: {}
11
+ property :Roles, required: false, default: []
12
+
13
+ alias_method :first_name, :FirstName
14
+ alias_method :middle_name, :MiddleName
15
+ alias_method :last_name, :LastName
16
+ alias_method :address, :Address
17
+ alias_method :phone_number, :PhoneNumber
18
+ end
19
+ end
20
+ end
@@ -1,6 +1,6 @@
1
1
  module Redox
2
2
  module Models
3
- class Demographics < Model
3
+ class Demographics < AbstractModel
4
4
  property :FirstName, required: false, from: :first_name
5
5
  property :MiddleName, required: false, from: :middle_name
6
6
  property :LastName, required: false, from: :last_name
@@ -9,7 +9,7 @@ module Redox
9
9
  property :Sex, required: false, from: :sex
10
10
  property :Race, required: false, from: :race
11
11
  property :IsHispanic, required: false
12
- property :MaritalStatus, required: false, from: :martial_status
12
+ property :MaritalStatus, required: false, from: :marital_status
13
13
  property :IsDeceased, required: false
14
14
  property :DeathDateTime, required: false
15
15
  property :Language, required: false, from: :language
@@ -25,7 +25,7 @@ module Redox
25
25
  alias_method :ssn, :SSN
26
26
  alias_method :sex, :Sex
27
27
  alias_method :race, :Race
28
- alias_method :martial_status, :MaritalStatus
28
+ alias_method :marital_status, :MaritalStatus
29
29
  alias_method :language, :Language
30
30
  alias_method :address, :Address
31
31
  alias_method :phone_number, :PhoneNumber
@@ -1,6 +1,6 @@
1
1
  module Redox
2
2
  module Models
3
- class Identifier < Model
3
+ class Identifier < AbstractModel
4
4
  property :ID, from: :id
5
5
  property :IDType, from: :id_type
6
6
 
@@ -1,13 +1,9 @@
1
1
  module Redox
2
2
  module Models
3
- class PCP < Model
3
+ class PCP < OrderingProvider
4
4
  property :NPI, from: :npi
5
- property :FirstName, required: false, from: :first_name
6
- property :LastName, required: false, from: :last_name
7
5
 
8
6
  alias_method :npi, :NPI
9
- alias_method :first_name, :FirstName
10
- alias_method :last_name, :LastName
11
7
  end
12
8
  end
13
9
  end
@@ -0,0 +1,21 @@
1
+ module Redox
2
+ module Models
3
+ class Provider < Model
4
+ property :Identifiers, from: :identifiers, required: false, default: []
5
+ property :Demographics, from: :demographics, required: false
6
+
7
+ alias_method :identifiers, :Identifiers
8
+
9
+ def demographics
10
+ self[:Demographics] = Demographics.new(self[:Demographics]) unless self[:Demographics].is_a?(Redox::Models::Demographics)
11
+ self[:Demographics] ||= Demographics.new
12
+ end
13
+
14
+ def add_identifier(type: , value: )
15
+ self[:Identifiers] << Identifier.new({'ID' => value, 'IDType' => type})
16
+
17
+ return self
18
+ end
19
+ end
20
+ end
21
+ end
@@ -0,0 +1,24 @@
1
+ module Redox
2
+ module Models
3
+ class Scheduling < AbstractModel
4
+ property :Visit, required: false, from: :visit, default: Redox::Models::Visit.new
5
+ property :Patient, required: false, from: :patient, default: Redox::Models::Patient.new
6
+ property :AppointmentInfo, required: false, from: :appointment_info, default: []
7
+
8
+ alias_method :patient, :Patient
9
+ alias_method :visit, :Visit
10
+ alias_method :appointment_info, :AppointmentInfo
11
+
12
+ def add_appointment_info(code: nil, codeset: nil, description: nil, value: nil)
13
+ self[:AppointmentInfo] << {
14
+ Code: code,
15
+ Codeset: codeset,
16
+ Description: description,
17
+ Value: value
18
+ }
19
+
20
+ self
21
+ end
22
+ end
23
+ end
24
+ end
@@ -1,9 +1,6 @@
1
1
  module Redox
2
2
  module Models
3
- class Transaction < Hashie::Trash
4
- include Hashie::Extensions::IgnoreUndeclared
5
- include Hashie::Extensions::IndifferentAccess
6
-
3
+ class Transaction < AbstractModel
7
4
  property :Chargeable, required: false, from: :chargeable, default: {}
8
5
  property :DateTimeOfService, required: false, from: :start
9
6
  property :Department, required: false, from: :department, default: {}
@@ -48,6 +45,18 @@ module Redox
48
45
  self
49
46
  end
50
47
 
48
+ def add_ordering_provider(**kwargs)
49
+ self[:OrderingProviders] ||= []
50
+ self[:OrderingProviders] << OrderingProvider.new(kwargs)
51
+ self
52
+ end
53
+
54
+ def add_performer(**kwargs)
55
+ self[:Performers] ||= []
56
+ self[:Performers] << OrderingProvider.new(kwargs)
57
+ self
58
+ end
59
+
51
60
  def to_h
52
61
  result = super.to_h
53
62
 
@@ -9,11 +9,19 @@ module Redox
9
9
  property :Insurances, from: :insurances, required: false, default: []
10
10
  property :Location, from: :location, required: false, default: DEFAULT_LOCATION
11
11
  property :VisitDateTime, from: :start, required: false
12
+ property :Duration, from: :duration, required: false
12
13
  property :VisitNumber, from: :visit_number, required: false
13
14
  property :AccountNumber, from: :account_number, required: false
15
+ property :Status, from: :status, required: false
16
+ property :Type, from: :type, required: false
17
+ property :Reason, from: :reason, required: false
18
+ property :Equipment, from: :equipment, required: false
19
+ property :CancelReason, from: :cancel_reason, required: false
20
+ property :DischargeDateTime, from: :end, required: false
14
21
 
15
22
  alias_method :insurances, :Insurances
16
23
  alias_method :start, :VisitDateTime
24
+ alias_method :end, :DischargeDateTime
17
25
 
18
26
  def department=(v)
19
27
  self[:Location] ||= DEFAULT_LOCATION
@@ -27,6 +35,12 @@ module Redox
27
35
  self
28
36
  end
29
37
 
38
+ def add_equipment(description: nil, code: nil)
39
+ self[:Equipment] ||= []
40
+ self[:Equipment] << { Description: description, Code: code }
41
+ self
42
+ end
43
+
30
44
  def insurances
31
45
  self[:Insurances] = self[:Insurances].map {|ins| ins.is_a?(Redox::Models::Insurance) ? ins : Insurance.new(ins) }
32
46
  end
@@ -34,7 +48,7 @@ module Redox
34
48
  def to_h
35
49
  result = super.to_h
36
50
 
37
- %w[VisitDateTime].each do |k|
51
+ %w[VisitDateTime DischargeDateTime].each do |k|
38
52
  result[key][k] = Redox::Models.format_datetime(result[key][k])
39
53
  end
40
54
 
@@ -0,0 +1,12 @@
1
+ module Redox
2
+ module Request
3
+ class Media
4
+ CREATE_META = Redox::Models::Meta.new(EventType: 'New', DataModel: 'Media')
5
+
6
+ def self.create(model, meta: Redox::Models::Meta.new)
7
+ meta = CREATE_META.merge(meta)
8
+ return Redox::Models::Model.from_response((RedoxClient.connection.request(body: Redox::Request.build_body(model, meta))))
9
+ end
10
+ end
11
+ end
12
+ end
@@ -0,0 +1,12 @@
1
+ module Redox
2
+ module Request
3
+ class Provider
4
+ QUERY_META = Redox::Models::Meta.new(EventType: 'ProviderQuery', DataModel: 'Provider')
5
+
6
+ def self.query(provider, meta: Redox::Models::Meta.new)
7
+ meta = QUERY_META.merge(meta)
8
+ return Redox::Models::Model.from_response_inflected((RedoxClient.connection.request(body: Redox::Request.build_body(provider, meta))))
9
+ end
10
+ end
11
+ end
12
+ end
@@ -0,0 +1,30 @@
1
+ module Redox
2
+ module Request
3
+ class Scheduling
4
+ CREATE_META = Redox::Models::Meta.new(EventType: 'New', DataModel: 'Scheduling')
5
+ CANCEL_META = Redox::Models::Meta.new(EventType: 'Cancel', DataModel: 'Scheduling')
6
+ RESCHEDULE_META = Redox::Models::Meta.new(EventType: 'Reschedule', DataModel: 'Scheduling')
7
+ MODIFICATION_META = Redox::Models::Meta.new(EventType: 'Modification', DataModel: 'Scheduling')
8
+
9
+ def self.create(model, meta: Redox::Models::Meta.new)
10
+ meta = CREATE_META.merge(meta)
11
+ return Redox::Models::Model.from_response((RedoxClient.connection.request(body: Redox::Request.build_body(model, meta))))
12
+ end
13
+
14
+ def self.cancel(model, meta: Redox::Models::Meta.new)
15
+ meta = CANCEL_META.merge(meta)
16
+ return Redox::Models::Model.from_response((RedoxClient.connection.request(body: Redox::Request.build_body(model, meta))))
17
+ end
18
+
19
+ def self.reschedule(model, meta: Redox::Models::Meta.new)
20
+ meta = RESCHEDULE_META.merge(meta)
21
+ return Redox::Models::Model.from_response((RedoxClient.connection.request(body: Redox::Request.build_body(model, meta))))
22
+ end
23
+
24
+ def self.modification(model, meta: Redox::Models::Meta.new)
25
+ meta = MODIFICATION_META.merge(meta)
26
+ return Redox::Models::Model.from_response((RedoxClient.connection.request(body: Redox::Request.build_body(model, meta))))
27
+ end
28
+ end
29
+ end
30
+ end
data/lib/redox/version.rb CHANGED
@@ -1,3 +1,3 @@
1
1
  module Redox
2
- VERSION = '1.3.1'.freeze
2
+ VERSION = '1.6.0'.freeze
3
3
  end
metadata CHANGED
@@ -1,16 +1,16 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: redox
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.3.1
4
+ version: 1.6.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Alexander Clark
8
8
  - Mike Crockett
9
9
  - Mike Carr
10
- autorequire:
10
+ autorequire:
11
11
  bindir: exe
12
12
  cert_chain: []
13
- date: 2020-10-02 00:00:00.000000000 Z
13
+ date: 2021-02-04 00:00:00.000000000 Z
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
16
16
  name: httparty
@@ -130,7 +130,7 @@ dependencies:
130
130
  - - "~>"
131
131
  - !ruby/object:Gem::Version
132
132
  version: '0.9'
133
- description:
133
+ description:
134
134
  email:
135
135
  - alexander.clark@weinfuse.com
136
136
  - mike.crockett@weinfuse.com
@@ -148,21 +148,30 @@ files:
148
148
  - lib/redox/authentication.rb
149
149
  - lib/redox/connection.rb
150
150
  - lib/redox/models/financial.rb
151
+ - lib/redox/models/media.rb
152
+ - lib/redox/models/media_upload.rb
151
153
  - lib/redox/models/meta.rb
152
154
  - lib/redox/models/model.rb
155
+ - lib/redox/models/ordering_provider.rb
153
156
  - lib/redox/models/patient.rb
157
+ - lib/redox/models/patient/contacts.rb
154
158
  - lib/redox/models/patient/demographics.rb
155
159
  - lib/redox/models/patient/identifier.rb
156
160
  - lib/redox/models/patient/insurance.rb
157
161
  - lib/redox/models/patient/p_c_p.rb
158
162
  - lib/redox/models/potential_matches.rb
163
+ - lib/redox/models/provider.rb
164
+ - lib/redox/models/scheduling.rb
159
165
  - lib/redox/models/transaction.rb
160
166
  - lib/redox/models/visit.rb
161
167
  - lib/redox/redox_exception.rb
162
168
  - lib/redox/request/financial.rb
169
+ - lib/redox/request/media.rb
163
170
  - lib/redox/request/patient_admin.rb
164
171
  - lib/redox/request/patient_search.rb
172
+ - lib/redox/request/provider.rb
165
173
  - lib/redox/request/request.rb
174
+ - lib/redox/request/scheduling.rb
166
175
  - lib/redox/version.rb
167
176
  - redox.gemspec
168
177
  homepage: https://github.com/WeInfuse/redox
@@ -170,7 +179,7 @@ licenses:
170
179
  - MIT
171
180
  metadata:
172
181
  allowed_push_host: https://rubygems.org
173
- post_install_message:
182
+ post_install_message:
174
183
  rdoc_options: []
175
184
  require_paths:
176
185
  - lib
@@ -185,9 +194,9 @@ required_rubygems_version: !ruby/object:Gem::Requirement
185
194
  - !ruby/object:Gem::Version
186
195
  version: '0'
187
196
  requirements: []
188
- rubyforge_project:
197
+ rubyforge_project:
189
198
  rubygems_version: 2.7.6
190
- signing_key:
199
+ signing_key:
191
200
  specification_version: 4
192
201
  summary: Ruby wrapper for the Redox Engine API
193
202
  test_files: []