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

Last change on this file since 99 was 99, checked in by KOBAYASHI, Shinji, 16 years ago

refs #39
fixed Access_Group_Ref

File size: 6.9 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
9 class Object_ID
10 attr_reader :value
11
12 def initialize(value)
13 self.value=value
14 end
15
16 def value=(value)
17 raise ArgumentError, "empty value" if value.nil? or value.empty?
18 @value = value
19 end
20 def ==(object_id)
21 @value == object_id.value
22 end
23 end # of ObjectID
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
49
50 class Archetype_ID < Object_ID
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
91 end
92
93 class Terminology_ID < Object_ID
94 attr_reader :name, :version_id
95
96 def initialize(value, name , version_id="")
97 super(value)
98 self.name = name
99 self.version_id = version_id
100 end
101
102 def name=(name)
103 raise ArgumentError, "name not valid" if name.nil? or name.empty?
104 @name = name
105 end
106
107 def version_id=(version_id)
108 raise ArgumentError, "version_id not valid" if version_id.nil?
109 @version_id = version_id
110 end
111 end # of Terminology_ID
112
113 class Generic_ID < Object_ID
114 attr_reader :scheme
115
116 def initialize(value, scheme)
117 super(value)
118 self.scheme = scheme
119 end
120
121 def scheme=(scheme)
122 raise ArgumentError, "scheme not valid" if scheme.nil? or scheme.empty?
123 @scheme = scheme
124 end
125 end # of Generic_ID
126
127 class UID_Based_ID < Object_ID
128 def initialize(value)
129 super(value)
130 end
131
132 def extension
133 if self.has_extension?
134 @value[/::.*/][2..-1]
135 else
136 ''
137 end
138 end
139
140 def has_extension?
141 @value.include? '::'
142 end
143
144 def root
145 if self.has_extension?
146 @value[/.*::/][0..-3]
147 else
148 @value
149 end
150 end
151 end
152
153 class Locatable_Ref < Object_Ref
154 attr_reader :namespace, :type, :id, :path
155
156 def initialize(namespace, type, id, path)
157 super(namespace, type, id)
158 self.path = path
159 end
160
161 def path=(path)
162 raise ArgumentError if path.nil? or path.empty?
163 @path = path
164 end
165
166 def as_uri
167 'ehr://' + @id.value + '/' + @path
168 end
169 end
170
171 class Party_Ref < Object_Ref
172 TYPE = ['PERSON', 'ORGANISATION', 'GROUP', 'AGENT', 'ROLE','PARTY', 'ACTOR']
173 def initialize(namespace, type, id)
174 super(namespace, type, id)
175 end
176
177 def type=(type)
178 raise ArgumentError, 'type invalid' if !TYPE.include? type
179 @type = type
180 end
181 end
182
183 class Access_Group_Ref < Object_Ref
184 def type=(type)
185 raise ArgumentError, 'type invalid' if !(type == 'ACCESS_GROUP')
186 @type = type
187 end
188 end
189
190 class Hier_Object_ID < UID_Based_ID
191
192 end
193
194 class Version_Tree_ID
195 attr_reader :value, :trunk_version, :branch_number, :branch_version
196
197 def initialize(value)
198 self.value = value
199 end
200
201 def value=(value)
202 raise ArgumentError, 'value invalid' if value.nil? or value.empty?
203 @value = value
204 (trunk_version, branch_number, branch_version) = value.split '.'
205 self.trunk_version =trunk_version
206 end
207
208 def trunk_version=(trunk_version)
209 Raise ArgumentError, 'trunk_version invalid' if trunk_version.nil? and trunk_version.to_i >= 0
210 @trunk_version = trunk_version
211 end
212
213 def branch_number=(branch_number)
214 Raise ArgumentError, 'branch number invalid' if branch_nmuber.nil?
215 end
216
217 def is_branch?
218 !@branch_version.nil?
219 end
220 private
221 def value_valid
222
223 end
224 end
225
226 class UID
227 attr_reader :value
228
229 def initialize(value)
230 self.value = value
231 end
232
233 def value=(value)
234 raise ArgumentError if value.nil? or value.empty?
235 @value = value
236 end
237 end
238
239 class UUID < UID
240
241 end
242
243 class Internet_ID <UID
244
245 end
246
247 class ISO_OID <UID
248
249 end
250 end # of Identification
251 end # of Support
252 end # of RM
253end # of OpenEHR
Note: See TracBrowser for help on using the repository browser.