Merge pull request #4346 from dmkoch/digitalocean-droplet-options

Add "virtio" and "private_networking" options for DigitalOcean droplets
reviewable/pr18780/r1
Michael DeHaan 11 years ago
commit 05251f2745

@ -63,6 +63,18 @@ options:
ssh_key_ids: ssh_key_ids:
description: description:
- Optional, comma separated list of ssh_key_ids that you would like to be added to the server - Optional, comma separated list of ssh_key_ids that you would like to be added to the server
virtio:
description:
- "Bool, turn on virtio driver in droplet for improved network and storage I/O"
version_added: "1.4"
default: "yes"
choices: [ "yes", "no" ]
private_networking:
description:
- "Bool, add an additional, private network interface to droplet for inter-droplet communication"
version_added: "1.4"
default: "no"
choices: [ "yes", "no" ]
wait: wait:
description: description:
- Wait for the droplet to be in state 'running' before returning. If wait is "no" an ip_address may not be returned. - Wait for the droplet to be in state 'running' before returning. If wait is "no" an ip_address may not be returned.
@ -148,9 +160,14 @@ import os
import time import time
try: try:
import dopy
from dopy.manager import DoError, DoManager from dopy.manager import DoError, DoManager
except ImportError as e: except ImportError as e:
print "failed=True msg='dopy required for this module'" print "failed=True msg='dopy >= 0.2.2 required for this module'"
sys.exit(1)
if dopy.__version__ < '0.2.2':
print "failed=True msg='dopy >= 0.2.2 required for this module'"
sys.exit(1) sys.exit(1)
class TimeoutError(DoError): class TimeoutError(DoError):
@ -211,8 +228,8 @@ class Droplet(JsonfyMixIn):
cls.manager = DoManager(client_id, api_key) cls.manager = DoManager(client_id, api_key)
@classmethod @classmethod
def add(cls, name, size_id, image_id, region_id, ssh_key_ids=None): def add(cls, name, size_id, image_id, region_id, ssh_key_ids=None, virtio=True, private_networking=False):
json = cls.manager.new_droplet(name, size_id, image_id, region_id, ssh_key_ids) json = cls.manager.new_droplet(name, size_id, image_id, region_id, ssh_key_ids, virtio, private_networking)
droplet = cls(json) droplet = cls(json)
return droplet return droplet
@ -313,7 +330,9 @@ def core(module):
size_id=getkeyordie('size_id'), size_id=getkeyordie('size_id'),
image_id=getkeyordie('image_id'), image_id=getkeyordie('image_id'),
region_id=getkeyordie('region_id'), region_id=getkeyordie('region_id'),
ssh_key_ids=module.params['ssh_key_ids'] ssh_key_ids=module.params['ssh_key_ids'],
virtio=module.params['virtio'],
private_networking=module.params['private_networking']
) )
if droplet.is_powered_on(): if droplet.is_powered_on():
@ -372,6 +391,8 @@ def main():
image_id = dict(type='int'), image_id = dict(type='int'),
region_id = dict(type='int'), region_id = dict(type='int'),
ssh_key_ids = dict(default=''), ssh_key_ids = dict(default=''),
virtio = dict(type='bool', choices=BOOLEANS, default='yes'),
private_networking = dict(type='bool', choices=BOOLEANS, default='no'),
id = dict(aliases=['droplet_id'], type='int'), id = dict(aliases=['droplet_id'], type='int'),
unique_name = dict(type='bool', default='no'), unique_name = dict(type='bool', default='no'),
wait = dict(type='bool', default=True), wait = dict(type='bool', default=True),

Loading…
Cancel
Save