File: PropertyCollector.rst

package info (click to toggle)
python-pyvmomi 6.7.1-2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 14,984 kB
  • sloc: python: 9,206; xml: 77; makefile: 11
file content (461 lines) | stat: -rw-r--r-- 16,517 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
.. _str: https://docs.python.org/2/library/stdtypes.html

.. _bool: https://docs.python.org/2/library/stdtypes.html

.. _vim.Task: ../../vim/Task.rst

.. _truncated: ../../vmodl/query/PropertyCollector/UpdateSet.rst#truncated

.. _CreateFilter: ../../vmodl/query/PropertyCollector.rst#createFilter

.. _maxWaitSeconds: ../../vmodl/query/PropertyCollector/WaitOptions.rst#maxWaitSeconds

.. _PropertyFilter: ../../vmodl/query/PropertyCollector/Filter.rst

.. _WaitForUpdates: ../../vmodl/query/PropertyCollector.rst#waitForUpdates

.. _CheckForUpdates: ../../vmodl/query/PropertyCollector.rst#checkForUpdates

.. _vSphere API 4.1: ../../vim/version.rst#vmodlqueryversionversion3

.. _RequestCanceled: ../../vmodl/fault/RequestCanceled.rst

.. _WaitForUpdatesEx: ../../vmodl/query/PropertyCollector.rst#waitForUpdatesEx

.. _PropertyCollector: ../../vmodl/query/PropertyCollector.rst

.. _RetrievePropertiesEx: ../../vmodl/query/PropertyCollector.rst#retrievePropertiesEx

.. _CreatePropertyCollector: ../../vmodl/query/PropertyCollector.rst#createPropertyCollector

.. _vmodl.fault.InvalidType: ../../vmodl/fault/InvalidType.rst

.. _DestroyPropertyCollector: ../../vmodl/query/PropertyCollector.rst#destroy

.. _vmodl.fault.NotSupported: ../../vmodl/fault/NotSupported.rst

.. _vmodl.fault.InvalidArgument: ../../vmodl/fault/InvalidArgument.rst

.. _vmodl.fault.RequestCanceled: ../../vmodl/fault/RequestCanceled.rst

.. _vmodl.query.InvalidProperty: ../../vmodl/query/InvalidProperty.rst

.. _vmodl.query.PropertyCollector: ../../vmodl/query/PropertyCollector.rst

.. _vmodl.fault.ManagedObjectNotFound: ../../vmodl/fault/ManagedObjectNotFound.rst

.. _vmodl.query.InvalidCollectorVersion: ../../vmodl/query/InvalidCollectorVersion.rst

.. _vmodl.query.PropertyCollector.Filter: ../../vmodl/query/PropertyCollector/Filter.rst

.. _vmodl.query.PropertyCollector.UpdateSet: ../../vmodl/query/PropertyCollector/UpdateSet.rst

.. _vmodl.query.PropertyCollector.FilterSpec: ../../vmodl/query/PropertyCollector/FilterSpec.rst

.. _vmodl.query.PropertyCollector.WaitOptions: ../../vmodl/query/PropertyCollector/WaitOptions.rst

.. _vmodl.query.PropertyCollector.ObjectContent: ../../vmodl/query/PropertyCollector/ObjectContent.rst

.. _vmodl.query.PropertyCollector.RetrieveResult: ../../vmodl/query/PropertyCollector/RetrieveResult.rst

.. _vmodl.query.PropertyCollector.RetrieveOptions: ../../vmodl/query/PropertyCollector/RetrieveOptions.rst


vmodl.query.PropertyCollector
=============================
  The `PropertyCollector`_ managed object retrieves and detects changes to the properties of other managed objects. The `RetrievePropertiesEx`_ method provides one-time property retrieval. The `WaitForUpdatesEx`_ method provides incremental change detection and supports both polling and notification.For change detection a client creates one or more filters to specify the subset of managed objects in which the client is interested. Filters keep per-session state to track incremental changes. Because this state is per-session:
   * A session cannot share its
   * `PropertyCollector`_
   * filters with other sessions
   * two different clients can share the same session, and so can share the same filters, but this is not recommended
   * When a session terminates, the associated
   * `PropertyCollector`_
   * filters are automatically destroyed.
   * 




Attributes
----------
    filter ([`vmodl.query.PropertyCollector.Filter`_]):
      privilege: System.View
       The filters that this `PropertyCollector`_ uses to determine the list of properties for which it detects incremental changes.


Methods
-------


CreateFilter(spec, partialUpdates):
   Creates a new filter for the given set of managed objects.


  Privilege:
               System.View



  Args:
    spec (`vmodl.query.PropertyCollector.FilterSpec`_):
       The specifications for the filter.


    partialUpdates (`bool`_):
       Flag to specify whether a change to a nested property should report only the nested change or the entire specified property value. If the value is true, a change should report only the nested property. If the value is false, a change should report the enclosing property named in the filter.




  Returns:
    `vmodl.query.PropertyCollector.Filter`_:
         A reference to the new filter.

  Raises:

    `vmodl.query.InvalidProperty`_: 
       if "spec" has a property that is not defined on one of the objects.

    `vmodl.fault.InvalidArgument`_: 
       if any of the following is true:
        * "spec" is empty.
        * "spec" contains a selection with properties not defined on its type.
        * 

    `vmodl.fault.InvalidType`_: 
       if "spec" contains, directly or indirectly, a type name that does not refer to a known type.

    `vmodl.fault.ManagedObjectNotFound`_: 
       See `reportMissingObjectsInResults`_ .


RetrieveProperties(specSet):
   Retrieves the specified properties of the specified managed objects.This method is similar to creating the filters, receiving the property values, and destroying the filters. The main difference is that the output blends the results from all the filters and reports a given managed object at most once no matter how many filters apply.The filter creation step can throw all of the same faults as `CreateFilter`_ .


  Privilege:
               System.Anonymous



  Args:
    specSet (`vmodl.query.PropertyCollector.FilterSpec`_):
       Specifies the properties to retrieve.




  Returns:
    [`vmodl.query.PropertyCollector.ObjectContent`_]:
         The data contents of the specified objects.

  Raises:

    `vmodl.query.InvalidProperty`_: 
       See `CreateFilter`_ 

    `vmodl.fault.InvalidArgument`_: 
       See `CreateFilter`_ 

    `vmodl.fault.InvalidType`_: 
       See `CreateFilter`_ 

    `vmodl.fault.ManagedObjectNotFound`_: 
       See `CreateFilter`_ 


CheckForUpdates(version):
   Checks for updates on properties specified by the union of all current filters. If no updates are pending, this method returns null.


  Privilege:
               System.View



  Args:
    version (`str`_, optional):
       The data version currently known to the client. The value must be either
        * the special initial version (an empty string)
        * a data version returned from
        * `CheckForUpdates`_
        * or
        * `WaitForUpdates`_
        * by the same
        * `PropertyCollector`_
        * on the same session.
        * a non-truncated data version returned from
        * `WaitForUpdatesEx`_
        * by the same
        * `PropertyCollector`_
        * on the same session.
        * 




  Returns:
    `vmodl.query.PropertyCollector.UpdateSet`_:
         Changes since the passed in data version. If no updates are pending, then this method returns null.

  Raises:

    `vmodl.query.InvalidCollectorVersion`_: 
       if the data version does not meet the requirements above.

    `vmodl.fault.RequestCanceled`_: 
       if `CancelWaitForUpdates`_ has been called or the session was closed or the `PropertyCollector`_ was destroyed at some point after the call was received but before the update calculation was actually started


WaitForUpdates(version):
   Calculate the set of updates for each existing filter in the session, returning when at least one filter has updates.


  Privilege:
               System.View



  Args:
    version (`str`_, optional):
       The data version currently known to the client. The value must be either
        * the special initial version (an empty string)
        * a data version returned from
        * `CheckForUpdates`_
        * or
        * `WaitForUpdates`_
        * by the same
        * `PropertyCollector`_
        * on the same session
        * a non-truncated data version returned from
        * `WaitForUpdatesEx`_
        * by the same
        * `PropertyCollector`_
        * on the same session.
        * 




  Returns:
    `vmodl.query.PropertyCollector.UpdateSet`_:
         Changes since the passed in data version.

  Raises:

    `vmodl.query.InvalidCollectorVersion`_: 
       if the data version does not meet the requirements above.

    `vmodl.fault.RequestCanceled`_: 
       if `CancelWaitForUpdates`_ has been called or the session was closed or the `PropertyCollector`_ was destroyed at some point after the call was received


CancelWaitForUpdates():
   Attempts to cancel outstanding calls to `WaitForUpdates`_ or `WaitForUpdatesEx`_ in the current session. If an update calculation is in process this method has no effect. If an update calculation is not in process any waiting calls complete quickly and report a `RequestCanceled`_ fault.


  Privilege:
               System.View



  Args:


  Returns:
    None
         


WaitForUpdatesEx(version, options):
   Calculate the set of updates for each existing filter in the session. `WaitForUpdatesEx`_ may return only partial update calculations. See `truncated`_ for a more detailed explanation. `WaitForUpdatesEx`_ may also return null after a timeout, either as requested by `maxWaitSeconds`_ or due to `PropertyCollector`_ policy.If an application uses waitForUpdatesEx it is strongly recommended that it not make concurrent calls to `WaitForUpdates`_ , `CheckForUpdates`_ , or `WaitForUpdatesEx`_ in the same session. Concurrent calls may cause suspended change calculations to be discarded.
  since: `vSphere API 4.1`_


  Privilege:
               System.View



  Args:
    version (`str`_, optional):
       The data version currently known to the client. The value must be either
        * the special initial data version (an empty string),
        * a data version returned from
        * `CheckForUpdates`_
        * or
        * `WaitForUpdates`_
        * 
        * a non-truncated data version returned from
        * `WaitForUpdatesEx`_
        * 
        * a truncated data version returned from the last call to
        * `WaitForUpdatesEx`_
        * with no intervening calls to
        * `WaitForUpdates`_
        * or
        * `CheckForUpdates`_
        * .
        * 


    options (`vmodl.query.PropertyCollector.WaitOptions`_, optional):
       Additional options controlling the change calculation. If omitted, equivalent to an options argument with no fields set.




  Returns:
    `vmodl.query.PropertyCollector.UpdateSet`_:
         Changes since the passed in version or null if there are no changes.

  Raises:

    `vmodl.query.InvalidCollectorVersion`_: 
       if the data version does not meet the requirements above.

    `vmodl.fault.RequestCanceled`_: 
       if `CancelWaitForUpdates`_ has been called or the session was closed or the `PropertyCollector`_ was destroyed at some point after the call was received


RetrievePropertiesEx(specSet, options):
   Retrieves the specified properties of the specified managed objects.This method is similar to creating the filters, receiving the property values, and destroying the filters. The main difference is that the output blends the results from all the filters and reports a given managed object at most once no matter how many filters apply.The filter creation step can throw all of the same faults as `CreateFilter`_ .
  since: `vSphere API 4.1`_


  Privilege:
               System.Anonymous



  Args:
    specSet (`vmodl.query.PropertyCollector.FilterSpec`_):
       Specifies the properties to retrieve.


    options (`vmodl.query.PropertyCollector.RetrieveOptions`_):
       Additional method options. If omitted, equivalent to an options argument with no fields set.




  Returns:
    `vmodl.query.PropertyCollector.RetrieveResult`_:
         retrieved objects or null if there are no matching objects.

  Raises:

    `vmodl.query.InvalidProperty`_: 
       See `CreateFilter`_ 

    `vmodl.fault.InvalidArgument`_: 
       if any of the following is true: See `CreateFilter`_ 

    `vmodl.fault.InvalidType`_: 
       See `CreateFilter`_ 

    `vmodl.fault.ManagedObjectNotFound`_: 
       See `CreateFilter`_ 


ContinueRetrievePropertiesEx(token):
   Retrieves additional results from a retrieval started by `RetrievePropertiesEx`_ on the same session on the same `PropertyCollector`_ .
  since: `vSphere API 4.1`_


  Privilege:
               System.Anonymous



  Args:
    token (`str`_):
       the token returned in the previous `RetrieveResult`_ returned on the same session by the same `PropertyCollector`_ .




  Returns:
    `vmodl.query.PropertyCollector.RetrieveResult`_:
         retrieved objects.

  Raises:

    `vmodl.query.InvalidProperty`_: 
       vmodl.query.InvalidProperty

    `vmodl.fault.InvalidArgument`_: 
       If the token does not match the token from the previous `RetrieveResult`_ returned on the same session by the same `PropertyCollector`_ .


CancelRetrievePropertiesEx(token):
   Discards remaining results from a retrieval started by `RetrievePropertiesEx`_ on the same session on the same `PropertyCollector`_ .
  since: `vSphere API 4.1`_


  Privilege:
               System.Anonymous



  Args:
    token (`str`_):
       the token returned in the previous `RetrieveResult`_ returned on the same session by the same `PropertyCollector`_ .




  Returns:
    None
         

  Raises:

    `vmodl.query.InvalidProperty`_: 
       vmodl.query.InvalidProperty

    `vmodl.fault.InvalidArgument`_: 
       If the token does not match the token from the previous `RetrieveResult`_ returned on the same session by the same `PropertyCollector`_ .


CreatePropertyCollector():
   Creates a new session-specific `PropertyCollector`_ that can be used to retrieve property updates independent of any other `PropertyCollector`_ . The newly created `PropertyCollector`_ is not tied to the creating `PropertyCollector`_ in any way and exists until it is destroyed by a call to `DestroyPropertyCollector`_ or until the session on which the PropertyCollector was created is closed. This is in contrast to the default `PropertyCollector`_ , which always exists, but still has session-specific data such as filters and unfinished update calculations that are discarded when the associated session is closed.A new `PropertyCollector`_ can be useful when multiple modules or even multiple clients that share the same session need to create their own `PropertyFilter`_ objects and process updates independently. They may also be useful to allow important updates to be seen on one `PropertyCollector`_ while a large update is being calculated on another. The underlying issue that this addresses is that any call to `WaitForUpdates`_ , `CheckForUpdates`_ , or `WaitForUpdatesEx`_ does updates on all the filters created on a given `PropertyCollector`_ on a given session.A more subtle use of multiple `PropertyCollector`_ objects is implied by the fact that the returned version value for the various updates calculations is strongly ordered. The only way this can make sense is that two different versions calculated on the same `PropertyCollector`_ on the same session cannot ever be created in parallel. This means that multiple calls to `WaitForUpdates`_ , `CheckForUpdates`_ , or `WaitForUpdatesEx`_ made to the same `PropertyCollector`_ on the same session on different threads of the same client, or even on different clients that share the same session are still handled on the server serially. Use of different `PropertyCollector`_ instances allows the server to handle these calculations in parallel.Typically a service that supports the `PropertyCollector`_ managed object type will automatically create a default `PropertyCollector`_ and provide some way to obtain a reference to this `PropertyCollector`_ . If not, it will have to provide some service-specific way to create the a `PropertyCollector`_ .
  since: `vSphere API 4.1`_


  Privilege:
               System.View



  Args:


  Returns:
    `vmodl.query.PropertyCollector`_:
         A reference to the new `PropertyCollector`_ .


DestroyPropertyCollector():
   Destroys this `PropertyCollector`_ .A `PropertyCollector`_ that was created by `CreatePropertyCollector`_ is automatically destroyed when the session on which it was created is closed. This method can be used to destroy them explicitly.An automatically created `PropertyCollector`_ provided by a service is not session specific and may not be destroyed.
  since: `vSphere API 4.1`_


  Privilege:
               System.View



  Args:


  Returns:
    None
         

  Raises:

    `vmodl.fault.NotSupported`_: 
       if this `PropertyCollector`_ is not allowed to be destroyed.