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

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

access_group_ref test/unit move to rspec

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