source: ruby/branches/0.5/lib/open_ehr/rm/support/identification.rb @ 259

Last change on this file since 259 was 259, checked in by KOBAYASHI, Shinji, 11 years ago

support/identification package moving from test/unit to rspec

File size: 9.4 KB
Line 
1# This module is an implementation of this UML:
2# http://www.openehr.org/uml/release-1.0.1/Browsable/_9_0_76d0249_1109331021343_528780_2066Report.html
3# Ticket refs #39
4module OpenEHR
5  module RM
6    module Support
7      module Identification
8        class ObjectID
9          attr_reader :value
10
11          def initialize(args = {})
12            self.value=args[:value]
13          end
14
15          def value=(value)
16            raise ArgumentError, "empty value" if value.nil? or value.empty?
17            @value = value           
18          end
19
20          def ==(object_id)
21            @value == object_id.value
22          end
23        end # of ObjectID
24
25        class ObjectRef
26          attr_reader :namespace, :type, :id
27
28          def initialize(namespace, type, id)
29            self.namespace = namespace
30            self.type = type
31            self.id = id
32          end
33
34          def namespace=(namespace)
35            raise ArgumentError if namespace.nil? or namespace.empty? or !(/([a-z]|[A-Z]).*/ =~ namespace) # error original is =~ #([a-z][A-Z])([a-z]|[A-Z]|\s|[v0-9]|[_-\:\/\&\+\?])*/
36            @namespace = namespace
37          end
38
39          def type=(type)
40            raise ArgumentError if type.nil? or type.empty?
41            @type = type
42          end
43
44          def id=(id)
45            raise ArgumentError if id.nil?
46            @id = id
47          end
48        end
49
50        class ArchetypeID < ObjectID
51          attr_reader :domain_concept, :rm_name, :rm_entity, :rm_originator, :specialisation, :version_id
52
53          def initialize(value, domain_concept, rm_name, rm_entity, rm_originator, specialisation, version_id)
54            super(value)
55            self.domain_concept = domain_concept
56            self.rm_name = rm_name
57            self.rm_entity = rm_entity
58            self.rm_originator = rm_originator
59            self.specialisation = specialisation
60            self.version_id = version_id
61          end
62
63          def domain_concept=(domain_concept)
64            raise ArgumentError, "domain concept not valid" if domain_concept.nil? or domain_concept.empty?
65            @domain_concept = domain_concept
66          end
67
68          def rm_name=(rm_name)
69            raise ArgumentError, "rm_name not valid" if rm_name.nil? or rm_name.empty?
70            @rm_name = rm_name
71          end
72
73          def rm_entity=(rm_entity)
74            raise ArgumentError, "rm_entity not valid" if rm_entity.nil? or rm_entity.empty?
75            @rm_entity = rm_entity
76          end
77
78          def rm_originator=(rm_originator)
79            raise ArgumentError, "rm_originator not valid" if rm_originator.nil? or rm_originator.empty?
80            @rm_originator = rm_originator
81          end
82
83          def specialisation=(specialisation)
84            raise ArgumentError, "rm_specialisation not valid" if specialisation.nil? or specialisation.empty?
85            @specialisation = specialisation
86          end
87          def version_id=(version_id)
88            raise ArgumentError, "version_id not valid" if version_id.nil? or version_id.empty?
89            @version_id = version_id
90          end
91        end
92
93        class TerminologyID < ObjectID
94          attr_reader :name, :version_id
95
96          def initialize(args = {})
97            super(args)
98          end
99
100          def value
101            if @version_id.empty?
102              @name
103            else
104              @name + '(' + @version_id + ')'
105            end 
106          end
107
108
109          def value=(value)
110            raise ArgumentError, "value not valid" if value.nil? or value.empty?
111            if /(.*)\((.*)\)$/ =~ value
112              @name = $1
113              @version_id = $2
114            else
115              @name = value
116              @version_id = ''
117            end
118            @value = value
119          end
120
121          def name=(name)
122            raise ArgumentError, "name not valid" if name.nil? or name.empty?
123            @name = name
124          end
125
126          def version_id=(version_id)
127            raise ArgumentError, "version_id not valid" if version_id.nil?
128            @version_id = version_id
129          end
130        end # of Terminology_ID
131
132        class GenericID < ObjectID
133          attr_reader :scheme
134
135          def initialize(value, scheme)
136            super(value)
137            self.scheme = scheme
138          end
139
140          def scheme=(scheme)
141            raise ArgumentError, "scheme not valid" if scheme.nil? or scheme.empty?
142            @scheme = scheme
143          end
144        end # of Generic_ID
145
146        class TemplateID < ObjectID
147
148        end
149
150        class UIDBasedID < ObjectID
151          def initialize(value)
152            super(value)
153          end
154
155          def extension
156            if self.has_extension?
157              @value[/::.*/][2..-1]
158            else
159              ''
160            end
161          end
162
163          def has_extension?
164            @value.include? '::'
165          end
166
167          def root
168            if self.has_extension?
169              @value[/.*::/][0..-3]
170            else
171              @value
172            end
173          end
174        end
175
176        class ObjectVersionID < UIDBasedID
177          attr_reader :object_id, :creating_system_id, :version_tree_id
178
179          def initialize(value)
180            super(value)
181          end
182
183          def value=(value)
184            super(value)
185            if /^(\w+)::(\w+)::((\d|\.)+)$/ =~ value
186              self.object_id = UID.new($1)
187              self.creating_system_id = UID.new($2)
188              self.version_tree_id = VersionTreeID.new($3)
189            else
190              raise ArgumentError, 'invalid format'
191            end
192          end
193
194          def object_id=(object_id)
195            raise ArgumentError, 'object_id is mandatory' if object_id.nil?
196            @object_id = object_id
197          end
198
199          def creating_system_id=(creating_system_id)
200            if creating_system_id.nil?
201              raise ArgumentError, 'creating_system_id is mandatory'
202            end
203            @creating_system_id = creating_system_id
204          end
205
206          def version_tree_id=(version_tree_id)
207            if version_tree_id.nil?
208              raise ArgumentError, 'version_tree_id is mandatory'
209            end
210            @version_tree_id = version_tree_id
211          end
212
213          def is_branch?
214            return @version_tree_id.is_branch?
215          end
216        end
217
218        class LocatableRef < ObjectRef
219          attr_reader :namespace, :type, :id, :path
220
221          def initialize(namespace, type, id, path)
222            super(namespace, type, id)
223            self.path = path
224          end
225
226          def path=(path)
227            raise ArgumentError if path.nil? or path.empty?
228            @path = path
229          end
230
231          def as_uri
232            'ehr://' + @id.value + '/' + @path
233          end
234        end
235
236        class PartyRef < ObjectRef
237
238          def type=(type)
239            parties = ['PERSON', 'ORGANISATION', 'GROUP', 'AGENT', 'ROLE','PARTY', 'ACTOR']
240            raise ArgumentError, 'type invalid' unless parties.include? type
241            @type = type
242          end
243        end
244
245        class AccessGroupRef < ObjectRef
246          def type=(type)
247            raise ArgumentError, 'type invalid' unless type == 'ACCESS_GROUP'
248            @type = type
249          end
250        end
251
252        class HierObjectID < UIDBasedID
253
254        end
255
256        class VersionTreeID
257          attr_reader :value, :trunk_version, :branch_number, :branch_version
258
259          def initialize(value)
260            self.value = value
261          end
262
263          def value=(value)
264            raise ArgumentError, 'value invalid' if value.nil? or value.empty?
265            @trunk_version = @branch_number = @branch_version = nil
266            (trunk_version, branch_number, branch_version) = value.split '.'
267            self.trunk_version = trunk_version
268            self.branch_number = branch_number
269            self.branch_version = branch_version
270          end
271
272          def trunk_version=(trunk_version)
273            raise ArgumentError, 'trunk_version invalid' if trunk_version.nil? and !trunk_version.to_i >= 1
274            @trunk_version = trunk_version
275            set_value
276          end
277
278          def branch_number=(branch_number)
279            raise ArgumentError, 'branch number invalid' unless branch_number.nil? or branch_number.to_i >= 1
280            @branch_number = branch_number
281            set_value
282          end
283
284          def branch_version=(branch_version)
285            raise ArgumentError, 'branch version invalid' if (!branch_version.nil? and !( branch_version.to_i >= 1)) or (!branch_version.nil? and @branch_number.nil?)
286            @branch_version = branch_version
287            set_value
288          end
289          def is_branch?
290            !@branch_version.nil? and !@branch_number.nil?
291          end
292
293          def is_first?
294            trunk_version == '1'
295          end
296
297          private
298          def set_value
299            @value = trunk_version
300            @value = @value + '.' + @branch_number unless @branch_number.nil?
301            @value = @value + '.' + @branch_version unless @branch_version.nil?
302          end
303        end
304
305        class UID
306          attr_reader :value
307
308          def initialize(value)
309            self.value = value
310          end
311
312          def value=(value)
313            raise ArgumentError if value.nil? or value.empty?
314            @value = value
315          end
316        end
317
318        class UUID < UID
319
320        end
321
322        class InternetID <UID
323         
324        end
325
326        class IsoOID <UID
327
328        end       
329      end # of Identification
330    end # of Support
331  end # of RM
332end # of OpenEHR
Note: See TracBrowser for help on using the repository browser.