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, 15 years ago

support/identification package moving from test/unit to rspec

File size: 9.4 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)
21 @value == object_id.value
22 end
[4]23 end # of ObjectID
[94]24
[167]25 class ObjectRef
[94]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)
[259]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]|[_-\:\/\&\+\?])*/
[94]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
[259]50 class ArchetypeID < ObjectID
[91]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
[26]91 end
92
[259]93 class TerminologyID < ObjectID
[92]94 attr_reader :name, :version_id
[26]95
[259]96 def initialize(args = {})
97 super(args)
[4]98 end
[26]99
[107]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)
[106]110 raise ArgumentError, "value not valid" if value.nil? or value.empty?
[107]111 if /(.*)\((.*)\)$/ =~ value
[106]112 @name = $1
113 @version_id = $2
114 else
115 @name = value
[158]116 @version_id = ''
[106]117 end
118 @value = value
119 end
120
[92]121 def name=(name)
122 raise ArgumentError, "name not valid" if name.nil? or name.empty?
123 @name = name
[4]124 end
[26]125
[92]126 def version_id=(version_id)
127 raise ArgumentError, "version_id not valid" if version_id.nil?
128 @version_id = version_id
[4]129 end
[92]130 end # of Terminology_ID
[26]131
[259]132 class GenericID < ObjectID
[92]133 attr_reader :scheme
[26]134
[92]135 def initialize(value, scheme)
136 super(value)
137 self.scheme = scheme
[4]138 end
[26]139
[92]140 def scheme=(scheme)
141 raise ArgumentError, "scheme not valid" if scheme.nil? or scheme.empty?
142 @scheme = scheme
[4]143 end
[92]144 end # of Generic_ID
[94]145
[259]146 class TemplateID < ObjectID
[100]147
148 end
149
[259]150 class UIDBasedID < ObjectID
[93]151 def initialize(value)
152 super(value)
153 end
[97]154
[93]155 def extension
156 if self.has_extension?
157 @value[/::.*/][2..-1]
158 else
159 ''
160 end
161 end
[97]162
[93]163 def has_extension?
164 @value.include? '::'
165 end
[97]166
[93]167 def root
168 if self.has_extension?
169 @value[/.*::/][0..-3]
170 else
171 @value
172 end
173 end
174 end
[95]175
[259]176 class ObjectVersionID < UIDBasedID
[157]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
[259]186 self.object_id = UID.new($1)
187 self.creating_system_id = UID.new($2)
188 self.version_tree_id = VersionTreeID.new($3)
[157]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
[158]212
213 def is_branch?
214 return @version_tree_id.is_branch?
215 end
[157]216 end
217
[167]218 class LocatableRef < ObjectRef
[97]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
[167]236 class PartyRef < ObjectRef
[98]237
238 def type=(type)
[100]239 parties = ['PERSON', 'ORGANISATION', 'GROUP', 'AGENT', 'ROLE','PARTY', 'ACTOR']
[101]240 raise ArgumentError, 'type invalid' unless parties.include? type
[98]241 @type = type
242 end
243 end
[99]244
[167]245 class AccessGroupRef < ObjectRef
[99]246 def type=(type)
[101]247 raise ArgumentError, 'type invalid' unless type == 'ACCESS_GROUP'
[99]248 @type = type
249 end
250 end
251
[259]252 class HierObjectID < UIDBasedID
[95]253
254 end
255
[259]256 class VersionTreeID
[98]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?
[101]265 @trunk_version = @branch_number = @branch_version = nil
[98]266 (trunk_version, branch_number, branch_version) = value.split '.'
[100]267 self.trunk_version = trunk_version
268 self.branch_number = branch_number
269 self.branch_version = branch_version
[98]270 end
271
272 def trunk_version=(trunk_version)
[101]273 raise ArgumentError, 'trunk_version invalid' if trunk_version.nil? and !trunk_version.to_i >= 1
[98]274 @trunk_version = trunk_version
[101]275 set_value
[98]276 end
277
278 def branch_number=(branch_number)
[101]279 raise ArgumentError, 'branch number invalid' unless branch_number.nil? or branch_number.to_i >= 1
[100]280 @branch_number = branch_number
[101]281 set_value
[98]282 end
283
[100]284 def branch_version=(branch_version)
[101]285 raise ArgumentError, 'branch version invalid' if (!branch_version.nil? and !( branch_version.to_i >= 1)) or (!branch_version.nil? and @branch_number.nil?)
[100]286 @branch_version = branch_version
[101]287 set_value
[100]288 end
[98]289 def is_branch?
[101]290 !@branch_version.nil? and !@branch_number.nil?
[98]291 end
[101]292
293 def is_first?
294 trunk_version == '1'
295 end
296
[98]297 private
[101]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?
[98]302 end
303 end
304
[259]305 class UID
[98]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
[259]318 class UUID < UID
[98]319
320 end
321
[259]322 class InternetID <UID
[98]323
324 end
325
[259]326 class IsoOID <UID
[98]327
[157]328 end
[93]329 end # of Identification
[4]330 end # of Support
331 end # of RM
332end # of OpenEHR
Note: See TracBrowser for help on using the repository browser.