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

Last change on this file since 274 was 274, checked in by KOBAYASHI, Shinji, 15 years ago

version_tree_id changed test/unit to rspec

File size: 11.1 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 self.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 :rm_originator, :rm_name, :rm_entity,
52 :concept_name, :specialisation, :version_id
53
54 def initialize(args = {})
55 if args[:value].nil?
56 self.rm_originator = args[:rm_originator]
57 self.rm_name = args[:rm_name]
58 self.rm_entity = args[:rm_entity]
59 self.concept_name = args[:concept_name]
60 self.version_id = args[:version_id]
61 self.specialisation = args[:specialisation]
62 else
63 super(args)
64 end
65 end
66
67 def value=(value)
68 if /([a-zA-Z]\w+)-([a-zA-Z]\w+)-([a-zA-Z]\w+)\.([a-zA-Z]\w+)(-([a-zA-Z]\w+))?\.(v[1-9]\d*)/ =~ value
69 self.rm_originator = $1
70 self.rm_name = $2
71 self.rm_entity = $3
72 self.concept_name = $4
73 self.specialisation = $6
74 self.version_id = $7
75 else
76 raise ArgumentError, 'invalid archetype id form'
77 end
78 end
79
80 def qualified_rm_entity
81 return @rm_originator + '-' + @rm_name + '-' + @rm_entity
82 end
83
84 def domain_concept
85 if @specialisation.nil?
86 return @concept_name
87 else
88 return @concept_name + '-' + @specialisation
89 end
90 end
91
92 def value
93 return self.qualified_rm_entity + '.' +
94 self.domain_concept + '.' + @version_id
95 end
96
97 def concept_name=(concept_name)
98 if concept_name.nil? or concept_name.empty?
99 raise ArgumentError, 'concept_name is mandatory'
100 end
101 @concept_name = concept_name
102 end
103
104 def domain_concept=(domain_concept)
105 if domain_concept.nil? or domain_concept.empty?
106 raise ArgumentError, "domain concept not valid"
107 end
108 if /([a-zA-Z]\w+)(-([a-zA-Z]\w))?/ =~ domain_concept
109 self.concept_name = $1
110 self.specialisation = $3
111 else
112 raise ArgumentError, 'invalid domain concept form'
113 end
114 end
115
116 def rm_name=(rm_name)
117 raise ArgumentError, "rm_name not valid" if rm_name.nil? or rm_name.empty?
118 @rm_name = rm_name
119 end
120
121 def rm_entity=(rm_entity)
122 if rm_entity.nil? or rm_entity.empty?
123 raise ArgumentError, "rm_entity is mandatory"
124 end
125 @rm_entity = rm_entity
126 end
127
128 def rm_originator=(rm_originator)
129 if rm_originator.nil? or rm_originator.empty?
130 raise ArgumentError, "rm_originator not valid"
131 end
132 @rm_originator = rm_originator
133 end
134
135 def specialisation=(specialisation)
136 if !specialisation.nil? and specialisation.empty?
137 raise ArgumentError, "rm_specialisation not valid"
138 end
139 @specialisation = specialisation
140 end
141
142 def version_id=(version_id)
143 raise ArgumentError, "version_id not valid" if version_id.nil? or version_id.empty?
144 @version_id = version_id
145 end
146 end
147
148 class TerminologyID < ObjectID
149 attr_reader :name, :version_id
150
151 def initialize(args = {})
152 if args[:value].nil?
153 self.name = args[:name]
154 self.version_id = args[:version_id]
155 else
156 super(args)
157 end
158 end
159
160 def value
161 if @version_id.empty?
162 @name
163 else
164 @name + '(' + @version_id + ')'
165 end
166 end
167
168
169 def value=(value)
170 raise ArgumentError, "value not valid" if value.nil? or value.empty?
171 if /(.*)\((.*)\)/ =~ value
172 self.name = $1
173 self.version_id = $2
174 else
175 self.name = value
176 self.version_id = ''
177 end
178 end
179
180 def name=(name)
181 raise ArgumentError, "name not valid" if name.nil? or name.empty?
182 @name = name
183 end
184
185 def version_id=(version_id)
186 if version_id.nil?
187 @version_id = ''
188 else
189 @version_id = version_id
190 end
191 end
192 end # of Terminology_ID
193
194 class GenericID < ObjectID
195 attr_reader :scheme
196
197 def initialize(args)
198 super(args)
199 self.scheme = args[:scheme]
200 end
201
202 def scheme=(scheme)
203 if scheme.nil? or scheme.empty?
204 raise ArgumentError, "scheme not valid"
205 end
206 @scheme = scheme
207 end
208 end # of Generic_ID
209
210 class TemplateID < ObjectID
211
212 end
213
214 class UIDBasedID < ObjectID
215 attr_reader :root, :extension
216
217 def initialize(args = {})
218 super(args)
219 end
220
221 def value=(value)
222 super(value)
223 if /(\S+)::(\S+)/ =~ value
224 @root = UID.new(:value => $1)
225 @extension = $2
226 else
227 @root = UID.new(:value => value)
228 @extension = ''
229 end
230 end
231
232 def has_extension?
233 return !@extension.empty?
234 end
235 end
236
237 class ObjectVersionID < UIDBasedID
238 attr_reader :object_id, :creating_system_id, :version_tree_id
239
240 def initialize(value)
241 super(value)
242 end
243
244 def value=(value)
245 super(value)
246 if /^(\w+)::(\w+)::((\d|\.)+)$/ =~ value
247 self.object_id = UID.new($1)
248 self.creating_system_id = UID.new($2)
249 self.version_tree_id = VersionTreeID.new($3)
250 else
251 raise ArgumentError, 'invalid format'
252 end
253 end
254
255 def object_id=(object_id)
256 raise ArgumentError, 'object_id is mandatory' if object_id.nil?
257 @object_id = object_id
258 end
259
260 def creating_system_id=(creating_system_id)
261 if creating_system_id.nil?
262 raise ArgumentError, 'creating_system_id is mandatory'
263 end
264 @creating_system_id = creating_system_id
265 end
266
267 def version_tree_id=(version_tree_id)
268 if version_tree_id.nil?
269 raise ArgumentError, 'version_tree_id is mandatory'
270 end
271 @version_tree_id = version_tree_id
272 end
273
274 def is_branch?
275 return @version_tree_id.is_branch?
276 end
277 end
278
279 class LocatableRef < ObjectRef
280 attr_reader :namespace, :type, :id, :path
281
282 def initialize(namespace, type, id, path)
283 super(namespace, type, id)
284 self.path = path
285 end
286
287 def path=(path)
288 raise ArgumentError if path.nil? or path.empty?
289 @path = path
290 end
291
292 def as_uri
293 'ehr://' + @id.value + '/' + @path
294 end
295 end
296
297 class PartyRef < ObjectRef
298
299 def type=(type)
300 parties = ['PERSON', 'ORGANISATION', 'GROUP', 'AGENT', 'ROLE','PARTY', 'ACTOR']
301 raise ArgumentError, 'type invalid' unless parties.include? type
302 @type = type
303 end
304 end
305
306 class AccessGroupRef < ObjectRef
307 def type=(type)
308 raise ArgumentError, 'type invalid' unless type == 'ACCESS_GROUP'
309 @type = type
310 end
311 end
312
313 class HierObjectID < UIDBasedID
314
315 end
316
317 class VersionTreeID
318 attr_reader :trunk_version, :branch_number, :branch_version
319
320 def initialize(args = {})
321 self.value = args[:value]
322 end
323
324 def value=(value)
325 raise ArgumentError, 'value invalid' if value.nil? or value.empty?
326 (trunk_version, branch_number, branch_version) = value.split '.'
327 self.trunk_version = trunk_version
328 self.branch_number = branch_number
329 self.branch_version = branch_version
330 end
331
332 def value
333 @value = trunk_version
334 @value = @value + '.' + @branch_number unless @branch_number.nil?
335 @value = @value + '.' + @branch_version unless @branch_version.nil?
336 return @value
337 end
338
339 def trunk_version=(trunk_version)
340 if trunk_version.nil? || (trunk_version.to_i < 1)
341 raise ArgumentError, 'trunk_version invalid'
342 end
343 @trunk_version = trunk_version
344 end
345
346 def branch_number=(branch_number)
347 unless branch_number.nil? or branch_number.to_i >= 1
348 raise ArgumentError, 'branch number invalid'
349 end
350 @branch_number = branch_number
351 end
352
353 def branch_version=(branch_version)
354 if (!branch_version.nil? and !(branch_version.to_i >= 1)) or
355 (!branch_version.nil? and @branch_number.nil?)
356 raise ArgumentError, 'branch version invalid'
357 end
358 @branch_version = branch_version
359 end
360
361 def is_branch?
362 !@branch_version.nil? and !@branch_number.nil?
363 end
364
365 def is_first?
366 trunk_version == '1'
367 end
368 end
369
370 class UID
371 attr_reader :value
372
373 def initialize(args = {})
374 self.value = args[:value]
375 end
376
377 def value=(value)
378 raise ArgumentError if value.nil? or value.empty?
379 @value = value
380 end
381 end
382
383 class UUID < UID
384
385 end
386
387 class InternetID <UID
388
389 end
390
391 class IsoOID <UID
392
393 end
394 end # of Identification
395 end # of Support
396 end # of RM
397end # of OpenEHR
Note: See TracBrowser for help on using the repository browser.