Skip to content

Instantly share code, notes, and snippets.

@hartsock
Created June 5, 2014 17:08
Show Gist options
  • Select an option

  • Save hartsock/fc0d69fa3124639bc631 to your computer and use it in GitHub Desktop.

Select an option

Save hartsock/fc0d69fa3124639bc631 to your computer and use it in GitHub Desktop.
pyVmomi sample (no dependencies) that demonstrates working with tasks
#!/usr/bin/env python
# VMware vSphere Python SDK
# Copyright (c) 2008-2013 VMware, Inc. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""
A Python script for changing the name of an object. Demonstrates the use
of tasks in an asynchronous way.
"""
import atexit
import argparse
import getpass
import sys
import time
from pyVim import connect
from pyVmomi import vim
def get_args():
parser = argparse.ArgumentParser()
parser.add_argument('-s', '--host',
required=True,
action='store',
help='Remote host to connect to')
parser.add_argument('-u', '--user',
required=True,
action='store',
help='User name to use when connecting to host')
parser.add_argument('-p', '--password',
required=False,
action='store',
help='Password to use when connecting to host')
parser.add_argument('-o', '--port',
required=False,
action='store',
help="port to use, default 443", default=443)
parser.add_argument('-n', '--name',
required=True,
action='store',
help='Name of the entity to look for.')
parser.add_argument('-r', '--new_name',
required=False,
action='store',
help='New name of the entity.')
args = parser.parse_args()
if args.password is None:
args.password = getpass.getpass(
prompt='Enter password for host %s and user %s: ' %
(args.host, args.user))
args = parser.parse_args()
return args
args = get_args()
# form a connection...
si = connect.SmartConnect(host=args.host, user=args.user, pwd=args.password,
port=args.port)
# doing this means you don't need to remember to disconnect your script/objects
atexit.register(connect.Disconnect, si)
# search the whole inventory tree recursively... a brutish but effective tactic
root_folder = si.content.rootFolder
entity_stack = root_folder.childEntity
name = args.name
object = None
while entity_stack:
entity = entity_stack.pop()
if entity.name == name:
object = entity
break
elif isinstance(entity, vim.Datacenter):
# add this vim.DataCenter's folders to our search
# we don't know the entity's type so we have to scan
# each potential folder...
entity_stack.append(entity.datastoreFolder)
entity_stack.append(entity.hostFolder)
entity_stack.append(entity.networkFolder)
entity_stack.append(entity.vmFolder)
elif isinstance(entity, vim.Folder):
# add all child entities from this folder to our search
entity_stack.extend(entity.childEntity)
if object is None:
print "A object named %s could not be found" % args.name
exit()
if args.new_name:
new_name = args.new_name
else:
# just because we want the script to do *something*
new_name = args.name + "0"
print
print "name : %s" % object.name
print
print " renaming from %s to %s" % (args.name, new_name)
print
# rename creates a task...
task = object.Rename(new_name)
# Did you know that task objects in pyVmomi get updates automatically?
# Check this out... it's not super efficient but here's how you could
# have a script that looped waiting on a task but still had the
# chance to periodically check other things or do other actions...
print "rename task state:"
count = 0
state = task.info.state
while task.info.state != vim.TaskInfo.State.success:
sys.stdout.write("\r\t" + str(time.time()) + "\t: " + task.info.state)
sys.stdout.flush()
count += 1
print
print "rename finished"
print
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment