1 tony 1.1 // ===================================================================
2 // Title: Core Software 2.8
3 // Filename: Core28_Software.mof
4 // Version: 2.8
5 // Status: Final
6 // Date: Jan 26, 2004
7 // ===================================================================
8 // Copyright 2002-2003 Distributed Management Task Force, Inc. (DMTF).
9 // All rights reserved.
10 // DMTF is a not-for-profit association of industry members dedicated
11 // to promoting enterprise and systems management and interoperability.
12 // DMTF specifications and documents may be reproduced for uses
13 // consistent with this purpose by members and non-members,
14 // provided that correct attribution is given.
15 // As DMTF specifications may be revised from time to time,
16 // the particular version and release date should always be noted.
17 //
18 // Implementation of certain elements of this standard or proposed
19 // standard may be subject to third party patent rights, including
20 // provisional patent rights (herein "patent rights"). DMTF makes
21 // no representations to users of the standard as to the existence
22 tony 1.1 // of such rights, and is not responsible to recognize, disclose, or
23 // identify any or all such third party patent right, owners or
24 // claimants, nor for any incomplete or inaccurate identification or
25 // disclosure of such rights, owners or claimants. DMTF shall have no
26 // liability to any party, in any manner or circumstance, under any
27 // legal theory whatsoever, for failure to recognize, disclose, or
28 // identify any such third party patent rights, or for such party's
29 // reliance on the standard or incorporation thereof in its product,
30 // protocols or testing procedures. DMTF shall have no liability to
31 // any party implementing such standard, whether such implementation
32 // is foreseeable or not, nor to any patent owner or claimant, and shall
33 // have no liability or responsibility for costs or losses incurred if
34 // a standard is withdrawn or modified after publication, and shall be
35 // indemnified and held harmless by any party implementing the
36 // standard from any and all claims of infringement by a patent owner
37 // for such implementations.
38 //
39 // For information about patents held by third-parties which have
40 // notified the DMTF that, in their opinion, such patent may relate to
41 // or impact implementations of DMTF standards, visit
42 // http://www.dmtf.org/about/policies/disclosures.php.
43 tony 1.1 // ===================================================================
44 // Description: The Core Model defines basic management concepts.
45 // This file defines the SoftwareIdentity class,
46 // representing software assets/inventory/units of
47 // existence.
48 //
49 // The object classes below are listed in an order that
50 // avoids forward references. Required objects, defined
51 // by other working groups, are omitted.
52 // ==================================================================
53 // Change Log for v2.8 Final
54 // CR1189 - Add SerialNumber property to SoftwareIdentity
55 // CR1200 - ElementSoftwareIdentity
56 // CR1210 - Removal of experimental Qualifiers for core.
57 //
58 // Change Log for v2.8 Preliminary
59 // CR1019 - CIM Versioning for 2.8 Preliminary
60 // CR1020 - Add ServiceSoftware relationship
61 // CR1049 - Modify the ServiceSoftware association to be
62 // ServiceSoftwareIdentity
63 // CR1098 - Addition of InstalledSoftwareIdentity
64 tony 1.1 // CR1131 - Add enumerations to SoftwareIdentity.Classification
65 //
66 // Change Log for v2.7
67 // CR968 - Remove the Experimental qualifier
68 // CR994 - Update the description of InstanceID
69 //
70 // Change Log for v2.7
71 // CR753 - Add SoftwareIdentity
72 // CR904 - Added missing brackets to SoftwareIdentity.
73 // ClassificationDescriptions array
74 // ===================================================================
75
76 #pragma locale ("en_US")
77
78
79 // ==================================================================
80 // SoftwareIdentity
81 // ==================================================================
82 [Version ( "2.8.0" ), Description (
83 "SoftwareIdentity represents software, viewed as an asset "
84 "and/or individually identifiable entity (similar to Physical "
85 tony 1.1 "Element). It does NOT indicate whether the software is "
86 "installed, executing, etc. (The latter is the role of the "
87 "SoftwareFeature/ SoftwareElement classes and the Application "
88 "Model.) Since software may be acquired, SoftwareIdentity can "
89 "be associated with a Product using the "
90 "ProductSoftwareComponent relationship. \n"
91 "Note that the Application Model manages the deployment and "
92 "installation of software via the classes, SoftwareFeatures and "
93 "SoftwareElements. The deployment/installation concepts are "
94 "related to the asset/identity one. In fact, a SoftwareIdentity "
95 "may correspond to a Product, or to one or more "
96 "SoftwareFeatures or SoftwareElements - depending on the "
97 "granularity of these classes and the deployment model. The "
98 "correspondence of Software Identity to Product, "
99 "SoftwareFeature or SoftwareElement is indicated using the "
100 "ConcreteIdentity association. Note that there may not be "
101 "sufficient detail or instrumentation to instantiate "
102 "ConcreteIdentity. And, if the association is instantiated, "
103 "some duplication of information may result. For example, the "
104 "Vendor described in the instances of Product and "
105 "SoftwareIdentity MAY be the same. However, this is not "
106 tony 1.1 "necessarily true, and it is why vendor and similar information "
107 "are duplicated in this class. \n"
108 "Note that ConcreteIdentity can also be used to describe the "
109 "relationship of the software to any LogicalFiles that result "
110 "from installing it. As above, there may not be sufficient "
111 "detail or instrumentation to instantiate this association.")]
112 class CIM_SoftwareIdentity : CIM_LogicalElement {
113
114 [Key, Description (
115 "Within the scope of the instantiating Namespace, InstanceID "
116 "opaquely and uniquely identifies an instance of this class. "
117 "In order to ensure uniqueness within the NameSpace, the "
118 "value of InstanceID SHOULD be constructed using the "
119 "following 'preferred' algorithm: \n"
120 "<OrgID>:<LocalID> \n"
121 "Where <OrgID> and <LocalID> are separated by a colon ':', "
122 "and where <OrgID> MUST include a copyrighted, trademarked "
123 "or otherwise unique name that is owned by the business "
124 "entity creating/defining the InstanceID, or is a registered "
125 "ID that is assigned to the business entity by a recognized "
126 "global authority (This is similar to the <Schema "
127 tony 1.1 "Name>_<Class Name> structure of Schema class names.) In "
128 "addition, to ensure uniqueness <OrgID> MUST NOT contain a "
129 "colon (':'). When using this algorithm, the first colon to "
130 "appear in InstanceID MUST appear between <OrgID> and "
131 "<LocalID>. \n"
132 "<LocalID> is chosen by the business entity and SHOULD not "
133 "be re-used to identify different underlying (real-world) "
134 "elements. If the above 'preferred' algorithm is not used, "
135 "the defining entity MUST assure that the resultant "
136 "InstanceID is not re-used across any InstanceIDs produced "
137 "by this or other providers for this instance's NameSpace. \n"
138 "For DMTF defined instances, the 'preferred' algorithm MUST "
139 "be used with the <OrgID> set to 'CIM'.")]
140 string InstanceID;
141
142 [Description (
143 "The major number component of the software's version "
144 "information - for example, '12' from version 12.1(3)T. This "
145 "property is defined as a numeric value to allow the "
146 "determination of 'newer' vs. 'older' releases. A 'newer' "
147 "major release is indicated by a larger numeric value.")]
148 tony 1.1 uint16 MajorVersion;
149
150 [Description (
151 "The minor number component of the software's version "
152 "information - for example, '1' from version 12.1(3)T. This "
153 "property is defined as a numeric value to allow the "
154 "determination of 'newer' vs. 'older' releases. A 'newer' "
155 "minor release is indicated by a larger numeric value.")]
156 uint16 MinorVersion;
157
158 [Description (
159 "The revision or maintenance release component of the "
160 "software's version information - for example, '3' from "
161 "version 12.1(3)T. This property is defined as a numeric "
162 "value to allow the determination of 'newer' vs. 'older' "
163 "releases. A 'newer' revision is indicated by a larger "
164 "numeric value.")]
165 uint16 RevisionNumber;
166
167 [Description (
168 "The build number of the software.")]
169 tony 1.1 uint16 BuildNumber;
170
171 [Description (
172 "A string representing the complete software version "
173 "information - for example, '12.1(3)T'. This string and the "
174 "numeric major/minor/revision/build properties are "
175 "complementary. Since vastly different representations and "
176 "semantics exist for versions, it is not assumed that one "
177 "representation is sufficient to permit a client to perform "
178 "computations (i.e., the values are numeric) and a user to "
179 "recognize the software's version (i.e., the values are "
180 "understandable and readable). Hence, both numeric and "
181 "string representations of version are provided.")]
182 string VersionString;
183
184 [Description (
185 "Specifies the target operating systems of the software. Due "
186 "to the extreme variability in operating systems, this "
187 "property is defined as a string array.")]
188 string TargetOperatingSystems[];
189
190 tony 1.1 [Description (
191 "Manufacturer of this software.")]
192 string Manufacturer;
193
194 [Description (
195 "The language editions supported by the software. The "
196 "language codes defined in ISO 639 should be used.")]
197 string Languages[];
198
199 [Description (
200 "An array of enumerated integers that classify this "
201 "software. For example, the software MAY be instrumentation "
202 "(value=5) or firmware and diagnostic software (10 and 7). "
203 "The use of value 6, Firmware/BIOS, is being deprecated. "
204 "Instead, either the value 10 (Firmware) and/or 11 "
205 "(BIOS/FCode) SHOULD be used."),
206 ValueMap { "0", "1", "2", "3", "4", "5", "6", "7", "8", "9",
207 "10", "11", "..", "0x8000..0xFFFF" },
208 Values { "Unknown", "Other", "Driver", "Configuration Software",
209 "Application Software", "Instrumentation", "Firmware/BIOS",
210 "Diagnostic Software", "Operating System", "Middleware",
211 tony 1.1 "Firmware", "BIOS/FCode", "DMTF Reserved",
212 "Vendor Reserved" }, ArrayType ( "Indexed" ),
213 ModelCorrespondence {
214 "CIM_SoftwareIdentity.ClassificationDescriptions" }]
215 uint16 Classifications[];
216
217 [Description (
218 "An array of free-form strings providing more detailed "
219 "explanations for any of the entries in the Classifications "
220 "array. Note that each entry is related to one in the "
221 "Classifications array located at the same index."),
222 ArrayType ( "Indexed" ),
223 ModelCorrespondence { "CIM_SoftwareIdentity.Classifications" }]
224 string ClassificationDescriptions[];
225
226 [Description (
227 "A manufacturer-allocated number used to identify the "
228 "software.")]
229 string SerialNumber;
230
231 };
232 tony 1.1
233 // ===================================================================
234 // ElementSoftwareIdentity
235 // ===================================================================
236 [Association, Version ( "2.8.0" ), Description (
237 "ElementSoftwareIdentity allows a Managed Element to report its "
238 "software related asset information (firmware, drivers, "
239 "configuration software, and etc.)")]
240 class CIM_ElementSoftwareIdentity : CIM_Dependency {
241
242 [Override ( "Antecedent" ), Description (
243 "A LogicalElement's Software Asset.")]
244 CIM_SoftwareIdentity REF Antecedent;
245
246 [Override ( "Dependent" ), Description (
247 "The ManagedElement that requires or uses the software.")]
248 CIM_ManagedElement REF Dependent;
249
250 [Description (
251 "Indicates the element's ability to upgrade this software "
252 "asset. \n"
253 tony 1.1 "'Resides off element'(2), indicates the persistence of the "
254 "software is outside of the element. Typically for a element "
255 "this software is part of the OperatingSystem is typically "
256 "upgradeable. \n"
257 "'Owner Upgradeable' (3), indicates the persistence of the "
258 "software is on the element and is upgradeable by the owner. "
259 "\n'FactoryUpgradeable' (4),indicates the persistence of the "
260 "software is on the element and is upgradeable by the "
261 "manufacturer. \n"
262 "'Not Upgradeable' (5), indicates the presistence of the "
263 "software is on the element and is not upgradeable. (i.e. "
264 "burned into a non replaceable ROM chip."),
265 ValueMap { "0", "1", "2", "3", "4", "5", "..","0x8000..0xFFFF" },
266 Values { "Unknown", "Other", "Resides off device",
267 "Owner Upgradeable", "Factory Upgradeable","Not Upgradeable",
268 "DMTF Reserved", "Vendor Reserved" },
269 ModelCorrespondence {
270 "CIM_ElementSoftwareIdentity.OtherUpgradeCondition" }]
271 uint16 UpgradeCondition;
272
273 [Description (
274 tony 1.1 "Describes the upgrade condition, when UpgradeCondition is "
275 "set to 1 (\"Other\")."),
276 ModelCorrespondence {
277 "CIM_ElementSoftwareIdentity.UpgradeCondition" }]
278 string OtherUpgradeCondition;
279 };
280
281 // ==================================================================
282 // InstalledSoftwareIdentity
283 // ==================================================================
284 [Association, Version ( "2.8.0" ), Description (
285 "The InstalledSoftwareIdentity association identifies the "
286 "System on which a SoftwareIdentity is installed. This class is "
287 "a corollary to InstalledSoftwareElement, but deals with the "
288 "asset aspects of software (as indicated by SoftwareIdentity), "
289 "versus the deployment aspects (as indicated by "
290 "SoftwareElement).")]
291 class CIM_InstalledSoftwareIdentity {
292
293 [Key, Description (
294 "The system on which the software is installed.")]
295 tony 1.1 CIM_System REF System;
296
297 [Key, Description (
298 "The SoftwareIdentity that is installed.")]
299 CIM_SoftwareIdentity REF InstalledSoftware;
300 };
301
302 // ===================================================================
303 // end of file
304 // ===================================================================
|