X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=juju%2Fmachine.py;h=04abc3b9d8ac64d525d936353995ae1099850498;hb=c82b09f55dddef7a72885713bcfd272af479fb5a;hp=4bc8ff6de0f5ce6045cc24f93e72eb22f510a7a7;hpb=596ccbe375a3a45e1625b798bb42da3df284ed09;p=osm%2FN2VC.git diff --git a/juju/machine.py b/juju/machine.py index 4bc8ff6..04abc3b 100644 --- a/juju/machine.py +++ b/juju/machine.py @@ -1,4 +1,25 @@ -class Machine(object): +import logging + +from . import model +from .client import client + +log = logging.getLogger(__name__) + + +class Machine(model.ModelEntity): + async def destroy(self, force=False): + """Remove this machine from the model. + + """ + facade = client.ClientFacade() + facade.connect(self.connection) + + log.debug( + 'Destroying machine %s', self.id) + + return await facade.DestroyMachines(force, [self.id]) + remove = destroy + def run(self, command, timeout=None): """Run command on this machine. @@ -8,6 +29,24 @@ class Machine(object): """ pass + async def set_annotations(self, annotations): + """Set annotations on this machine. + + :param annotations map[string]string: the annotations as key/value + pairs. + + """ + log.debug('Updating annotations on machine %s', self.id) + + self.ann_facade = client.AnnotationsFacade() + self.ann_facade.connect(self.connection) + + ann = client.EntityAnnotations( + entity=self.id, + annotations=annotations, + ) + return await self.ann_facade.Set([ann]) + def scp( self, source_path, user=None, destination_path=None, proxy=False, scp_opts=None):