Merge pull request #4346 from dmkoch/digitalocean-droplet-options
Add "virtio" and "private_networking" options for DigitalOcean droplets
This commit is contained in:
commit
84ff24d92c
1 changed files with 25 additions and 4 deletions
|
@ -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…
Reference in a new issue