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

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

object_version_id 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
[278]243          def initialize(args= {})
244            super(args)
[157]245          end
246
247          def value=(value)
[278]248            if /^(\S+)::(\S+)::((\d|\.)+)$/ =~ value
249              self.object_id = UID.new(:value => $1)
250              self.creating_system_id = UID.new(:value => $2)
251              self.version_tree_id = VersionTreeID.new(:value => $3)
[157]252            else
253              raise ArgumentError, 'invalid format'
254            end
255          end
256
257          def object_id=(object_id)
258            raise ArgumentError, 'object_id is mandatory' if object_id.nil?
259            @object_id = object_id
260          end
261
262          def creating_system_id=(creating_system_id)
263            if creating_system_id.nil?
264              raise ArgumentError, 'creating_system_id is mandatory'
265            end
266            @creating_system_id = creating_system_id
267          end
268
269          def version_tree_id=(version_tree_id)
270            if version_tree_id.nil?
271              raise ArgumentError, 'version_tree_id is mandatory'
272            end
273            @version_tree_id = version_tree_id
274          end
[158]275
276          def is_branch?
277            return @version_tree_id.is_branch?
278          end
[157]279        end
280
[167]281        class LocatableRef < ObjectRef
[97]282          attr_reader :namespace, :type, :id, :path
283
284          def initialize(namespace, type, id, path)
285            super(namespace, type, id)
286            self.path = path
287          end
288
289          def path=(path)
290            raise ArgumentError if path.nil? or path.empty?
291            @path = path
292          end
293
294          def as_uri
295            'ehr://' + @id.value + '/' + @path
296          end
297        end
298
[167]299        class PartyRef < ObjectRef
[98]300          def type=(type)
[277]301            parties = %w[PERSON ORGANISATION GROUP AGENT ROLE PARTY ACTOR]
[101]302            raise ArgumentError, 'type invalid' unless parties.include? type
[98]303            @type = type
304          end
305        end
[99]306
[167]307        class AccessGroupRef < ObjectRef
[276]308          def initialize(args = {})
309            super(args)
310            @type = 'ACCESS_GROUP'
311          end
312
[99]313          def type=(type)
314          end
315        end
316
[259]317        class HierObjectID < UIDBasedID
[95]318
319        end
320
[259]321        class VersionTreeID
[274]322          attr_reader :trunk_version, :branch_number, :branch_version
[98]323
[274]324          def initialize(args = {})
325            self.value = args[:value]
[98]326          end
327
328          def value=(value)
329            raise ArgumentError, 'value invalid' if value.nil? or value.empty?
330            (trunk_version, branch_number, branch_version) = value.split '.'
[100]331            self.trunk_version = trunk_version
332            self.branch_number = branch_number
333            self.branch_version = branch_version
[98]334          end
335
[274]336          def value
337            @value = trunk_version
338            @value = @value + '.' + @branch_number unless @branch_number.nil?
339            @value = @value + '.' + @branch_version unless @branch_version.nil?
340            return @value
341          end
342
[98]343          def trunk_version=(trunk_version)
[274]344            if trunk_version.nil? || (trunk_version.to_i < 1)
345              raise ArgumentError, 'trunk_version invalid'
346            end
[98]347            @trunk_version = trunk_version
348          end
349
350          def branch_number=(branch_number)
[274]351            unless branch_number.nil? or branch_number.to_i >= 1
352              raise ArgumentError, 'branch number invalid'
353            end
[100]354            @branch_number = branch_number
[98]355          end
356
[100]357          def branch_version=(branch_version)
[274]358            if (!branch_version.nil? and !(branch_version.to_i >= 1)) or
359                (!branch_version.nil? and @branch_number.nil?)
360              raise ArgumentError, 'branch version invalid'
361            end
[100]362            @branch_version = branch_version
363          end
[274]364
[98]365          def is_branch?
[101]366            !@branch_version.nil? and !@branch_number.nil?
[98]367          end
[101]368
369          def is_first?
370            trunk_version == '1'
371          end
[98]372        end
373
[259]374        class UID
[98]375          attr_reader :value
376
[272]377          def initialize(args = {})
378            self.value = args[:value]
[98]379          end
380
381          def value=(value)
382            raise ArgumentError if value.nil? or value.empty?
383            @value = value
384          end
385        end
386
[259]387        class UUID < UID
[98]388
389        end
390
[259]391        class InternetID <UID
[98]392         
393        end
394
[259]395        class IsoOID <UID
[98]396
[157]397        end       
[93]398      end # of Identification
[4]399    end # of Support
400  end # of RM
401end # of OpenEHR
Note: See TracBrowser for help on using the repository browser.