source: ruby/trunk/lib/models/rm/support/identification.rb@ 268

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

fixed around identification

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