Regen schema to pick up missing APIs
[osm/N2VC.git] / juju / client / _client.py
index b2f1682..0847da6 100644 (file)
@@ -5,8 +5,8 @@ from juju.client.facade import Type, ReturnMapping
 
 
 class Action(Type):
-    _toSchema = {'name': 'name', 'receiver': 'receiver', 'tag': 'tag', 'parameters': 'parameters'}
-    _toPy = {'name': 'name', 'receiver': 'receiver', 'tag': 'tag', 'parameters': 'parameters'}
+    _toSchema = {'name': 'name', 'parameters': 'parameters', 'receiver': 'receiver', 'tag': 'tag'}
+    _toPy = {'name': 'name', 'parameters': 'parameters', 'receiver': 'receiver', 'tag': 'tag'}
     def __init__(self, name=None, parameters=None, receiver=None, tag=None):
         '''
         name : str
@@ -21,8 +21,8 @@ class Action(Type):
 
 
 class ActionResult(Type):
-    _toSchema = {'started': 'started', 'error': 'error', 'message': 'message', 'status': 'status', 'enqueued': 'enqueued', 'action': 'action', 'completed': 'completed', 'output': 'output'}
-    _toPy = {'started': 'started', 'error': 'error', 'message': 'message', 'status': 'status', 'enqueued': 'enqueued', 'action': 'action', 'completed': 'completed', 'output': 'output'}
+    _toSchema = {'action': 'action', 'completed': 'completed', 'enqueued': 'enqueued', 'error': 'error', 'message': 'message', 'output': 'output', 'started': 'started', 'status': 'status'}
+    _toPy = {'action': 'action', 'completed': 'completed', 'enqueued': 'enqueued', 'error': 'error', 'message': 'message', 'output': 'output', 'started': 'started', 'status': 'status'}
     def __init__(self, action=None, completed=None, enqueued=None, error=None, message=None, output=None, started=None, status=None):
         '''
         action : Action
@@ -77,8 +77,8 @@ class Actions(Type):
 
 
 class ActionsByName(Type):
-    _toSchema = {'name': 'name', 'actions': 'actions', 'error': 'error'}
-    _toPy = {'name': 'name', 'actions': 'actions', 'error': 'error'}
+    _toSchema = {'actions': 'actions', 'error': 'error', 'name': 'name'}
+    _toPy = {'actions': 'actions', 'error': 'error', 'name': 'name'}
     def __init__(self, actions=None, error=None, name=None):
         '''
         actions : typing.Sequence<+T_co>[~ActionResult]<~ActionResult>
@@ -101,8 +101,8 @@ class ActionsByNames(Type):
 
 
 class ActionsByReceiver(Type):
-    _toSchema = {'receiver': 'receiver', 'actions': 'actions', 'error': 'error'}
-    _toPy = {'receiver': 'receiver', 'actions': 'actions', 'error': 'error'}
+    _toSchema = {'actions': 'actions', 'error': 'error', 'receiver': 'receiver'}
+    _toPy = {'actions': 'actions', 'error': 'error', 'receiver': 'receiver'}
     def __init__(self, actions=None, error=None, receiver=None):
         '''
         actions : typing.Sequence<+T_co>[~ActionResult]<~ActionResult>
@@ -125,8 +125,8 @@ class ActionsByReceivers(Type):
 
 
 class ApplicationCharmActionsResult(Type):
-    _toSchema = {'error': 'error', 'actions': 'actions', 'application_tag': 'application-tag'}
-    _toPy = {'application-tag': 'application_tag', 'actions': 'actions', 'error': 'error'}
+    _toSchema = {'actions': 'actions', 'application_tag': 'application-tag', 'error': 'error'}
+    _toPy = {'actions': 'actions', 'application-tag': 'application_tag', 'error': 'error'}
     def __init__(self, actions=None, application_tag=None, error=None):
         '''
         actions : typing.Mapping<~KT, +VT_co>[str, ~ActionSpec]<~ActionSpec>
@@ -169,8 +169,8 @@ class Entity(Type):
 
 
 class Error(Type):
-    _toSchema = {'info': 'info', 'code': 'code', 'message': 'message'}
-    _toPy = {'info': 'info', 'code': 'code', 'message': 'message'}
+    _toSchema = {'code': 'code', 'info': 'info', 'message': 'message'}
+    _toPy = {'code': 'code', 'info': 'info', 'message': 'message'}
     def __init__(self, code=None, info=None, message=None):
         '''
         code : str
@@ -184,7 +184,7 @@ class Error(Type):
 
 class ErrorInfo(Type):
     _toSchema = {'macaroon': 'macaroon', 'macaroon_path': 'macaroon-path'}
-    _toPy = {'macaroon-path': 'macaroon_path', 'macaroon': 'macaroon'}
+    _toPy = {'macaroon': 'macaroon', 'macaroon-path': 'macaroon_path'}
     def __init__(self, macaroon=None, macaroon_path=None):
         '''
         macaroon : Macaroon
@@ -235,8 +235,8 @@ class Macaroon(Type):
 
 
 class RunParams(Type):
-    _toSchema = {'commands': 'commands', 'machines': 'machines', 'units': 'units', 'applications': 'applications', 'timeout': 'timeout'}
-    _toPy = {'commands': 'commands', 'machines': 'machines', 'units': 'units', 'applications': 'applications', 'timeout': 'timeout'}
+    _toSchema = {'applications': 'applications', 'commands': 'commands', 'machines': 'machines', 'timeout': 'timeout', 'units': 'units'}
+    _toPy = {'applications': 'applications', 'commands': 'commands', 'machines': 'machines', 'timeout': 'timeout', 'units': 'units'}
     def __init__(self, applications=None, commands=None, machines=None, timeout=None, units=None):
         '''
         applications : typing.Sequence<+T_co>[str]
@@ -253,8 +253,8 @@ class RunParams(Type):
 
 
 class AgentGetEntitiesResult(Type):
-    _toSchema = {'life': 'life', 'error': 'error', 'jobs': 'jobs', 'container_type': 'container-type'}
-    _toPy = {'life': 'life', 'container-type': 'container_type', 'jobs': 'jobs', 'error': 'error'}
+    _toSchema = {'container_type': 'container-type', 'error': 'error', 'jobs': 'jobs', 'life': 'life'}
+    _toPy = {'container-type': 'container_type', 'error': 'error', 'jobs': 'jobs', 'life': 'life'}
     def __init__(self, container_type=None, error=None, jobs=None, life=None):
         '''
         container_type : str
@@ -279,8 +279,8 @@ class AgentGetEntitiesResults(Type):
 
 
 class CloudCredential(Type):
-    _toSchema = {'auth_type': 'auth-type', 'attrs': 'attrs', 'redacted': 'redacted'}
-    _toPy = {'auth-type': 'auth_type', 'attrs': 'attrs', 'redacted': 'redacted'}
+    _toSchema = {'attrs': 'attrs', 'auth_type': 'auth-type', 'redacted': 'redacted'}
+    _toPy = {'attrs': 'attrs', 'auth-type': 'auth_type', 'redacted': 'redacted'}
     def __init__(self, attrs=None, auth_type=None, redacted=None):
         '''
         attrs : typing.Mapping<~KT, +VT_co>[str, str]
@@ -293,8 +293,8 @@ class CloudCredential(Type):
 
 
 class CloudSpec(Type):
-    _toSchema = {'type_': 'type', 'identity_endpoint': 'identity-endpoint', 'storage_endpoint': 'storage-endpoint', 'region': 'region', 'name': 'name', 'endpoint': 'endpoint', 'credential': 'credential'}
-    _toPy = {'region': 'region', 'name': 'name', 'type': 'type_', 'identity-endpoint': 'identity_endpoint', 'endpoint': 'endpoint', 'credential': 'credential', 'storage-endpoint': 'storage_endpoint'}
+    _toSchema = {'credential': 'credential', 'endpoint': 'endpoint', 'identity_endpoint': 'identity-endpoint', 'name': 'name', 'region': 'region', 'storage_endpoint': 'storage-endpoint', 'type_': 'type'}
+    _toPy = {'credential': 'credential', 'endpoint': 'endpoint', 'identity-endpoint': 'identity_endpoint', 'name': 'name', 'region': 'region', 'storage-endpoint': 'storage_endpoint', 'type': 'type_'}
     def __init__(self, credential=None, endpoint=None, identity_endpoint=None, name=None, region=None, storage_endpoint=None, type_=None):
         '''
         credential : CloudCredential
@@ -315,8 +315,8 @@ class CloudSpec(Type):
 
 
 class CloudSpecResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -347,8 +347,8 @@ class ControllerConfigResult(Type):
 
 
 class EntityPassword(Type):
-    _toSchema = {'tag': 'tag', 'password': 'password'}
-    _toPy = {'tag': 'tag', 'password': 'password'}
+    _toSchema = {'password': 'password', 'tag': 'tag'}
+    _toPy = {'password': 'password', 'tag': 'tag'}
     def __init__(self, password=None, tag=None):
         '''
         password : str
@@ -369,17 +369,13 @@ class EntityPasswords(Type):
 
 
 class ErrorResult(Type):
-    _toSchema = {'info': 'info', 'code': 'code', 'message': 'message'}
-    _toPy = {'info': 'info', 'code': 'code', 'message': 'message'}
-    def __init__(self, code=None, info=None, message=None):
+    _toSchema = {'error': 'error'}
+    _toPy = {'error': 'error'}
+    def __init__(self, error=None):
         '''
-        code : str
-        info : ErrorInfo
-        message : str
+        error : Error
         '''
-        self.code = code
-        self.info = ErrorInfo.from_json(info) if info else None
-        self.message = message
+        self.error = Error.from_json(error) if error else None
 
 
 class ErrorResults(Type):
@@ -412,8 +408,18 @@ class ModelConfigResult(Type):
         self.config = config
 
 
+class ModelTag(Type):
+    _toSchema = {}
+    _toPy = {}
+    def __init__(self):
+        '''
+
+        '''
+        pass
+
+
 class NotifyWatchResult(Type):
-    _toSchema = {'notifywatcherid': 'NotifyWatcherId', 'error': 'error'}
+    _toSchema = {'error': 'error', 'notifywatcherid': 'NotifyWatcherId'}
     _toPy = {'NotifyWatcherId': 'notifywatcherid', 'error': 'error'}
     def __init__(self, notifywatcherid=None, error=None):
         '''
@@ -424,9 +430,19 @@ class NotifyWatchResult(Type):
         self.error = Error.from_json(error) if error else None
 
 
+class NotifyWatchResults(Type):
+    _toSchema = {'results': 'results'}
+    _toPy = {'results': 'results'}
+    def __init__(self, results=None):
+        '''
+        results : typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
+        '''
+        self.results = [NotifyWatchResult.from_json(o) for o in results or []]
+
+
 class StateServingInfo(Type):
-    _toSchema = {'state_port': 'state-port', 'system_identity': 'system-identity', 'api_port': 'api-port', 'cert': 'cert', 'shared_secret': 'shared-secret', 'private_key': 'private-key', 'ca_private_key': 'ca-private-key'}
-    _toPy = {'shared-secret': 'shared_secret', 'state-port': 'state_port', 'cert': 'cert', 'ca-private-key': 'ca_private_key', 'api-port': 'api_port', 'system-identity': 'system_identity', 'private-key': 'private_key'}
+    _toSchema = {'api_port': 'api-port', 'ca_private_key': 'ca-private-key', 'cert': 'cert', 'private_key': 'private-key', 'shared_secret': 'shared-secret', 'state_port': 'state-port', 'system_identity': 'system-identity'}
+    _toPy = {'api-port': 'api_port', 'ca-private-key': 'ca_private_key', 'cert': 'cert', 'private-key': 'private_key', 'shared-secret': 'shared_secret', 'state-port': 'state_port', 'system-identity': 'system_identity'}
     def __init__(self, api_port=None, ca_private_key=None, cert=None, private_key=None, shared_secret=None, state_port=None, system_identity=None):
         '''
         api_port : int
@@ -469,8 +485,8 @@ class Delta(Type):
 
 
 class AnnotationsGetResult(Type):
-    _toSchema = {'entity': 'entity', 'annotations': 'annotations', 'error': 'error'}
-    _toPy = {'entity': 'entity', 'annotations': 'annotations', 'error': 'error'}
+    _toSchema = {'annotations': 'annotations', 'entity': 'entity', 'error': 'error'}
+    _toPy = {'annotations': 'annotations', 'entity': 'entity', 'error': 'error'}
     def __init__(self, annotations=None, entity=None, error=None):
         '''
         annotations : typing.Mapping<~KT, +VT_co>[str, str]
@@ -503,8 +519,8 @@ class AnnotationsSet(Type):
 
 
 class EntityAnnotations(Type):
-    _toSchema = {'entity': 'entity', 'annotations': 'annotations'}
-    _toPy = {'entity': 'entity', 'annotations': 'annotations'}
+    _toSchema = {'annotations': 'annotations', 'entity': 'entity'}
+    _toPy = {'annotations': 'annotations', 'entity': 'entity'}
     def __init__(self, annotations=None, entity=None):
         '''
         annotations : typing.Mapping<~KT, +VT_co>[str, str]
@@ -515,8 +531,8 @@ class EntityAnnotations(Type):
 
 
 class AddApplicationUnits(Type):
-    _toSchema = {'application': 'application', 'placement': 'placement', 'num_units': 'num-units'}
-    _toPy = {'application': 'application', 'placement': 'placement', 'num-units': 'num_units'}
+    _toSchema = {'application': 'application', 'num_units': 'num-units', 'placement': 'placement'}
+    _toPy = {'application': 'application', 'num-units': 'num_units', 'placement': 'placement'}
     def __init__(self, application=None, num_units=None, placement=None):
         '''
         application : str
@@ -579,8 +595,8 @@ class ApplicationCharmRelationsResults(Type):
 
 
 class ApplicationDeploy(Type):
-    _toSchema = {'application': 'application', 'charm_url': 'charm-url', 'channel': 'channel', 'resources': 'resources', 'placement': 'placement', 'config_yaml': 'config-yaml', 'config': 'config', 'constraints': 'constraints', 'num_units': 'num-units', 'storage': 'storage', 'endpoint_bindings': 'endpoint-bindings', 'series': 'series'}
-    _toPy = {'application': 'application', 'num-units': 'num_units', 'channel': 'channel', 'resources': 'resources', 'placement': 'placement', 'endpoint-bindings': 'endpoint_bindings', 'config': 'config', 'constraints': 'constraints', 'series': 'series', 'storage': 'storage', 'charm-url': 'charm_url', 'config-yaml': 'config_yaml'}
+    _toSchema = {'application': 'application', 'channel': 'channel', 'charm_url': 'charm-url', 'config': 'config', 'config_yaml': 'config-yaml', 'constraints': 'constraints', 'endpoint_bindings': 'endpoint-bindings', 'num_units': 'num-units', 'placement': 'placement', 'resources': 'resources', 'series': 'series', 'storage': 'storage'}
+    _toPy = {'application': 'application', 'channel': 'channel', 'charm-url': 'charm_url', 'config': 'config', 'config-yaml': 'config_yaml', 'constraints': 'constraints', 'endpoint-bindings': 'endpoint_bindings', 'num-units': 'num_units', 'placement': 'placement', 'resources': 'resources', 'series': 'series', 'storage': 'storage'}
     def __init__(self, application=None, channel=None, charm_url=None, config=None, config_yaml=None, constraints=None, endpoint_bindings=None, num_units=None, placement=None, resources=None, series=None, storage=None):
         '''
         application : str
@@ -641,8 +657,8 @@ class ApplicationGet(Type):
 
 
 class ApplicationGetResults(Type):
-    _toSchema = {'application': 'application', 'config': 'config', 'charm': 'charm', 'constraints': 'constraints', 'series': 'series'}
-    _toPy = {'application': 'application', 'config': 'config', 'charm': 'charm', 'constraints': 'constraints', 'series': 'series'}
+    _toSchema = {'application': 'application', 'charm': 'charm', 'config': 'config', 'constraints': 'constraints', 'series': 'series'}
+    _toPy = {'application': 'application', 'charm': 'charm', 'config': 'config', 'constraints': 'constraints', 'series': 'series'}
     def __init__(self, application=None, charm=None, config=None, constraints=None, series=None):
         '''
         application : str
@@ -693,23 +709,29 @@ class ApplicationSet(Type):
 
 
 class ApplicationSetCharm(Type):
-    _toSchema = {'application': 'application', 'charm_url': 'charm-url', 'channel': 'channel', 'force_units': 'force-units', 'force_series': 'force-series', 'resource_ids': 'resource-ids'}
-    _toPy = {'application': 'application', 'force-units': 'force_units', 'channel': 'channel', 'charm-url': 'charm_url', 'force-series': 'force_series', 'resource-ids': 'resource_ids'}
-    def __init__(self, application=None, channel=None, charm_url=None, force_series=None, force_units=None, resource_ids=None):
+    _toSchema = {'application': 'application', 'channel': 'channel', 'charm_url': 'charm-url', 'config_settings': 'config-settings', 'config_settings_yaml': 'config-settings-yaml', 'force_series': 'force-series', 'force_units': 'force-units', 'resource_ids': 'resource-ids', 'storage_constraints': 'storage-constraints'}
+    _toPy = {'application': 'application', 'channel': 'channel', 'charm-url': 'charm_url', 'config-settings': 'config_settings', 'config-settings-yaml': 'config_settings_yaml', 'force-series': 'force_series', 'force-units': 'force_units', 'resource-ids': 'resource_ids', 'storage-constraints': 'storage_constraints'}
+    def __init__(self, application=None, channel=None, charm_url=None, config_settings=None, config_settings_yaml=None, force_series=None, force_units=None, resource_ids=None, storage_constraints=None):
         '''
         application : str
         channel : str
         charm_url : str
+        config_settings : typing.Mapping<~KT, +VT_co>[str, str]
+        config_settings_yaml : str
         force_series : bool
         force_units : bool
         resource_ids : typing.Mapping<~KT, +VT_co>[str, str]
+        storage_constraints : typing.Mapping<~KT, +VT_co>[str, ~StorageConstraints]<~StorageConstraints>
         '''
         self.application = application
         self.channel = channel
         self.charm_url = charm_url
+        self.config_settings = config_settings
+        self.config_settings_yaml = config_settings_yaml
         self.force_series = force_series
         self.force_units = force_units
         self.resource_ids = resource_ids
+        self.storage_constraints = storage_constraints
 
 
 class ApplicationUnexpose(Type):
@@ -735,8 +757,8 @@ class ApplicationUnset(Type):
 
 
 class ApplicationUpdate(Type):
-    _toSchema = {'application': 'application', 'charm_url': 'charm-url', 'constraints': 'constraints', 'settings_yaml': 'settings-yaml', 'min_units': 'min-units', 'settings': 'settings', 'force_series': 'force-series', 'force_charm_url': 'force-charm-url'}
-    _toPy = {'application': 'application', 'constraints': 'constraints', 'settings-yaml': 'settings_yaml', 'min-units': 'min_units', 'charm-url': 'charm_url', 'force-series': 'force_series', 'settings': 'settings', 'force-charm-url': 'force_charm_url'}
+    _toSchema = {'application': 'application', 'charm_url': 'charm-url', 'constraints': 'constraints', 'force_charm_url': 'force-charm-url', 'force_series': 'force-series', 'min_units': 'min-units', 'settings': 'settings', 'settings_yaml': 'settings-yaml'}
+    _toPy = {'application': 'application', 'charm-url': 'charm_url', 'constraints': 'constraints', 'force-charm-url': 'force_charm_url', 'force-series': 'force_series', 'min-units': 'min_units', 'settings': 'settings', 'settings-yaml': 'settings_yaml'}
     def __init__(self, application=None, charm_url=None, constraints=None, force_charm_url=None, force_series=None, min_units=None, settings=None, settings_yaml=None):
         '''
         application : str
@@ -769,8 +791,8 @@ class ApplicationsDeploy(Type):
 
 
 class CharmRelation(Type):
-    _toSchema = {'limit': 'limit', 'role': 'role', 'scope': 'scope', 'optional': 'optional', 'name': 'name', 'interface': 'interface'}
-    _toPy = {'limit': 'limit', 'role': 'role', 'scope': 'scope', 'optional': 'optional', 'name': 'name', 'interface': 'interface'}
+    _toSchema = {'interface': 'interface', 'limit': 'limit', 'name': 'name', 'optional': 'optional', 'role': 'role', 'scope': 'scope'}
+    _toPy = {'interface': 'interface', 'limit': 'limit', 'name': 'name', 'optional': 'optional', 'role': 'role', 'scope': 'scope'}
     def __init__(self, interface=None, limit=None, name=None, optional=None, role=None, scope=None):
         '''
         interface : str
@@ -789,8 +811,8 @@ class CharmRelation(Type):
 
 
 class Constraints(Type):
-    _toSchema = {'size': 'Size', 'pool': 'Pool', 'count': 'Count'}
-    _toPy = {'Size': 'size', 'Count': 'count', 'Pool': 'pool'}
+    _toSchema = {'count': 'Count', 'pool': 'Pool', 'size': 'Size'}
+    _toPy = {'Count': 'count', 'Pool': 'pool', 'Size': 'size'}
     def __init__(self, count=None, pool=None, size=None):
         '''
         count : int
@@ -833,31 +855,13 @@ class GetApplicationConstraints(Type):
 
 
 class GetConstraintsResults(Type):
-    _toSchema = {'cpu_power': 'cpu-power', 'instance_type': 'instance-type', 'tags': 'tags', 'virt_type': 'virt-type', 'arch': 'arch', 'container': 'container', 'root_disk': 'root-disk', 'mem': 'mem', 'cpu_cores': 'cpu-cores', 'spaces': 'spaces'}
-    _toPy = {'virt-type': 'virt_type', 'cpu-power': 'cpu_power', 'container': 'container', 'cpu-cores': 'cpu_cores', 'arch': 'arch', 'tags': 'tags', 'mem': 'mem', 'spaces': 'spaces', 'instance-type': 'instance_type', 'root-disk': 'root_disk'}
-    def __init__(self, arch=None, container=None, cpu_cores=None, cpu_power=None, instance_type=None, mem=None, root_disk=None, spaces=None, tags=None, virt_type=None):
+    _toSchema = {'constraints': 'constraints'}
+    _toPy = {'constraints': 'constraints'}
+    def __init__(self, constraints=None):
         '''
-        arch : str
-        container : str
-        cpu_cores : int
-        cpu_power : int
-        instance_type : str
-        mem : int
-        root_disk : int
-        spaces : typing.Sequence<+T_co>[str]
-        tags : typing.Sequence<+T_co>[str]
-        virt_type : str
+        constraints : Value
         '''
-        self.arch = arch
-        self.container = container
-        self.cpu_cores = cpu_cores
-        self.cpu_power = cpu_power
-        self.instance_type = instance_type
-        self.mem = mem
-        self.root_disk = root_disk
-        self.spaces = spaces
-        self.tags = tags
-        self.virt_type = virt_type
+        self.constraints = Value.from_json(constraints) if constraints else None
 
 
 class Placement(Type):
@@ -884,9 +888,23 @@ class SetConstraints(Type):
         self.constraints = Value.from_json(constraints) if constraints else None
 
 
+class StorageConstraints(Type):
+    _toSchema = {'count': 'count', 'pool': 'pool', 'size': 'size'}
+    _toPy = {'count': 'count', 'pool': 'pool', 'size': 'size'}
+    def __init__(self, count=None, pool=None, size=None):
+        '''
+        count : int
+        pool : str
+        size : int
+        '''
+        self.count = count
+        self.pool = pool
+        self.size = size
+
+
 class StringResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -897,13 +915,13 @@ class StringResult(Type):
 
 
 class Value(Type):
-    _toSchema = {'cpu_power': 'cpu-power', 'instance_type': 'instance-type', 'tags': 'tags', 'virt_type': 'virt-type', 'arch': 'arch', 'container': 'container', 'root_disk': 'root-disk', 'mem': 'mem', 'cpu_cores': 'cpu-cores', 'spaces': 'spaces'}
-    _toPy = {'virt-type': 'virt_type', 'cpu-power': 'cpu_power', 'container': 'container', 'cpu-cores': 'cpu_cores', 'arch': 'arch', 'tags': 'tags', 'mem': 'mem', 'spaces': 'spaces', 'instance-type': 'instance_type', 'root-disk': 'root_disk'}
-    def __init__(self, arch=None, container=None, cpu_cores=None, cpu_power=None, instance_type=None, mem=None, root_disk=None, spaces=None, tags=None, virt_type=None):
+    _toSchema = {'arch': 'arch', 'container': 'container', 'cores': 'cores', 'cpu_power': 'cpu-power', 'instance_type': 'instance-type', 'mem': 'mem', 'root_disk': 'root-disk', 'spaces': 'spaces', 'tags': 'tags', 'virt_type': 'virt-type'}
+    _toPy = {'arch': 'arch', 'container': 'container', 'cores': 'cores', 'cpu-power': 'cpu_power', 'instance-type': 'instance_type', 'mem': 'mem', 'root-disk': 'root_disk', 'spaces': 'spaces', 'tags': 'tags', 'virt-type': 'virt_type'}
+    def __init__(self, arch=None, container=None, cores=None, cpu_power=None, instance_type=None, mem=None, root_disk=None, spaces=None, tags=None, virt_type=None):
         '''
         arch : str
         container : str
-        cpu_cores : int
+        cores : int
         cpu_power : int
         instance_type : str
         mem : int
@@ -914,7 +932,7 @@ class Value(Type):
         '''
         self.arch = arch
         self.container = container
-        self.cpu_cores = cpu_cores
+        self.cores = cores
         self.cpu_power = cpu_power
         self.instance_type = instance_type
         self.mem = mem
@@ -925,8 +943,8 @@ class Value(Type):
 
 
 class StringsWatchResult(Type):
-    _toSchema = {'changes': 'changes', 'watcher_id': 'watcher-id', 'error': 'error'}
-    _toPy = {'watcher-id': 'watcher_id', 'changes': 'changes', 'error': 'error'}
+    _toSchema = {'changes': 'changes', 'error': 'error', 'watcher_id': 'watcher-id'}
+    _toPy = {'changes': 'changes', 'error': 'error', 'watcher-id': 'watcher_id'}
     def __init__(self, changes=None, error=None, watcher_id=None):
         '''
         changes : typing.Sequence<+T_co>[str]
@@ -979,8 +997,8 @@ class BackupsListResult(Type):
 
 
 class BackupsMetadataResult(Type):
-    _toSchema = {'ca_private_key': 'ca-private-key', 'size': 'size', 'started': 'started', 'id_': 'id', 'checksum': 'checksum', 'finished': 'finished', 'hostname': 'hostname', 'stored': 'stored', 'series': 'series', 'machine': 'machine', 'notes': 'notes', 'ca_cert': 'ca-cert', 'checksum_format': 'checksum-format', 'model': 'model', 'version': 'version'}
-    _toPy = {'started': 'started', 'size': 'size', 'ca-cert': 'ca_cert', 'ca-private-key': 'ca_private_key', 'checksum': 'checksum', 'machine': 'machine', 'finished': 'finished', 'hostname': 'hostname', 'stored': 'stored', 'series': 'series', 'notes': 'notes', 'id': 'id_', 'checksum-format': 'checksum_format', 'model': 'model', 'version': 'version'}
+    _toSchema = {'ca_cert': 'ca-cert', 'ca_private_key': 'ca-private-key', 'checksum': 'checksum', 'checksum_format': 'checksum-format', 'finished': 'finished', 'hostname': 'hostname', 'id_': 'id', 'machine': 'machine', 'model': 'model', 'notes': 'notes', 'series': 'series', 'size': 'size', 'started': 'started', 'stored': 'stored', 'version': 'version'}
+    _toPy = {'ca-cert': 'ca_cert', 'ca-private-key': 'ca_private_key', 'checksum': 'checksum', 'checksum-format': 'checksum_format', 'finished': 'finished', 'hostname': 'hostname', 'id': 'id_', 'machine': 'machine', 'model': 'model', 'notes': 'notes', 'series': 'series', 'size': 'size', 'started': 'started', 'stored': 'stored', 'version': 'version'}
     def __init__(self, ca_cert=None, ca_private_key=None, checksum=None, checksum_format=None, finished=None, hostname=None, id_=None, machine=None, model=None, notes=None, series=None, size=None, started=None, stored=None, version=None):
         '''
         ca_cert : str
@@ -1027,8 +1045,8 @@ class BackupsRemoveArgs(Type):
 
 
 class Number(Type):
-    _toSchema = {'build': 'Build', 'patch': 'Patch', 'tag': 'Tag', 'minor': 'Minor', 'major': 'Major'}
-    _toPy = {'Tag': 'tag', 'Major': 'major', 'Patch': 'patch', 'Minor': 'minor', 'Build': 'build'}
+    _toSchema = {'build': 'Build', 'major': 'Major', 'minor': 'Minor', 'patch': 'Patch', 'tag': 'Tag'}
+    _toPy = {'Build': 'build', 'Major': 'major', 'Minor': 'minor', 'Patch': 'patch', 'Tag': 'tag'}
     def __init__(self, build=None, major=None, minor=None, patch=None, tag=None):
         '''
         build : int
@@ -1055,8 +1073,8 @@ class RestoreArgs(Type):
 
 
 class Block(Type):
-    _toSchema = {'tag': 'tag', 'type_': 'type', 'id_': 'id', 'message': 'message'}
-    _toPy = {'type': 'type_', 'id': 'id_', 'tag': 'tag', 'message': 'message'}
+    _toSchema = {'id_': 'id', 'message': 'message', 'tag': 'tag', 'type_': 'type'}
+    _toPy = {'id': 'id_', 'message': 'message', 'tag': 'tag', 'type': 'type_'}
     def __init__(self, id_=None, message=None, tag=None, type_=None):
         '''
         id_ : str
@@ -1071,8 +1089,8 @@ class Block(Type):
 
 
 class BlockResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -1093,8 +1111,8 @@ class BlockResults(Type):
 
 
 class BlockSwitchParams(Type):
-    _toSchema = {'type_': 'type', 'message': 'message'}
-    _toPy = {'type': 'type_', 'message': 'message'}
+    _toSchema = {'message': 'message', 'type_': 'type'}
+    _toPy = {'message': 'message', 'type': 'type_'}
     def __init__(self, message=None, type_=None):
         '''
         message : str
@@ -1104,6 +1122,44 @@ class BlockSwitchParams(Type):
         self.type_ = type_
 
 
+class BundleChange(Type):
+    _toSchema = {'args': 'args', 'id_': 'id', 'method': 'method', 'requires': 'requires'}
+    _toPy = {'args': 'args', 'id': 'id_', 'method': 'method', 'requires': 'requires'}
+    def __init__(self, args=None, id_=None, method=None, requires=None):
+        '''
+        args : typing.Sequence<+T_co>[typing.Any]
+        id_ : str
+        method : str
+        requires : typing.Sequence<+T_co>[str]
+        '''
+        self.args = args
+        self.id_ = id_
+        self.method = method
+        self.requires = requires
+
+
+class BundleChangesParams(Type):
+    _toSchema = {'yaml': 'yaml'}
+    _toPy = {'yaml': 'yaml'}
+    def __init__(self, yaml=None):
+        '''
+        yaml : str
+        '''
+        self.yaml = yaml
+
+
+class BundleChangesResults(Type):
+    _toSchema = {'changes': 'changes', 'errors': 'errors'}
+    _toPy = {'changes': 'changes', 'errors': 'errors'}
+    def __init__(self, changes=None, errors=None):
+        '''
+        changes : typing.Sequence<+T_co>[~BundleChange]<~BundleChange>
+        errors : typing.Sequence<+T_co>[str]
+        '''
+        self.changes = [BundleChange.from_json(o) for o in changes or []]
+        self.errors = errors
+
+
 class CharmActionSpec(Type):
     _toSchema = {'description': 'description', 'params': 'params'}
     _toPy = {'description': 'description', 'params': 'params'}
@@ -1127,8 +1183,8 @@ class CharmActions(Type):
 
 
 class CharmInfo(Type):
-    _toSchema = {'config': 'config', 'actions': 'actions', 'revision': 'revision', 'metrics': 'metrics', 'url': 'url', 'meta': 'meta'}
-    _toPy = {'config': 'config', 'actions': 'actions', 'revision': 'revision', 'metrics': 'metrics', 'url': 'url', 'meta': 'meta'}
+    _toSchema = {'actions': 'actions', 'config': 'config', 'meta': 'meta', 'metrics': 'metrics', 'revision': 'revision', 'url': 'url'}
+    _toPy = {'actions': 'actions', 'config': 'config', 'meta': 'meta', 'metrics': 'metrics', 'revision': 'revision', 'url': 'url'}
     def __init__(self, actions=None, config=None, meta=None, metrics=None, revision=None, url=None):
         '''
         actions : CharmActions
@@ -1147,8 +1203,8 @@ class CharmInfo(Type):
 
 
 class CharmMeta(Type):
-    _toSchema = {'description': 'description', 'extra_bindings': 'extra-bindings', 'tags': 'tags', 'min_juju_version': 'min-juju-version', 'payload_classes': 'payload-classes', 'resources': 'resources', 'storage': 'storage', 'subordinate': 'subordinate', 'categories': 'categories', 'terms': 'terms', 'series': 'series', 'peers': 'peers', 'name': 'name', 'requires': 'requires', 'summary': 'summary', 'provides': 'provides'}
-    _toPy = {'description': 'description', 'min-juju-version': 'min_juju_version', 'peers': 'peers', 'provides': 'provides', 'resources': 'resources', 'extra-bindings': 'extra_bindings', 'terms': 'terms', 'subordinate': 'subordinate', 'categories': 'categories', 'series': 'series', 'storage': 'storage', 'name': 'name', 'requires': 'requires', 'summary': 'summary', 'payload-classes': 'payload_classes', 'tags': 'tags'}
+    _toSchema = {'categories': 'categories', 'description': 'description', 'extra_bindings': 'extra-bindings', 'min_juju_version': 'min-juju-version', 'name': 'name', 'payload_classes': 'payload-classes', 'peers': 'peers', 'provides': 'provides', 'requires': 'requires', 'resources': 'resources', 'series': 'series', 'storage': 'storage', 'subordinate': 'subordinate', 'summary': 'summary', 'tags': 'tags', 'terms': 'terms'}
+    _toPy = {'categories': 'categories', 'description': 'description', 'extra-bindings': 'extra_bindings', 'min-juju-version': 'min_juju_version', 'name': 'name', 'payload-classes': 'payload_classes', 'peers': 'peers', 'provides': 'provides', 'requires': 'requires', 'resources': 'resources', 'series': 'series', 'storage': 'storage', 'subordinate': 'subordinate', 'summary': 'summary', 'tags': 'tags', 'terms': 'terms'}
     def __init__(self, categories=None, description=None, extra_bindings=None, min_juju_version=None, name=None, payload_classes=None, peers=None, provides=None, requires=None, resources=None, series=None, storage=None, subordinate=None, summary=None, tags=None, terms=None):
         '''
         categories : typing.Sequence<+T_co>[str]
@@ -1188,7 +1244,7 @@ class CharmMeta(Type):
 
 class CharmMetric(Type):
     _toSchema = {'description': 'description', 'type_': 'type'}
-    _toPy = {'type': 'type_', 'description': 'description'}
+    _toPy = {'description': 'description', 'type': 'type_'}
     def __init__(self, description=None, type_=None):
         '''
         description : str
@@ -1199,18 +1255,20 @@ class CharmMetric(Type):
 
 
 class CharmMetrics(Type):
-    _toSchema = {'metrics': 'metrics'}
-    _toPy = {'metrics': 'metrics'}
-    def __init__(self, metrics=None):
+    _toSchema = {'metrics': 'metrics', 'plan': 'plan'}
+    _toPy = {'metrics': 'metrics', 'plan': 'plan'}
+    def __init__(self, metrics=None, plan=None):
         '''
         metrics : typing.Mapping<~KT, +VT_co>[str, ~CharmMetric]<~CharmMetric>
+        plan : CharmPlan
         '''
         self.metrics = metrics
+        self.plan = CharmPlan.from_json(plan) if plan else None
 
 
 class CharmOption(Type):
-    _toSchema = {'description': 'description', 'default': 'default', 'type_': 'type'}
-    _toPy = {'type': 'type_', 'description': 'description', 'default': 'default'}
+    _toSchema = {'default': 'default', 'description': 'description', 'type_': 'type'}
+    _toPy = {'default': 'default', 'description': 'description', 'type': 'type_'}
     def __init__(self, default=None, description=None, type_=None):
         '''
         default : typing.Mapping<~KT, +VT_co>[str, typing.Any]
@@ -1224,7 +1282,7 @@ class CharmOption(Type):
 
 class CharmPayloadClass(Type):
     _toSchema = {'name': 'name', 'type_': 'type'}
-    _toPy = {'type': 'type_', 'name': 'name'}
+    _toPy = {'name': 'name', 'type': 'type_'}
     def __init__(self, name=None, type_=None):
         '''
         name : str
@@ -1234,9 +1292,19 @@ class CharmPayloadClass(Type):
         self.type_ = type_
 
 
+class CharmPlan(Type):
+    _toSchema = {'required': 'required'}
+    _toPy = {'required': 'required'}
+    def __init__(self, required=None):
+        '''
+        required : bool
+        '''
+        self.required = required
+
+
 class CharmResourceMeta(Type):
-    _toSchema = {'description': 'description', 'type_': 'type', 'path': 'path', 'name': 'name'}
-    _toPy = {'type': 'type_', 'description': 'description', 'path': 'path', 'name': 'name'}
+    _toSchema = {'description': 'description', 'name': 'name', 'path': 'path', 'type_': 'type'}
+    _toPy = {'description': 'description', 'name': 'name', 'path': 'path', 'type': 'type_'}
     def __init__(self, description=None, name=None, path=None, type_=None):
         '''
         description : str
@@ -1251,8 +1319,8 @@ class CharmResourceMeta(Type):
 
 
 class CharmStorage(Type):
-    _toSchema = {'shared': 'shared', 'count_min': 'count-min', 'properties': 'properties', 'type_': 'type', 'description': 'description', 'name': 'name', 'location': 'location', 'minimum_size': 'minimum-size', 'read_only': 'read-only', 'count_max': 'count-max'}
-    _toPy = {'description': 'description', 'count-min': 'count_min', 'minimum-size': 'minimum_size', 'shared': 'shared', 'name': 'name', 'location': 'location', 'type': 'type_', 'count-max': 'count_max', 'read-only': 'read_only', 'properties': 'properties'}
+    _toSchema = {'count_max': 'count-max', 'count_min': 'count-min', 'description': 'description', 'location': 'location', 'minimum_size': 'minimum-size', 'name': 'name', 'properties': 'properties', 'read_only': 'read-only', 'shared': 'shared', 'type_': 'type'}
+    _toPy = {'count-max': 'count_max', 'count-min': 'count_min', 'description': 'description', 'location': 'location', 'minimum-size': 'minimum_size', 'name': 'name', 'properties': 'properties', 'read-only': 'read_only', 'shared': 'shared', 'type': 'type_'}
     def __init__(self, count_max=None, count_min=None, description=None, location=None, minimum_size=None, name=None, properties=None, read_only=None, shared=None, type_=None):
         '''
         count_max : int
@@ -1341,8 +1409,8 @@ class AddCharm(Type):
 
 
 class AddCharmWithAuthorization(Type):
-    _toSchema = {'macaroon': 'macaroon', 'channel': 'channel', 'url': 'url'}
-    _toPy = {'macaroon': 'macaroon', 'channel': 'channel', 'url': 'url'}
+    _toSchema = {'channel': 'channel', 'macaroon': 'macaroon', 'url': 'url'}
+    _toPy = {'channel': 'channel', 'macaroon': 'macaroon', 'url': 'url'}
     def __init__(self, channel=None, macaroon=None, url=None):
         '''
         channel : str
@@ -1355,8 +1423,8 @@ class AddCharmWithAuthorization(Type):
 
 
 class AddMachineParams(Type):
-    _toSchema = {'addresses': 'addresses', 'disks': 'disks', 'hardware_characteristics': 'hardware-characteristics', 'nonce': 'nonce', 'constraints': 'constraints', 'series': 'series', 'placement': 'placement', 'parent_id': 'parent-id', 'jobs': 'jobs', 'instance_id': 'instance-id', 'container_type': 'container-type'}
-    _toPy = {'addresses': 'addresses', 'disks': 'disks', 'instance-id': 'instance_id', 'container-type': 'container_type', 'nonce': 'nonce', 'constraints': 'constraints', 'series': 'series', 'placement': 'placement', 'parent-id': 'parent_id', 'hardware-characteristics': 'hardware_characteristics', 'jobs': 'jobs'}
+    _toSchema = {'addresses': 'addresses', 'constraints': 'constraints', 'container_type': 'container-type', 'disks': 'disks', 'hardware_characteristics': 'hardware-characteristics', 'instance_id': 'instance-id', 'jobs': 'jobs', 'nonce': 'nonce', 'parent_id': 'parent-id', 'placement': 'placement', 'series': 'series'}
+    _toPy = {'addresses': 'addresses', 'constraints': 'constraints', 'container-type': 'container_type', 'disks': 'disks', 'hardware-characteristics': 'hardware_characteristics', 'instance-id': 'instance_id', 'jobs': 'jobs', 'nonce': 'nonce', 'parent-id': 'parent_id', 'placement': 'placement', 'series': 'series'}
     def __init__(self, addresses=None, constraints=None, container_type=None, disks=None, hardware_characteristics=None, instance_id=None, jobs=None, nonce=None, parent_id=None, placement=None, series=None):
         '''
         addresses : typing.Sequence<+T_co>[~Address]<~Address>
@@ -1395,8 +1463,8 @@ class AddMachines(Type):
 
 
 class AddMachinesResult(Type):
-    _toSchema = {'machine': 'machine', 'error': 'error'}
-    _toPy = {'machine': 'machine', 'error': 'error'}
+    _toSchema = {'error': 'error', 'machine': 'machine'}
+    _toPy = {'error': 'error', 'machine': 'machine'}
     def __init__(self, error=None, machine=None):
         '''
         error : Error
@@ -1417,8 +1485,8 @@ class AddMachinesResults(Type):
 
 
 class Address(Type):
-    _toSchema = {'space_name': 'space-name', 'type_': 'type', 'scope': 'scope', 'value': 'value'}
-    _toPy = {'type': 'type_', 'value': 'value', 'scope': 'scope', 'space-name': 'space_name'}
+    _toSchema = {'scope': 'scope', 'space_name': 'space-name', 'type_': 'type', 'value': 'value'}
+    _toPy = {'scope': 'scope', 'space-name': 'space_name', 'type': 'type_', 'value': 'value'}
     def __init__(self, scope=None, space_name=None, type_=None, value=None):
         '''
         scope : str
@@ -1433,21 +1501,13 @@ class Address(Type):
 
 
 class AgentVersionResult(Type):
-    _toSchema = {'build': 'Build', 'patch': 'Patch', 'tag': 'Tag', 'minor': 'Minor', 'major': 'Major'}
-    _toPy = {'Tag': 'tag', 'Major': 'major', 'Patch': 'patch', 'Minor': 'minor', 'Build': 'build'}
-    def __init__(self, build=None, major=None, minor=None, patch=None, tag=None):
+    _toSchema = {'version': 'version'}
+    _toPy = {'version': 'version'}
+    def __init__(self, version=None):
         '''
-        build : int
-        major : int
-        minor : int
-        patch : int
-        tag : str
+        version : Number
         '''
-        self.build = build
-        self.major = major
-        self.minor = minor
-        self.patch = patch
-        self.tag = tag
+        self.version = Number.from_json(version) if version else None
 
 
 class AllWatcherId(Type):
@@ -1461,8 +1521,8 @@ class AllWatcherId(Type):
 
 
 class ApplicationStatus(Type):
-    _toSchema = {'can_upgrade_to': 'can-upgrade-to', 'subordinate_to': 'subordinate-to', 'workload_version': 'workload-version', 'life': 'life', 'charm': 'charm', 'status': 'status', 'units': 'units', 'meter_statuses': 'meter-statuses', 'series': 'series', 'err': 'err', 'relations': 'relations', 'exposed': 'exposed'}
-    _toPy = {'can-upgrade-to': 'can_upgrade_to', 'workload-version': 'workload_version', 'life': 'life', 'charm': 'charm', 'status': 'status', 'units': 'units', 'series': 'series', 'err': 'err', 'relations': 'relations', 'meter-statuses': 'meter_statuses', 'exposed': 'exposed', 'subordinate-to': 'subordinate_to'}
+    _toSchema = {'can_upgrade_to': 'can-upgrade-to', 'charm': 'charm', 'err': 'err', 'exposed': 'exposed', 'life': 'life', 'meter_statuses': 'meter-statuses', 'relations': 'relations', 'series': 'series', 'status': 'status', 'subordinate_to': 'subordinate-to', 'units': 'units', 'workload_version': 'workload-version'}
+    _toPy = {'can-upgrade-to': 'can_upgrade_to', 'charm': 'charm', 'err': 'err', 'exposed': 'exposed', 'life': 'life', 'meter-statuses': 'meter_statuses', 'relations': 'relations', 'series': 'series', 'status': 'status', 'subordinate-to': 'subordinate_to', 'units': 'units', 'workload-version': 'workload_version'}
     def __init__(self, can_upgrade_to=None, charm=None, err=None, exposed=None, life=None, meter_statuses=None, relations=None, series=None, status=None, subordinate_to=None, units=None, workload_version=None):
         '''
         can_upgrade_to : str
@@ -1493,8 +1553,8 @@ class ApplicationStatus(Type):
 
 
 class Binary(Type):
-    _toSchema = {'number': 'Number', 'series': 'Series', 'arch': 'Arch'}
-    _toPy = {'Series': 'series', 'Arch': 'arch', 'Number': 'number'}
+    _toSchema = {'arch': 'Arch', 'number': 'Number', 'series': 'Series'}
+    _toPy = {'Arch': 'arch', 'Number': 'number', 'Series': 'series'}
     def __init__(self, arch=None, number=None, series=None):
         '''
         arch : str
@@ -1506,22 +1566,6 @@ class Binary(Type):
         self.series = series
 
 
-class BundleChangesChange(Type):
-    _toSchema = {'args': 'args', 'requires': 'requires', 'id_': 'id', 'method': 'method'}
-    _toPy = {'args': 'args', 'id': 'id_', 'requires': 'requires', 'method': 'method'}
-    def __init__(self, args=None, id_=None, method=None, requires=None):
-        '''
-        args : typing.Sequence<+T_co>[typing.Any]
-        id_ : str
-        method : str
-        requires : typing.Sequence<+T_co>[str]
-        '''
-        self.args = args
-        self.id_ = id_
-        self.method = method
-        self.requires = requires
-
-
 class ConfigValue(Type):
     _toSchema = {'source': 'source', 'value': 'value'}
     _toPy = {'source': 'source', 'value': 'value'}
@@ -1535,7 +1579,7 @@ class ConfigValue(Type):
 
 
 class DestroyMachines(Type):
-    _toSchema = {'machine_names': 'machine-names', 'force': 'force'}
+    _toSchema = {'force': 'force', 'machine_names': 'machine-names'}
     _toPy = {'force': 'force', 'machine-names': 'machine_names'}
     def __init__(self, force=None, machine_names=None):
         '''
@@ -1547,8 +1591,8 @@ class DestroyMachines(Type):
 
 
 class DetailedStatus(Type):
-    _toSchema = {'info': 'info', 'data': 'data', 'kind': 'kind', 'since': 'since', 'err': 'err', 'life': 'life', 'status': 'status', 'version': 'version'}
-    _toPy = {'info': 'info', 'data': 'data', 'kind': 'kind', 'since': 'since', 'err': 'err', 'life': 'life', 'status': 'status', 'version': 'version'}
+    _toSchema = {'data': 'data', 'err': 'err', 'info': 'info', 'kind': 'kind', 'life': 'life', 'since': 'since', 'status': 'status', 'version': 'version'}
+    _toPy = {'data': 'data', 'err': 'err', 'info': 'info', 'kind': 'kind', 'life': 'life', 'since': 'since', 'status': 'status', 'version': 'version'}
     def __init__(self, data=None, err=None, info=None, kind=None, life=None, since=None, status=None, version=None):
         '''
         data : typing.Mapping<~KT, +VT_co>[str, typing.Any]
@@ -1587,8 +1631,8 @@ class EndpointStatus(Type):
 
 
 class EntityStatus(Type):
-    _toSchema = {'info': 'info', 'data': 'data', 'status': 'status', 'since': 'since'}
-    _toPy = {'info': 'info', 'data': 'data', 'status': 'status', 'since': 'since'}
+    _toSchema = {'data': 'data', 'info': 'info', 'since': 'since', 'status': 'status'}
+    _toPy = {'data': 'data', 'info': 'info', 'since': 'since', 'status': 'status'}
     def __init__(self, data=None, info=None, since=None, status=None):
         '''
         data : typing.Mapping<~KT, +VT_co>[str, typing.Any]
@@ -1603,8 +1647,8 @@ class EntityStatus(Type):
 
 
 class FindToolsParams(Type):
-    _toSchema = {'series': 'series', 'number': 'number', 'minor': 'minor', 'major': 'major', 'arch': 'arch'}
-    _toPy = {'series': 'series', 'number': 'number', 'minor': 'minor', 'major': 'major', 'arch': 'arch'}
+    _toSchema = {'arch': 'arch', 'major': 'major', 'minor': 'minor', 'number': 'number', 'series': 'series'}
+    _toPy = {'arch': 'arch', 'major': 'major', 'minor': 'minor', 'number': 'number', 'series': 'series'}
     def __init__(self, arch=None, major=None, minor=None, number=None, series=None):
         '''
         arch : str
@@ -1621,8 +1665,8 @@ class FindToolsParams(Type):
 
 
 class FindToolsResult(Type):
-    _toSchema = {'list_': 'list', 'error': 'error'}
-    _toPy = {'list': 'list_', 'error': 'error'}
+    _toSchema = {'error': 'error', 'list_': 'list'}
+    _toPy = {'error': 'error', 'list': 'list_'}
     def __init__(self, error=None, list_=None):
         '''
         error : Error
@@ -1633,46 +1677,26 @@ class FindToolsResult(Type):
 
 
 class FullStatus(Type):
-    _toSchema = {'relations': 'relations', 'machines': 'machines', 'applications': 'applications', 'model': 'model'}
-    _toPy = {'relations': 'relations', 'machines': 'machines', 'applications': 'applications', 'model': 'model'}
-    def __init__(self, applications=None, machines=None, model=None, relations=None):
+    _toSchema = {'applications': 'applications', 'machines': 'machines', 'model': 'model', 'relations': 'relations', 'remote_applications': 'remote-applications'}
+    _toPy = {'applications': 'applications', 'machines': 'machines', 'model': 'model', 'relations': 'relations', 'remote-applications': 'remote_applications'}
+    def __init__(self, applications=None, machines=None, model=None, relations=None, remote_applications=None):
         '''
         applications : typing.Mapping<~KT, +VT_co>[str, ~ApplicationStatus]<~ApplicationStatus>
         machines : typing.Mapping<~KT, +VT_co>[str, ~MachineStatus]<~MachineStatus>
         model : ModelStatusInfo
         relations : typing.Sequence<+T_co>[~RelationStatus]<~RelationStatus>
+        remote_applications : typing.Mapping<~KT, +VT_co>[str, ~RemoteApplicationStatus]<~RemoteApplicationStatus>
         '''
         self.applications = applications
         self.machines = machines
         self.model = ModelStatusInfo.from_json(model) if model else None
         self.relations = [RelationStatus.from_json(o) for o in relations or []]
-
-
-class GetBundleChangesParams(Type):
-    _toSchema = {'yaml': 'yaml'}
-    _toPy = {'yaml': 'yaml'}
-    def __init__(self, yaml=None):
-        '''
-        yaml : str
-        '''
-        self.yaml = yaml
-
-
-class GetBundleChangesResults(Type):
-    _toSchema = {'errors': 'errors', 'changes': 'changes'}
-    _toPy = {'errors': 'errors', 'changes': 'changes'}
-    def __init__(self, changes=None, errors=None):
-        '''
-        changes : typing.Sequence<+T_co>[~BundleChangesChange]<~BundleChangesChange>
-        errors : typing.Sequence<+T_co>[str]
-        '''
-        self.changes = [BundleChangesChange.from_json(o) for o in changes or []]
-        self.errors = errors
+        self.remote_applications = remote_applications
 
 
 class HardwareCharacteristics(Type):
-    _toSchema = {'cpu_power': 'cpu-power', 'tags': 'tags', 'availability_zone': 'availability-zone', 'mem': 'mem', 'root_disk': 'root-disk', 'arch': 'arch', 'cpu_cores': 'cpu-cores'}
-    _toPy = {'cpu-power': 'cpu_power', 'tags': 'tags', 'arch': 'arch', 'mem': 'mem', 'availability-zone': 'availability_zone', 'cpu-cores': 'cpu_cores', 'root-disk': 'root_disk'}
+    _toSchema = {'arch': 'arch', 'availability_zone': 'availability-zone', 'cpu_cores': 'cpu-cores', 'cpu_power': 'cpu-power', 'mem': 'mem', 'root_disk': 'root-disk', 'tags': 'tags'}
+    _toPy = {'arch': 'arch', 'availability-zone': 'availability_zone', 'cpu-cores': 'cpu_cores', 'cpu-power': 'cpu_power', 'mem': 'mem', 'root-disk': 'root_disk', 'tags': 'tags'}
     def __init__(self, arch=None, availability_zone=None, cpu_cores=None, cpu_power=None, mem=None, root_disk=None, tags=None):
         '''
         arch : str
@@ -1693,8 +1717,8 @@ class HardwareCharacteristics(Type):
 
 
 class History(Type):
-    _toSchema = {'statuses': 'statuses', 'error': 'error'}
-    _toPy = {'statuses': 'statuses', 'error': 'error'}
+    _toSchema = {'error': 'error', 'statuses': 'statuses'}
+    _toPy = {'error': 'error', 'statuses': 'statuses'}
     def __init__(self, error=None, statuses=None):
         '''
         error : Error
@@ -1705,7 +1729,7 @@ class History(Type):
 
 
 class HostPort(Type):
-    _toSchema = {'port': 'port', 'address': 'Address'}
+    _toSchema = {'address': 'Address', 'port': 'port'}
     _toPy = {'Address': 'address', 'port': 'port'}
     def __init__(self, address=None, port=None):
         '''
@@ -1716,12 +1740,35 @@ class HostPort(Type):
         self.port = port
 
 
+class MachineHardware(Type):
+    _toSchema = {'arch': 'arch', 'availability_zone': 'availability-zone', 'cores': 'cores', 'cpu_power': 'cpu-power', 'mem': 'mem', 'root_disk': 'root-disk', 'tags': 'tags'}
+    _toPy = {'arch': 'arch', 'availability-zone': 'availability_zone', 'cores': 'cores', 'cpu-power': 'cpu_power', 'mem': 'mem', 'root-disk': 'root_disk', 'tags': 'tags'}
+    def __init__(self, arch=None, availability_zone=None, cores=None, cpu_power=None, mem=None, root_disk=None, tags=None):
+        '''
+        arch : str
+        availability_zone : str
+        cores : int
+        cpu_power : int
+        mem : int
+        root_disk : int
+        tags : typing.Sequence<+T_co>[str]
+        '''
+        self.arch = arch
+        self.availability_zone = availability_zone
+        self.cores = cores
+        self.cpu_power = cpu_power
+        self.mem = mem
+        self.root_disk = root_disk
+        self.tags = tags
+
+
 class MachineStatus(Type):
-    _toSchema = {'dns_name': 'dns-name', 'jobs': 'jobs', 'id_': 'id', 'instance_id': 'instance-id', 'series': 'series', 'wants_vote': 'wants-vote', 'instance_status': 'instance-status', 'hardware': 'hardware', 'containers': 'containers', 'has_vote': 'has-vote', 'agent_status': 'agent-status'}
-    _toPy = {'has-vote': 'has_vote', 'instance-id': 'instance_id', 'instance-status': 'instance_status', 'series': 'series', 'dns-name': 'dns_name', 'wants-vote': 'wants_vote', 'id': 'id_', 'agent-status': 'agent_status', 'containers': 'containers', 'jobs': 'jobs', 'hardware': 'hardware'}
-    def __init__(self, agent_status=None, containers=None, dns_name=None, hardware=None, has_vote=None, id_=None, instance_id=None, instance_status=None, jobs=None, series=None, wants_vote=None):
+    _toSchema = {'agent_status': 'agent-status', 'constraints': 'constraints', 'containers': 'containers', 'dns_name': 'dns-name', 'hardware': 'hardware', 'has_vote': 'has-vote', 'id_': 'id', 'instance_id': 'instance-id', 'instance_status': 'instance-status', 'ip_addresses': 'ip-addresses', 'jobs': 'jobs', 'series': 'series', 'wants_vote': 'wants-vote'}
+    _toPy = {'agent-status': 'agent_status', 'constraints': 'constraints', 'containers': 'containers', 'dns-name': 'dns_name', 'hardware': 'hardware', 'has-vote': 'has_vote', 'id': 'id_', 'instance-id': 'instance_id', 'instance-status': 'instance_status', 'ip-addresses': 'ip_addresses', 'jobs': 'jobs', 'series': 'series', 'wants-vote': 'wants_vote'}
+    def __init__(self, agent_status=None, constraints=None, containers=None, dns_name=None, hardware=None, has_vote=None, id_=None, instance_id=None, instance_status=None, ip_addresses=None, jobs=None, series=None, wants_vote=None):
         '''
         agent_status : DetailedStatus
+        constraints : str
         containers : typing.Mapping<~KT, +VT_co>[str, ~MachineStatus]<~MachineStatus>
         dns_name : str
         hardware : str
@@ -1729,11 +1776,13 @@ class MachineStatus(Type):
         id_ : str
         instance_id : str
         instance_status : DetailedStatus
+        ip_addresses : typing.Sequence<+T_co>[str]
         jobs : typing.Sequence<+T_co>[str]
         series : str
         wants_vote : bool
         '''
         self.agent_status = DetailedStatus.from_json(agent_status) if agent_status else None
+        self.constraints = constraints
         self.containers = containers
         self.dns_name = dns_name
         self.hardware = hardware
@@ -1741,6 +1790,7 @@ class MachineStatus(Type):
         self.id_ = id_
         self.instance_id = instance_id
         self.instance_status = DetailedStatus.from_json(instance_status) if instance_status else None
+        self.ip_addresses = ip_addresses
         self.jobs = jobs
         self.series = series
         self.wants_vote = wants_vote
@@ -1768,55 +1818,19 @@ class ModelConfigResults(Type):
         self.config = config
 
 
-class ModelDefaultValues(Type):
-    _toSchema = {'config': 'config', 'cloud_tag': 'cloud-tag', 'cloud_region': 'cloud-region'}
-    _toPy = {'config': 'config', 'cloud-tag': 'cloud_tag', 'cloud-region': 'cloud_region'}
-    def __init__(self, cloud_region=None, cloud_tag=None, config=None):
-        '''
-        cloud_region : str
-        cloud_tag : str
-        config : typing.Mapping<~KT, +VT_co>[str, typing.Any]
-        '''
-        self.cloud_region = cloud_region
-        self.cloud_tag = cloud_tag
-        self.config = config
-
-
-class ModelDefaults(Type):
-    _toSchema = {'controller': 'controller', 'default': 'default', 'regions': 'regions'}
-    _toPy = {'controller': 'controller', 'default': 'default', 'regions': 'regions'}
-    def __init__(self, controller=None, default=None, regions=None):
-        '''
-        controller : typing.Mapping<~KT, +VT_co>[str, typing.Any]
-        default : typing.Mapping<~KT, +VT_co>[str, typing.Any]
-        regions : typing.Sequence<+T_co>[~RegionDefaults]<~RegionDefaults>
-        '''
-        self.controller = controller
-        self.default = default
-        self.regions = [RegionDefaults.from_json(o) for o in regions or []]
-
-
-class ModelDefaultsResult(Type):
-    _toSchema = {'config': 'config'}
-    _toPy = {'config': 'config'}
-    def __init__(self, config=None):
-        '''
-        config : typing.Mapping<~KT, +VT_co>[str, ~ModelDefaults]<~ModelDefaults>
-        '''
-        self.config = config
-
-
 class ModelInfo(Type):
-    _toSchema = {'default_series': 'default-series', 'life': 'life', 'cloud_region': 'cloud-region', 'users': 'users', 'uuid': 'uuid', 'owner_tag': 'owner-tag', 'cloud': 'cloud', 'cloud_credential_tag': 'cloud-credential-tag', 'status': 'status', 'name': 'name', 'controller_uuid': 'controller-uuid', 'provider_type': 'provider-type'}
-    _toPy = {'controller-uuid': 'controller_uuid', 'life': 'life', 'owner-tag': 'owner_tag', 'provider-type': 'provider_type', 'users': 'users', 'uuid': 'uuid', 'default-series': 'default_series', 'cloud': 'cloud', 'cloud-credential-tag': 'cloud_credential_tag', 'status': 'status', 'name': 'name', 'cloud-region': 'cloud_region'}
-    def __init__(self, cloud=None, cloud_credential_tag=None, cloud_region=None, controller_uuid=None, default_series=None, life=None, name=None, owner_tag=None, provider_type=None, status=None, users=None, uuid=None):
+    _toSchema = {'cloud_credential_tag': 'cloud-credential-tag', 'cloud_region': 'cloud-region', 'cloud_tag': 'cloud-tag', 'controller_uuid': 'controller-uuid', 'default_series': 'default-series', 'life': 'life', 'machines': 'machines', 'migration': 'migration', 'name': 'name', 'owner_tag': 'owner-tag', 'provider_type': 'provider-type', 'status': 'status', 'users': 'users', 'uuid': 'uuid'}
+    _toPy = {'cloud-credential-tag': 'cloud_credential_tag', 'cloud-region': 'cloud_region', 'cloud-tag': 'cloud_tag', 'controller-uuid': 'controller_uuid', 'default-series': 'default_series', 'life': 'life', 'machines': 'machines', 'migration': 'migration', 'name': 'name', 'owner-tag': 'owner_tag', 'provider-type': 'provider_type', 'status': 'status', 'users': 'users', 'uuid': 'uuid'}
+    def __init__(self, cloud_credential_tag=None, cloud_region=None, cloud_tag=None, controller_uuid=None, default_series=None, life=None, machines=None, migration=None, name=None, owner_tag=None, provider_type=None, status=None, users=None, uuid=None):
         '''
-        cloud : str
         cloud_credential_tag : str
         cloud_region : str
+        cloud_tag : str
         controller_uuid : str
         default_series : str
         life : str
+        machines : typing.Sequence<+T_co>[~ModelMachineInfo]<~ModelMachineInfo>
+        migration : ModelMigrationStatus
         name : str
         owner_tag : str
         provider_type : str
@@ -1824,12 +1838,14 @@ class ModelInfo(Type):
         users : typing.Sequence<+T_co>[~ModelUserInfo]<~ModelUserInfo>
         uuid : str
         '''
-        self.cloud = cloud
         self.cloud_credential_tag = cloud_credential_tag
         self.cloud_region = cloud_region
+        self.cloud_tag = cloud_tag
         self.controller_uuid = controller_uuid
         self.default_series = default_series
         self.life = life
+        self.machines = [ModelMachineInfo.from_json(o) for o in machines or []]
+        self.migration = ModelMigrationStatus.from_json(migration) if migration else None
         self.name = name
         self.owner_tag = owner_tag
         self.provider_type = provider_type
@@ -1838,6 +1854,40 @@ class ModelInfo(Type):
         self.uuid = uuid
 
 
+class ModelMachineInfo(Type):
+    _toSchema = {'hardware': 'hardware', 'has_vote': 'has-vote', 'id_': 'id', 'instance_id': 'instance-id', 'status': 'status', 'wants_vote': 'wants-vote'}
+    _toPy = {'hardware': 'hardware', 'has-vote': 'has_vote', 'id': 'id_', 'instance-id': 'instance_id', 'status': 'status', 'wants-vote': 'wants_vote'}
+    def __init__(self, hardware=None, has_vote=None, id_=None, instance_id=None, status=None, wants_vote=None):
+        '''
+        hardware : MachineHardware
+        has_vote : bool
+        id_ : str
+        instance_id : str
+        status : str
+        wants_vote : bool
+        '''
+        self.hardware = MachineHardware.from_json(hardware) if hardware else None
+        self.has_vote = has_vote
+        self.id_ = id_
+        self.instance_id = instance_id
+        self.status = status
+        self.wants_vote = wants_vote
+
+
+class ModelMigrationStatus(Type):
+    _toSchema = {'end': 'end', 'start': 'start', 'status': 'status'}
+    _toPy = {'end': 'end', 'start': 'start', 'status': 'status'}
+    def __init__(self, end=None, start=None, status=None):
+        '''
+        end : str
+        start : str
+        status : str
+        '''
+        self.end = end
+        self.start = start
+        self.status = status
+
+
 class ModelSet(Type):
     _toSchema = {'config': 'config'}
     _toPy = {'config': 'config'}
@@ -1849,19 +1899,19 @@ class ModelSet(Type):
 
 
 class ModelStatusInfo(Type):
-    _toSchema = {'cloud': 'cloud', 'name': 'name', 'migration': 'migration', 'region': 'region', 'available_version': 'available-version', 'version': 'version'}
-    _toPy = {'available-version': 'available_version', 'cloud': 'cloud', 'name': 'name', 'migration': 'migration', 'region': 'region', 'version': 'version'}
-    def __init__(self, available_version=None, cloud=None, migration=None, name=None, region=None, version=None):
+    _toSchema = {'available_version': 'available-version', 'cloud_tag': 'cloud-tag', 'migration': 'migration', 'name': 'name', 'region': 'region', 'version': 'version'}
+    _toPy = {'available-version': 'available_version', 'cloud-tag': 'cloud_tag', 'migration': 'migration', 'name': 'name', 'region': 'region', 'version': 'version'}
+    def __init__(self, available_version=None, cloud_tag=None, migration=None, name=None, region=None, version=None):
         '''
         available_version : str
-        cloud : str
+        cloud_tag : str
         migration : str
         name : str
         region : str
         version : str
         '''
         self.available_version = available_version
-        self.cloud = cloud
+        self.cloud_tag = cloud_tag
         self.migration = migration
         self.name = name
         self.region = region
@@ -1878,23 +1928,9 @@ class ModelUnset(Type):
         self.keys = keys
 
 
-class ModelUnsetKeys(Type):
-    _toSchema = {'cloud_tag': 'cloud-tag', 'keys': 'keys', 'cloud_region': 'cloud-region'}
-    _toPy = {'cloud-tag': 'cloud_tag', 'cloud-region': 'cloud_region', 'keys': 'keys'}
-    def __init__(self, cloud_region=None, cloud_tag=None, keys=None):
-        '''
-        cloud_region : str
-        cloud_tag : str
-        keys : typing.Sequence<+T_co>[str]
-        '''
-        self.cloud_region = cloud_region
-        self.cloud_tag = cloud_tag
-        self.keys = keys
-
-
 class ModelUserInfo(Type):
-    _toSchema = {'display_name': 'display-name', 'access': 'access', 'user': 'user', 'last_connection': 'last-connection'}
-    _toPy = {'last-connection': 'last_connection', 'access': 'access', 'user': 'user', 'display-name': 'display_name'}
+    _toSchema = {'access': 'access', 'display_name': 'display-name', 'last_connection': 'last-connection', 'user': 'user'}
+    _toPy = {'access': 'access', 'display-name': 'display_name', 'last-connection': 'last_connection', 'user': 'user'}
     def __init__(self, access=None, display_name=None, last_connection=None, user=None):
         '''
         access : str
@@ -1909,8 +1945,8 @@ class ModelUserInfo(Type):
 
 
 class ModelUserInfoResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -1951,8 +1987,8 @@ class PrivateAddressResults(Type):
 
 
 class ProvisioningScriptParams(Type):
-    _toSchema = {'data_dir': 'data-dir', 'nonce': 'nonce', 'disable_package_commands': 'disable-package-commands', 'machine_id': 'machine-id'}
-    _toPy = {'machine-id': 'machine_id', 'data-dir': 'data_dir', 'nonce': 'nonce', 'disable-package-commands': 'disable_package_commands'}
+    _toSchema = {'data_dir': 'data-dir', 'disable_package_commands': 'disable-package-commands', 'machine_id': 'machine-id', 'nonce': 'nonce'}
+    _toPy = {'data-dir': 'data_dir', 'disable-package-commands': 'disable_package_commands', 'machine-id': 'machine_id', 'nonce': 'nonce'}
     def __init__(self, data_dir=None, disable_package_commands=None, machine_id=None, nonce=None):
         '''
         data_dir : str
@@ -1996,21 +2032,9 @@ class PublicAddressResults(Type):
         self.public_address = public_address
 
 
-class RegionDefaults(Type):
-    _toSchema = {'value': 'value', 'region_name': 'region-name'}
-    _toPy = {'region-name': 'region_name', 'value': 'value'}
-    def __init__(self, region_name=None, value=None):
-        '''
-        region_name : str
-        value : typing.Mapping<~KT, +VT_co>[str, typing.Any]
-        '''
-        self.region_name = region_name
-        self.value = value
-
-
 class RelationStatus(Type):
-    _toSchema = {'interface': 'interface', 'endpoints': 'endpoints', 'id_': 'id', 'key': 'key', 'scope': 'scope'}
-    _toPy = {'id': 'id_', 'interface': 'interface', 'endpoints': 'endpoints', 'scope': 'scope', 'key': 'key'}
+    _toSchema = {'endpoints': 'endpoints', 'id_': 'id', 'interface': 'interface', 'key': 'key', 'scope': 'scope'}
+    _toPy = {'endpoints': 'endpoints', 'id': 'id_', 'interface': 'interface', 'key': 'key', 'scope': 'scope'}
     def __init__(self, endpoints=None, id_=None, interface=None, key=None, scope=None):
         '''
         endpoints : typing.Sequence<+T_co>[~EndpointStatus]<~EndpointStatus>
@@ -2026,20 +2050,60 @@ class RelationStatus(Type):
         self.scope = scope
 
 
-class ResolveCharmResult(Type):
-    _toSchema = {'url': 'url', 'error': 'error'}
-    _toPy = {'url': 'url', 'error': 'error'}
-    def __init__(self, error=None, url=None):
+class RemoteApplicationStatus(Type):
+    _toSchema = {'application_name': 'application-name', 'application_url': 'application-url', 'endpoints': 'endpoints', 'err': 'err', 'life': 'life', 'relations': 'relations', 'status': 'status'}
+    _toPy = {'application-name': 'application_name', 'application-url': 'application_url', 'endpoints': 'endpoints', 'err': 'err', 'life': 'life', 'relations': 'relations', 'status': 'status'}
+    def __init__(self, application_name=None, application_url=None, endpoints=None, err=None, life=None, relations=None, status=None):
         '''
-        error : str
-        url : str
+        application_name : str
+        application_url : str
+        endpoints : typing.Sequence<+T_co>[~RemoteEndpoint]<~RemoteEndpoint>
+        err : typing.Mapping<~KT, +VT_co>[str, typing.Any]
+        life : str
+        relations : typing.Sequence<+T_co>[str]
+        status : DetailedStatus
         '''
-        self.error = error
-        self.url = url
-
-
-class ResolveCharmResults(Type):
-    _toSchema = {'urls': 'urls'}
+        self.application_name = application_name
+        self.application_url = application_url
+        self.endpoints = [RemoteEndpoint.from_json(o) for o in endpoints or []]
+        self.err = err
+        self.life = life
+        self.relations = relations
+        self.status = DetailedStatus.from_json(status) if status else None
+
+
+class RemoteEndpoint(Type):
+    _toSchema = {'interface': 'interface', 'limit': 'limit', 'name': 'name', 'role': 'role', 'scope': 'scope'}
+    _toPy = {'interface': 'interface', 'limit': 'limit', 'name': 'name', 'role': 'role', 'scope': 'scope'}
+    def __init__(self, interface=None, limit=None, name=None, role=None, scope=None):
+        '''
+        interface : str
+        limit : int
+        name : str
+        role : str
+        scope : str
+        '''
+        self.interface = interface
+        self.limit = limit
+        self.name = name
+        self.role = role
+        self.scope = scope
+
+
+class ResolveCharmResult(Type):
+    _toSchema = {'error': 'error', 'url': 'url'}
+    _toPy = {'error': 'error', 'url': 'url'}
+    def __init__(self, error=None, url=None):
+        '''
+        error : str
+        url : str
+        '''
+        self.error = error
+        self.url = url
+
+
+class ResolveCharmResults(Type):
+    _toSchema = {'urls': 'urls'}
     _toPy = {'urls': 'urls'}
     def __init__(self, urls=None):
         '''
@@ -2059,8 +2123,8 @@ class ResolveCharms(Type):
 
 
 class Resolved(Type):
-    _toSchema = {'unit_name': 'unit-name', 'retry': 'retry'}
-    _toPy = {'unit-name': 'unit_name', 'retry': 'retry'}
+    _toSchema = {'retry': 'retry', 'unit_name': 'unit-name'}
+    _toPy = {'retry': 'retry', 'unit-name': 'unit_name'}
     def __init__(self, retry=None, unit_name=None):
         '''
         retry : bool
@@ -2071,36 +2135,18 @@ class Resolved(Type):
 
 
 class SetModelAgentVersion(Type):
-    _toSchema = {'build': 'Build', 'patch': 'Patch', 'tag': 'Tag', 'minor': 'Minor', 'major': 'Major'}
-    _toPy = {'Tag': 'tag', 'Major': 'major', 'Patch': 'patch', 'Minor': 'minor', 'Build': 'build'}
-    def __init__(self, build=None, major=None, minor=None, patch=None, tag=None):
-        '''
-        build : int
-        major : int
-        minor : int
-        patch : int
-        tag : str
-        '''
-        self.build = build
-        self.major = major
-        self.minor = minor
-        self.patch = patch
-        self.tag = tag
-
-
-class SetModelDefaults(Type):
-    _toSchema = {'config': 'config'}
-    _toPy = {'config': 'config'}
-    def __init__(self, config=None):
+    _toSchema = {'version': 'version'}
+    _toPy = {'version': 'version'}
+    def __init__(self, version=None):
         '''
-        config : typing.Sequence<+T_co>[~ModelDefaultValues]<~ModelDefaultValues>
+        version : Number
         '''
-        self.config = [ModelDefaultValues.from_json(o) for o in config or []]
+        self.version = Number.from_json(version) if version else None
 
 
 class StatusHistoryFilter(Type):
-    _toSchema = {'size': 'size', 'date': 'date', 'delta': 'delta'}
-    _toPy = {'size': 'size', 'date': 'date', 'delta': 'delta'}
+    _toSchema = {'date': 'date', 'delta': 'delta', 'size': 'size'}
+    _toPy = {'date': 'date', 'delta': 'delta', 'size': 'size'}
     def __init__(self, date=None, delta=None, size=None):
         '''
         date : str
@@ -2113,8 +2159,8 @@ class StatusHistoryFilter(Type):
 
 
 class StatusHistoryRequest(Type):
-    _toSchema = {'historykind': 'historyKind', 'tag': 'tag', 'size': 'size', 'filter_': 'filter'}
-    _toPy = {'filter': 'filter_', 'historyKind': 'historykind', 'tag': 'tag', 'size': 'size'}
+    _toSchema = {'filter_': 'filter', 'historykind': 'historyKind', 'size': 'size', 'tag': 'tag'}
+    _toPy = {'filter': 'filter_', 'historyKind': 'historykind', 'size': 'size', 'tag': 'tag'}
     def __init__(self, filter_=None, historykind=None, size=None, tag=None):
         '''
         filter_ : StatusHistoryFilter
@@ -2139,8 +2185,8 @@ class StatusHistoryRequests(Type):
 
 
 class StatusHistoryResult(Type):
-    _toSchema = {'history': 'history', 'error': 'error'}
-    _toPy = {'history': 'history', 'error': 'error'}
+    _toSchema = {'error': 'error', 'history': 'history'}
+    _toPy = {'error': 'error', 'history': 'history'}
     def __init__(self, error=None, history=None):
         '''
         error : Error
@@ -2171,8 +2217,8 @@ class StatusParams(Type):
 
 
 class Tools(Type):
-    _toSchema = {'version': 'version', 'sha256': 'sha256', 'size': 'size', 'url': 'url'}
-    _toPy = {'version': 'version', 'sha256': 'sha256', 'size': 'size', 'url': 'url'}
+    _toSchema = {'sha256': 'sha256', 'size': 'size', 'url': 'url', 'version': 'version'}
+    _toPy = {'sha256': 'sha256', 'size': 'size', 'url': 'url', 'version': 'version'}
     def __init__(self, sha256=None, size=None, url=None, version=None):
         '''
         sha256 : str
@@ -2187,12 +2233,13 @@ class Tools(Type):
 
 
 class UnitStatus(Type):
-    _toSchema = {'workload_status': 'workload-status', 'opened_ports': 'opened-ports', 'subordinates': 'subordinates', 'workload_version': 'workload-version', 'public_address': 'public-address', 'charm': 'charm', 'agent_status': 'agent-status', 'machine': 'machine'}
-    _toPy = {'public-address': 'public_address', 'workload-version': 'workload_version', 'subordinates': 'subordinates', 'opened-ports': 'opened_ports', 'charm': 'charm', 'workload-status': 'workload_status', 'machine': 'machine', 'agent-status': 'agent_status'}
-    def __init__(self, agent_status=None, charm=None, machine=None, opened_ports=None, public_address=None, subordinates=None, workload_status=None, workload_version=None):
+    _toSchema = {'agent_status': 'agent-status', 'charm': 'charm', 'leader': 'leader', 'machine': 'machine', 'opened_ports': 'opened-ports', 'public_address': 'public-address', 'subordinates': 'subordinates', 'workload_status': 'workload-status', 'workload_version': 'workload-version'}
+    _toPy = {'agent-status': 'agent_status', 'charm': 'charm', 'leader': 'leader', 'machine': 'machine', 'opened-ports': 'opened_ports', 'public-address': 'public_address', 'subordinates': 'subordinates', 'workload-status': 'workload_status', 'workload-version': 'workload_version'}
+    def __init__(self, agent_status=None, charm=None, leader=None, machine=None, opened_ports=None, public_address=None, subordinates=None, workload_status=None, workload_version=None):
         '''
         agent_status : DetailedStatus
         charm : str
+        leader : bool
         machine : str
         opened_ports : typing.Sequence<+T_co>[str]
         public_address : str
@@ -2202,6 +2249,7 @@ class UnitStatus(Type):
         '''
         self.agent_status = DetailedStatus.from_json(agent_status) if agent_status else None
         self.charm = charm
+        self.leader = leader
         self.machine = machine
         self.opened_ports = opened_ports
         self.public_address = public_address
@@ -2210,19 +2258,9 @@ class UnitStatus(Type):
         self.workload_version = workload_version
 
 
-class UnsetModelDefaults(Type):
-    _toSchema = {'keys': 'keys'}
-    _toPy = {'keys': 'keys'}
-    def __init__(self, keys=None):
-        '''
-        keys : typing.Sequence<+T_co>[~ModelUnsetKeys]<~ModelUnsetKeys>
-        '''
-        self.keys = [ModelUnsetKeys.from_json(o) for o in keys or []]
-
-
 class Cloud(Type):
-    _toSchema = {'type_': 'type', 'identity_endpoint': 'identity-endpoint', 'storage_endpoint': 'storage-endpoint', 'regions': 'regions', 'auth_types': 'auth-types', 'endpoint': 'endpoint'}
-    _toPy = {'auth-types': 'auth_types', 'regions': 'regions', 'type': 'type_', 'identity-endpoint': 'identity_endpoint', 'endpoint': 'endpoint', 'storage-endpoint': 'storage_endpoint'}
+    _toSchema = {'auth_types': 'auth-types', 'endpoint': 'endpoint', 'identity_endpoint': 'identity-endpoint', 'regions': 'regions', 'storage_endpoint': 'storage-endpoint', 'type_': 'type'}
+    _toPy = {'auth-types': 'auth_types', 'endpoint': 'endpoint', 'identity-endpoint': 'identity_endpoint', 'regions': 'regions', 'storage-endpoint': 'storage_endpoint', 'type': 'type_'}
     def __init__(self, auth_types=None, endpoint=None, identity_endpoint=None, regions=None, storage_endpoint=None, type_=None):
         '''
         auth_types : typing.Sequence<+T_co>[str]
@@ -2241,8 +2279,8 @@ class Cloud(Type):
 
 
 class CloudCredentialResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -2262,9 +2300,33 @@ class CloudCredentialResults(Type):
         self.results = [CloudCredentialResult.from_json(o) for o in results or []]
 
 
+class CloudInstanceTypesConstraint(Type):
+    _toSchema = {'cloud_tag': 'cloud-tag', 'constraints': 'constraints', 'region': 'region'}
+    _toPy = {'cloud-tag': 'cloud_tag', 'constraints': 'constraints', 'region': 'region'}
+    def __init__(self, cloud_tag=None, constraints=None, region=None):
+        '''
+        cloud_tag : str
+        constraints : Value
+        region : str
+        '''
+        self.cloud_tag = cloud_tag
+        self.constraints = Value.from_json(constraints) if constraints else None
+        self.region = region
+
+
+class CloudInstanceTypesConstraints(Type):
+    _toSchema = {'constraints': 'constraints'}
+    _toPy = {'constraints': 'constraints'}
+    def __init__(self, constraints=None):
+        '''
+        constraints : typing.Sequence<+T_co>[~CloudInstanceTypesConstraint]<~CloudInstanceTypesConstraint>
+        '''
+        self.constraints = [CloudInstanceTypesConstraint.from_json(o) for o in constraints or []]
+
+
 class CloudRegion(Type):
-    _toSchema = {'name': 'name', 'endpoint': 'endpoint', 'storage_endpoint': 'storage-endpoint', 'identity_endpoint': 'identity-endpoint'}
-    _toPy = {'identity-endpoint': 'identity_endpoint', 'endpoint': 'endpoint', 'storage-endpoint': 'storage_endpoint', 'name': 'name'}
+    _toSchema = {'endpoint': 'endpoint', 'identity_endpoint': 'identity-endpoint', 'name': 'name', 'storage_endpoint': 'storage-endpoint'}
+    _toPy = {'endpoint': 'endpoint', 'identity-endpoint': 'identity_endpoint', 'name': 'name', 'storage-endpoint': 'storage_endpoint'}
     def __init__(self, endpoint=None, identity_endpoint=None, name=None, storage_endpoint=None):
         '''
         endpoint : str
@@ -2310,9 +2372,61 @@ class CloudsResult(Type):
         self.clouds = clouds
 
 
+class InstanceType(Type):
+    _toSchema = {'arches': 'arches', 'cost': 'cost', 'cpu_cores': 'cpu-cores', 'deprecated': 'deprecated', 'memory': 'memory', 'name': 'name', 'root_disk': 'root-disk', 'virt_type': 'virt-type'}
+    _toPy = {'arches': 'arches', 'cost': 'cost', 'cpu-cores': 'cpu_cores', 'deprecated': 'deprecated', 'memory': 'memory', 'name': 'name', 'root-disk': 'root_disk', 'virt-type': 'virt_type'}
+    def __init__(self, arches=None, cost=None, cpu_cores=None, deprecated=None, memory=None, name=None, root_disk=None, virt_type=None):
+        '''
+        arches : typing.Sequence<+T_co>[str]
+        cost : int
+        cpu_cores : int
+        deprecated : bool
+        memory : int
+        name : str
+        root_disk : int
+        virt_type : str
+        '''
+        self.arches = arches
+        self.cost = cost
+        self.cpu_cores = cpu_cores
+        self.deprecated = deprecated
+        self.memory = memory
+        self.name = name
+        self.root_disk = root_disk
+        self.virt_type = virt_type
+
+
+class InstanceTypesResult(Type):
+    _toSchema = {'cost_currency': 'cost-currency', 'cost_divisor': 'cost-divisor', 'cost_unit': 'cost-unit', 'error': 'error', 'instance_types': 'instance-types'}
+    _toPy = {'cost-currency': 'cost_currency', 'cost-divisor': 'cost_divisor', 'cost-unit': 'cost_unit', 'error': 'error', 'instance-types': 'instance_types'}
+    def __init__(self, cost_currency=None, cost_divisor=None, cost_unit=None, error=None, instance_types=None):
+        '''
+        cost_currency : str
+        cost_divisor : int
+        cost_unit : str
+        error : Error
+        instance_types : typing.Sequence<+T_co>[~InstanceType]<~InstanceType>
+        '''
+        self.cost_currency = cost_currency
+        self.cost_divisor = cost_divisor
+        self.cost_unit = cost_unit
+        self.error = Error.from_json(error) if error else None
+        self.instance_types = [InstanceType.from_json(o) for o in instance_types or []]
+
+
+class InstanceTypesResults(Type):
+    _toSchema = {'results': 'results'}
+    _toPy = {'results': 'results'}
+    def __init__(self, results=None):
+        '''
+        results : typing.Sequence<+T_co>[~InstanceTypesResult]<~InstanceTypesResult>
+        '''
+        self.results = [InstanceTypesResult.from_json(o) for o in results or []]
+
+
 class StringsResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -2333,8 +2447,8 @@ class StringsResults(Type):
 
 
 class UpdateCloudCredential(Type):
-    _toSchema = {'tag': 'tag', 'credential': 'credential'}
-    _toPy = {'tag': 'tag', 'credential': 'credential'}
+    _toSchema = {'credential': 'credential', 'tag': 'tag'}
+    _toPy = {'credential': 'credential', 'tag': 'tag'}
     def __init__(self, credential=None, tag=None):
         '''
         credential : CloudCredential
@@ -2386,6 +2500,34 @@ class DestroyControllerArgs(Type):
         self.destroy_models = destroy_models
 
 
+class HostedModelConfig(Type):
+    _toSchema = {'cloud_spec': 'cloud-spec', 'config': 'config', 'error': 'error', 'name': 'name', 'owner': 'owner'}
+    _toPy = {'cloud-spec': 'cloud_spec', 'config': 'config', 'error': 'error', 'name': 'name', 'owner': 'owner'}
+    def __init__(self, cloud_spec=None, config=None, error=None, name=None, owner=None):
+        '''
+        cloud_spec : CloudSpec
+        config : typing.Mapping<~KT, +VT_co>[str, typing.Any]
+        error : Error
+        name : str
+        owner : str
+        '''
+        self.cloud_spec = CloudSpec.from_json(cloud_spec) if cloud_spec else None
+        self.config = config
+        self.error = Error.from_json(error) if error else None
+        self.name = name
+        self.owner = owner
+
+
+class HostedModelConfigsResults(Type):
+    _toSchema = {'models': 'models'}
+    _toPy = {'models': 'models'}
+    def __init__(self, models=None):
+        '''
+        models : typing.Sequence<+T_co>[~HostedModelConfig]<~HostedModelConfig>
+        '''
+        self.models = [HostedModelConfig.from_json(o) for o in models or []]
+
+
 class InitiateMigrationArgs(Type):
     _toSchema = {'specs': 'specs'}
     _toPy = {'specs': 'specs'}
@@ -2397,8 +2539,8 @@ class InitiateMigrationArgs(Type):
 
 
 class InitiateMigrationResult(Type):
-    _toSchema = {'model_tag': 'model-tag', 'migration_id': 'migration-id', 'error': 'error'}
-    _toPy = {'model-tag': 'model_tag', 'migration-id': 'migration_id', 'error': 'error'}
+    _toSchema = {'error': 'error', 'migration_id': 'migration-id', 'model_tag': 'model-tag'}
+    _toPy = {'error': 'error', 'migration-id': 'migration_id', 'model-tag': 'model_tag'}
     def __init__(self, error=None, migration_id=None, model_tag=None):
         '''
         error : Error
@@ -2421,39 +2563,43 @@ class InitiateMigrationResults(Type):
 
 
 class MigrationSpec(Type):
-    _toSchema = {'model_tag': 'model-tag', 'target_info': 'target-info'}
-    _toPy = {'model-tag': 'model_tag', 'target-info': 'target_info'}
-    def __init__(self, model_tag=None, target_info=None):
+    _toSchema = {'external_control': 'external-control', 'model_tag': 'model-tag', 'skip_initial_prechecks': 'skip-initial-prechecks', 'target_info': 'target-info'}
+    _toPy = {'external-control': 'external_control', 'model-tag': 'model_tag', 'skip-initial-prechecks': 'skip_initial_prechecks', 'target-info': 'target_info'}
+    def __init__(self, external_control=None, model_tag=None, skip_initial_prechecks=None, target_info=None):
         '''
+        external_control : bool
         model_tag : str
+        skip_initial_prechecks : bool
         target_info : MigrationTargetInfo
         '''
+        self.external_control = external_control
         self.model_tag = model_tag
+        self.skip_initial_prechecks = skip_initial_prechecks
         self.target_info = MigrationTargetInfo.from_json(target_info) if target_info else None
 
 
 class MigrationTargetInfo(Type):
-    _toSchema = {'password': 'password', 'controller_tag': 'controller-tag', 'addrs': 'addrs', 'ca_cert': 'ca-cert', 'macaroon': 'macaroon', 'auth_tag': 'auth-tag'}
-    _toPy = {'auth-tag': 'auth_tag', 'password': 'password', 'ca-cert': 'ca_cert', 'addrs': 'addrs', 'macaroon': 'macaroon', 'controller-tag': 'controller_tag'}
-    def __init__(self, addrs=None, auth_tag=None, ca_cert=None, controller_tag=None, macaroon=None, password=None):
+    _toSchema = {'addrs': 'addrs', 'auth_tag': 'auth-tag', 'ca_cert': 'ca-cert', 'controller_tag': 'controller-tag', 'macaroons': 'macaroons', 'password': 'password'}
+    _toPy = {'addrs': 'addrs', 'auth-tag': 'auth_tag', 'ca-cert': 'ca_cert', 'controller-tag': 'controller_tag', 'macaroons': 'macaroons', 'password': 'password'}
+    def __init__(self, addrs=None, auth_tag=None, ca_cert=None, controller_tag=None, macaroons=None, password=None):
         '''
         addrs : typing.Sequence<+T_co>[str]
         auth_tag : str
         ca_cert : str
         controller_tag : str
-        macaroon : str
+        macaroons : str
         password : str
         '''
         self.addrs = addrs
         self.auth_tag = auth_tag
         self.ca_cert = ca_cert
         self.controller_tag = controller_tag
-        self.macaroon = macaroon
+        self.macaroons = macaroons
         self.password = password
 
 
 class Model(Type):
-    _toSchema = {'name': 'name', 'uuid': 'uuid', 'owner_tag': 'owner-tag'}
+    _toSchema = {'name': 'name', 'owner_tag': 'owner-tag', 'uuid': 'uuid'}
     _toPy = {'name': 'name', 'owner-tag': 'owner_tag', 'uuid': 'uuid'}
     def __init__(self, name=None, owner_tag=None, uuid=None):
         '''
@@ -2467,8 +2613,8 @@ class Model(Type):
 
 
 class ModelBlockInfo(Type):
-    _toSchema = {'name': 'name', 'model_uuid': 'model-uuid', 'owner_tag': 'owner-tag', 'blocks': 'blocks'}
-    _toPy = {'name': 'name', 'owner-tag': 'owner_tag', 'model-uuid': 'model_uuid', 'blocks': 'blocks'}
+    _toSchema = {'blocks': 'blocks', 'model_uuid': 'model-uuid', 'name': 'name', 'owner_tag': 'owner-tag'}
+    _toPy = {'blocks': 'blocks', 'model-uuid': 'model_uuid', 'name': 'name', 'owner-tag': 'owner_tag'}
     def __init__(self, blocks=None, model_uuid=None, name=None, owner_tag=None):
         '''
         blocks : typing.Sequence<+T_co>[str]
@@ -2493,19 +2639,21 @@ class ModelBlockInfoList(Type):
 
 
 class ModelStatus(Type):
-    _toSchema = {'life': 'life', 'application_count': 'application-count', 'owner_tag': 'owner-tag', 'model_tag': 'model-tag', 'hosted_machine_count': 'hosted-machine-count'}
-    _toPy = {'life': 'life', 'model-tag': 'model_tag', 'owner-tag': 'owner_tag', 'hosted-machine-count': 'hosted_machine_count', 'application-count': 'application_count'}
-    def __init__(self, application_count=None, hosted_machine_count=None, life=None, model_tag=None, owner_tag=None):
+    _toSchema = {'application_count': 'application-count', 'hosted_machine_count': 'hosted-machine-count', 'life': 'life', 'machines': 'machines', 'model_tag': 'model-tag', 'owner_tag': 'owner-tag'}
+    _toPy = {'application-count': 'application_count', 'hosted-machine-count': 'hosted_machine_count', 'life': 'life', 'machines': 'machines', 'model-tag': 'model_tag', 'owner-tag': 'owner_tag'}
+    def __init__(self, application_count=None, hosted_machine_count=None, life=None, machines=None, model_tag=None, owner_tag=None):
         '''
         application_count : int
         hosted_machine_count : int
         life : str
+        machines : typing.Sequence<+T_co>[~ModelMachineInfo]<~ModelMachineInfo>
         model_tag : str
         owner_tag : str
         '''
         self.application_count = application_count
         self.hosted_machine_count = hosted_machine_count
         self.life = life
+        self.machines = [ModelMachineInfo.from_json(o) for o in machines or []]
         self.model_tag = model_tag
         self.owner_tag = owner_tag
 
@@ -2567,8 +2715,8 @@ class UserAccess(Type):
 
 
 class UserAccessResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -2622,7 +2770,7 @@ class BytesResult(Type):
 
 class DeployerConnectionValues(Type):
     _toSchema = {'api_addresses': 'api-addresses', 'state_addresses': 'state-addresses'}
-    _toPy = {'state-addresses': 'state_addresses', 'api-addresses': 'api_addresses'}
+    _toPy = {'api-addresses': 'api_addresses', 'state-addresses': 'state_addresses'}
     def __init__(self, api_addresses=None, state_addresses=None):
         '''
         api_addresses : typing.Sequence<+T_co>[str]
@@ -2632,9 +2780,25 @@ class DeployerConnectionValues(Type):
         self.state_addresses = state_addresses
 
 
+class EntityStatusArgs(Type):
+    _toSchema = {'data': 'data', 'info': 'info', 'status': 'status', 'tag': 'tag'}
+    _toPy = {'data': 'data', 'info': 'info', 'status': 'status', 'tag': 'tag'}
+    def __init__(self, data=None, info=None, status=None, tag=None):
+        '''
+        data : typing.Mapping<~KT, +VT_co>[str, typing.Any]
+        info : str
+        status : str
+        tag : str
+        '''
+        self.data = data
+        self.info = info
+        self.status = status
+        self.tag = tag
+
+
 class LifeResult(Type):
-    _toSchema = {'life': 'life', 'error': 'error'}
-    _toPy = {'life': 'life', 'error': 'error'}
+    _toSchema = {'error': 'error', 'life': 'life'}
+    _toPy = {'error': 'error', 'life': 'life'}
     def __init__(self, error=None, life=None):
         '''
         error : Error
@@ -2654,6 +2818,16 @@ class LifeResults(Type):
         self.results = [LifeResult.from_json(o) for o in results or []]
 
 
+class SetStatus(Type):
+    _toSchema = {'entities': 'entities'}
+    _toPy = {'entities': 'entities'}
+    def __init__(self, entities=None):
+        '''
+        entities : typing.Sequence<+T_co>[~EntityStatusArgs]<~EntityStatusArgs>
+        '''
+        self.entities = [EntityStatusArgs.from_json(o) for o in entities or []]
+
+
 class StringsWatchResults(Type):
     _toSchema = {'results': 'results'}
     _toPy = {'results': 'results'}
@@ -2665,8 +2839,8 @@ class StringsWatchResults(Type):
 
 
 class AddSubnetParams(Type):
-    _toSchema = {'subnet_tag': 'subnet-tag', 'subnet_provider_id': 'subnet-provider-id', 'space_tag': 'space-tag', 'zones': 'zones'}
-    _toPy = {'subnet-tag': 'subnet_tag', 'subnet-provider-id': 'subnet_provider_id', 'zones': 'zones', 'space-tag': 'space_tag'}
+    _toSchema = {'space_tag': 'space-tag', 'subnet_provider_id': 'subnet-provider-id', 'subnet_tag': 'subnet-tag', 'zones': 'zones'}
+    _toPy = {'space-tag': 'space_tag', 'subnet-provider-id': 'subnet_provider_id', 'subnet-tag': 'subnet_tag', 'zones': 'zones'}
     def __init__(self, space_tag=None, subnet_provider_id=None, subnet_tag=None, zones=None):
         '''
         space_tag : str
@@ -2691,8 +2865,8 @@ class AddSubnetsParams(Type):
 
 
 class CreateSpaceParams(Type):
-    _toSchema = {'provider_id': 'provider-id', 'space_tag': 'space-tag', 'subnet_tags': 'subnet-tags', 'public': 'public'}
-    _toPy = {'subnet-tags': 'subnet_tags', 'space-tag': 'space_tag', 'public': 'public', 'provider-id': 'provider_id'}
+    _toSchema = {'provider_id': 'provider-id', 'public': 'public', 'space_tag': 'space-tag', 'subnet_tags': 'subnet-tags'}
+    _toPy = {'provider-id': 'provider_id', 'public': 'public', 'space-tag': 'space_tag', 'subnet-tags': 'subnet_tags'}
     def __init__(self, provider_id=None, public=None, space_tag=None, subnet_tags=None):
         '''
         provider_id : str
@@ -2737,8 +2911,8 @@ class ListSubnetsResults(Type):
 
 
 class ProviderSpace(Type):
-    _toSchema = {'name': 'name', 'provider_id': 'provider-id', 'subnets': 'subnets', 'error': 'error'}
-    _toPy = {'name': 'name', 'subnets': 'subnets', 'provider-id': 'provider_id', 'error': 'error'}
+    _toSchema = {'error': 'error', 'name': 'name', 'provider_id': 'provider-id', 'subnets': 'subnets'}
+    _toPy = {'error': 'error', 'name': 'name', 'provider-id': 'provider_id', 'subnets': 'subnets'}
     def __init__(self, error=None, name=None, provider_id=None, subnets=None):
         '''
         error : Error
@@ -2753,8 +2927,8 @@ class ProviderSpace(Type):
 
 
 class Subnet(Type):
-    _toSchema = {'status': 'status', 'provider_id': 'provider-id', 'space_tag': 'space-tag', 'vlan_tag': 'vlan-tag', 'zones': 'zones', 'life': 'life', 'cidr': 'cidr'}
-    _toPy = {'status': 'status', 'zones': 'zones', 'vlan-tag': 'vlan_tag', 'life': 'life', 'cidr': 'cidr', 'space-tag': 'space_tag', 'provider-id': 'provider_id'}
+    _toSchema = {'cidr': 'cidr', 'life': 'life', 'provider_id': 'provider-id', 'space_tag': 'space-tag', 'status': 'status', 'vlan_tag': 'vlan-tag', 'zones': 'zones'}
+    _toPy = {'cidr': 'cidr', 'life': 'life', 'provider-id': 'provider_id', 'space-tag': 'space_tag', 'status': 'status', 'vlan-tag': 'vlan_tag', 'zones': 'zones'}
     def __init__(self, cidr=None, life=None, provider_id=None, space_tag=None, status=None, vlan_tag=None, zones=None):
         '''
         cidr : str
@@ -2787,8 +2961,8 @@ class SubnetsFilters(Type):
 
 
 class BlockDevice(Type):
-    _toSchema = {'uuid': 'UUID', 'busaddress': 'BusAddress', 'size': 'Size', 'hardwareid': 'HardwareId', 'filesystemtype': 'FilesystemType', 'label': 'Label', 'devicelinks': 'DeviceLinks', 'inuse': 'InUse', 'mountpoint': 'MountPoint', 'devicename': 'DeviceName'}
-    _toPy = {'InUse': 'inuse', 'Size': 'size', 'Label': 'label', 'DeviceName': 'devicename', 'BusAddress': 'busaddress', 'FilesystemType': 'filesystemtype', 'MountPoint': 'mountpoint', 'UUID': 'uuid', 'HardwareId': 'hardwareid', 'DeviceLinks': 'devicelinks'}
+    _toSchema = {'busaddress': 'BusAddress', 'devicelinks': 'DeviceLinks', 'devicename': 'DeviceName', 'filesystemtype': 'FilesystemType', 'hardwareid': 'HardwareId', 'inuse': 'InUse', 'label': 'Label', 'mountpoint': 'MountPoint', 'size': 'Size', 'uuid': 'UUID'}
+    _toPy = {'BusAddress': 'busaddress', 'DeviceLinks': 'devicelinks', 'DeviceName': 'devicename', 'FilesystemType': 'filesystemtype', 'HardwareId': 'hardwareid', 'InUse': 'inuse', 'Label': 'label', 'MountPoint': 'mountpoint', 'Size': 'size', 'UUID': 'uuid'}
     def __init__(self, busaddress=None, devicelinks=None, devicename=None, filesystemtype=None, hardwareid=None, inuse=None, label=None, mountpoint=None, size=None, uuid=None):
         '''
         busaddress : str
@@ -2837,8 +3011,8 @@ class SetMachineBlockDevices(Type):
 
 
 class EntitiesWatchResult(Type):
-    _toSchema = {'changes': 'changes', 'watcher_id': 'watcher-id', 'error': 'error'}
-    _toPy = {'watcher-id': 'watcher_id', 'changes': 'changes', 'error': 'error'}
+    _toSchema = {'changes': 'changes', 'error': 'error', 'watcher_id': 'watcher-id'}
+    _toPy = {'changes': 'changes', 'error': 'error', 'watcher-id': 'watcher_id'}
     def __init__(self, changes=None, error=None, watcher_id=None):
         '''
         changes : typing.Sequence<+T_co>[str]
@@ -2851,7 +3025,7 @@ class EntitiesWatchResult(Type):
 
 
 class MachineStorageId(Type):
-    _toSchema = {'machine_tag': 'machine-tag', 'attachment_tag': 'attachment-tag'}
+    _toSchema = {'attachment_tag': 'attachment-tag', 'machine_tag': 'machine-tag'}
     _toPy = {'attachment-tag': 'attachment_tag', 'machine-tag': 'machine_tag'}
     def __init__(self, attachment_tag=None, machine_tag=None):
         '''
@@ -2863,8 +3037,8 @@ class MachineStorageId(Type):
 
 
 class MachineStorageIdsWatchResult(Type):
-    _toSchema = {'changes': 'changes', 'watcher_id': 'watcher-id', 'error': 'error'}
-    _toPy = {'watcher-id': 'watcher_id', 'changes': 'changes', 'error': 'error'}
+    _toSchema = {'changes': 'changes', 'error': 'error', 'watcher_id': 'watcher-id'}
+    _toPy = {'changes': 'changes', 'error': 'error', 'watcher-id': 'watcher_id'}
     def __init__(self, changes=None, error=None, watcher_id=None):
         '''
         changes : typing.Sequence<+T_co>[~MachineStorageId]<~MachineStorageId>
@@ -2877,8 +3051,8 @@ class MachineStorageIdsWatchResult(Type):
 
 
 class BoolResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -2899,8 +3073,8 @@ class BoolResults(Type):
 
 
 class MachinePortRange(Type):
-    _toSchema = {'relation_tag': 'relation-tag', 'port_range': 'port-range', 'unit_tag': 'unit-tag'}
-    _toPy = {'relation-tag': 'relation_tag', 'port-range': 'port_range', 'unit-tag': 'unit_tag'}
+    _toSchema = {'port_range': 'port-range', 'relation_tag': 'relation-tag', 'unit_tag': 'unit-tag'}
+    _toPy = {'port-range': 'port_range', 'relation-tag': 'relation_tag', 'unit-tag': 'unit_tag'}
     def __init__(self, port_range=None, relation_tag=None, unit_tag=None):
         '''
         port_range : PortRange
@@ -2913,8 +3087,8 @@ class MachinePortRange(Type):
 
 
 class MachinePorts(Type):
-    _toSchema = {'subnet_tag': 'subnet-tag', 'machine_tag': 'machine-tag'}
-    _toPy = {'subnet-tag': 'subnet_tag', 'machine-tag': 'machine_tag'}
+    _toSchema = {'machine_tag': 'machine-tag', 'subnet_tag': 'subnet-tag'}
+    _toPy = {'machine-tag': 'machine_tag', 'subnet-tag': 'subnet_tag'}
     def __init__(self, machine_tag=None, subnet_tag=None):
         '''
         machine_tag : str
@@ -2935,8 +3109,8 @@ class MachinePortsParams(Type):
 
 
 class MachinePortsResult(Type):
-    _toSchema = {'ports': 'ports', 'error': 'error'}
-    _toPy = {'ports': 'ports', 'error': 'error'}
+    _toSchema = {'error': 'error', 'ports': 'ports'}
+    _toPy = {'error': 'error', 'ports': 'ports'}
     def __init__(self, error=None, ports=None):
         '''
         error : Error
@@ -2956,18 +3130,8 @@ class MachinePortsResults(Type):
         self.results = [MachinePortsResult.from_json(o) for o in results or []]
 
 
-class NotifyWatchResults(Type):
-    _toSchema = {'results': 'results'}
-    _toPy = {'results': 'results'}
-    def __init__(self, results=None):
-        '''
-        results : typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
-        '''
-        self.results = [NotifyWatchResult.from_json(o) for o in results or []]
-
-
 class PortRange(Type):
-    _toSchema = {'from_port': 'from-port', 'to_port': 'to-port', 'protocol': 'protocol'}
+    _toSchema = {'from_port': 'from-port', 'protocol': 'protocol', 'to_port': 'to-port'}
     _toPy = {'from-port': 'from_port', 'protocol': 'protocol', 'to-port': 'to_port'}
     def __init__(self, from_port=None, protocol=None, to_port=None):
         '''
@@ -2991,8 +3155,8 @@ class StringResults(Type):
 
 
 class ControllersChangeResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -3013,8 +3177,8 @@ class ControllersChangeResults(Type):
 
 
 class ControllersChanges(Type):
-    _toSchema = {'removed': 'removed', 'demoted': 'demoted', 'added': 'added', 'maintained': 'maintained', 'converted': 'converted', 'promoted': 'promoted'}
-    _toPy = {'removed': 'removed', 'demoted': 'demoted', 'added': 'added', 'maintained': 'maintained', 'converted': 'converted', 'promoted': 'promoted'}
+    _toSchema = {'added': 'added', 'converted': 'converted', 'demoted': 'demoted', 'maintained': 'maintained', 'promoted': 'promoted', 'removed': 'removed'}
+    _toPy = {'added': 'added', 'converted': 'converted', 'demoted': 'demoted', 'maintained': 'maintained', 'promoted': 'promoted', 'removed': 'removed'}
     def __init__(self, added=None, converted=None, demoted=None, maintained=None, promoted=None, removed=None):
         '''
         added : typing.Sequence<+T_co>[str]
@@ -3033,18 +3197,16 @@ class ControllersChanges(Type):
 
 
 class ControllersSpec(Type):
-    _toSchema = {'model_tag': 'model-tag', 'num_controllers': 'num-controllers', 'series': 'series', 'constraints': 'constraints', 'placement': 'placement'}
-    _toPy = {'model-tag': 'model_tag', 'placement': 'placement', 'num-controllers': 'num_controllers', 'constraints': 'constraints', 'series': 'series'}
-    def __init__(self, constraints=None, model_tag=None, num_controllers=None, placement=None, series=None):
+    _toSchema = {'constraints': 'constraints', 'num_controllers': 'num-controllers', 'placement': 'placement', 'series': 'series'}
+    _toPy = {'constraints': 'constraints', 'num-controllers': 'num_controllers', 'placement': 'placement', 'series': 'series'}
+    def __init__(self, constraints=None, num_controllers=None, placement=None, series=None):
         '''
         constraints : Value
-        model_tag : str
         num_controllers : int
         placement : typing.Sequence<+T_co>[str]
         series : str
         '''
         self.constraints = Value.from_json(constraints) if constraints else None
-        self.model_tag = model_tag
         self.num_controllers = num_controllers
         self.placement = placement
         self.series = series
@@ -3061,8 +3223,8 @@ class ControllersSpecs(Type):
 
 
 class HAMember(Type):
-    _toSchema = {'tag': 'tag', 'series': 'series', 'public_address': 'public-address'}
-    _toPy = {'public-address': 'public_address', 'tag': 'tag', 'series': 'series'}
+    _toSchema = {'public_address': 'public-address', 'series': 'series', 'tag': 'tag'}
+    _toPy = {'public-address': 'public_address', 'series': 'series', 'tag': 'tag'}
     def __init__(self, public_address=None, series=None, tag=None):
         '''
         public_address : Address
@@ -3075,8 +3237,8 @@ class HAMember(Type):
 
 
 class Member(Type):
-    _toSchema = {'votes': 'Votes', 'buildindexes': 'BuildIndexes', 'tags': 'Tags', 'arbiter': 'Arbiter', 'address': 'Address', 'priority': 'Priority', 'hidden': 'Hidden', 'id_': 'Id', 'slavedelay': 'SlaveDelay'}
-    _toPy = {'Id': 'id_', 'BuildIndexes': 'buildindexes', 'Address': 'address', 'SlaveDelay': 'slavedelay', 'Tags': 'tags', 'Votes': 'votes', 'Priority': 'priority', 'Hidden': 'hidden', 'Arbiter': 'arbiter'}
+    _toSchema = {'address': 'Address', 'arbiter': 'Arbiter', 'buildindexes': 'BuildIndexes', 'hidden': 'Hidden', 'id_': 'Id', 'priority': 'Priority', 'slavedelay': 'SlaveDelay', 'tags': 'Tags', 'votes': 'Votes'}
+    _toPy = {'Address': 'address', 'Arbiter': 'arbiter', 'BuildIndexes': 'buildindexes', 'Hidden': 'hidden', 'Id': 'id_', 'Priority': 'priority', 'SlaveDelay': 'slavedelay', 'Tags': 'tags', 'Votes': 'votes'}
     def __init__(self, address=None, arbiter=None, buildindexes=None, hidden=None, id_=None, priority=None, slavedelay=None, tags=None, votes=None):
         '''
         address : str
@@ -3101,8 +3263,8 @@ class Member(Type):
 
 
 class MongoUpgradeResults(Type):
-    _toSchema = {'rs_members': 'rs-members', 'ha_members': 'ha-members', 'master': 'master'}
-    _toPy = {'ha-members': 'ha_members', 'rs-members': 'rs_members', 'master': 'master'}
+    _toSchema = {'ha_members': 'ha-members', 'master': 'master', 'rs_members': 'rs-members'}
+    _toPy = {'ha-members': 'ha_members', 'master': 'master', 'rs-members': 'rs_members'}
     def __init__(self, ha_members=None, master=None, rs_members=None):
         '''
         ha_members : typing.Sequence<+T_co>[~HAMember]<~HAMember>
@@ -3114,6 +3276,22 @@ class MongoUpgradeResults(Type):
         self.rs_members = [Member.from_json(o) for o in rs_members or []]
 
 
+class MongoVersion(Type):
+    _toSchema = {'engine': 'engine', 'major': 'major', 'minor': 'minor', 'patch': 'patch'}
+    _toPy = {'engine': 'engine', 'major': 'major', 'minor': 'minor', 'patch': 'patch'}
+    def __init__(self, engine=None, major=None, minor=None, patch=None):
+        '''
+        engine : str
+        major : int
+        minor : int
+        patch : str
+        '''
+        self.engine = engine
+        self.major = major
+        self.minor = minor
+        self.patch = patch
+
+
 class ResumeReplicationParams(Type):
     _toSchema = {'members': 'members'}
     _toPy = {'members': 'members'}
@@ -3125,35 +3303,13 @@ class ResumeReplicationParams(Type):
 
 
 class UpgradeMongoParams(Type):
-    _toSchema = {'patch': 'Patch', 'minor': 'Minor', 'major': 'Major', 'storageengine': 'StorageEngine'}
-    _toPy = {'Major': 'major', 'Minor': 'minor', 'Patch': 'patch', 'StorageEngine': 'storageengine'}
-    def __init__(self, major=None, minor=None, patch=None, storageengine=None):
-        '''
-        major : int
-        minor : int
-        patch : str
-        storageengine : str
-        '''
-        self.major = major
-        self.minor = minor
-        self.patch = patch
-        self.storageengine = storageengine
-
-
-class Version(Type):
-    _toSchema = {'patch': 'Patch', 'minor': 'Minor', 'major': 'Major', 'storageengine': 'StorageEngine'}
-    _toPy = {'Major': 'major', 'Minor': 'minor', 'Patch': 'patch', 'StorageEngine': 'storageengine'}
-    def __init__(self, major=None, minor=None, patch=None, storageengine=None):
+    _toSchema = {'target': 'target'}
+    _toPy = {'target': 'target'}
+    def __init__(self, target=None):
         '''
-        major : int
-        minor : int
-        patch : str
-        storageengine : str
+        target : MongoVersion
         '''
-        self.major = major
-        self.minor = minor
-        self.patch = patch
-        self.storageengine = storageengine
+        self.target = MongoVersion.from_json(target) if target else None
 
 
 class SSHHostKeySet(Type):
@@ -3167,8 +3323,8 @@ class SSHHostKeySet(Type):
 
 
 class SSHHostKeys(Type):
-    _toSchema = {'tag': 'tag', 'public_keys': 'public-keys'}
-    _toPy = {'tag': 'tag', 'public-keys': 'public_keys'}
+    _toSchema = {'public_keys': 'public-keys', 'tag': 'tag'}
+    _toPy = {'public-keys': 'public_keys', 'tag': 'tag'}
     def __init__(self, public_keys=None, tag=None):
         '''
         public_keys : typing.Sequence<+T_co>[str]
@@ -3189,8 +3345,8 @@ class ImageFilterParams(Type):
 
 
 class ImageMetadata(Type):
-    _toSchema = {'kind': 'kind', 'created': 'created', 'url': 'url', 'series': 'series', 'arch': 'arch'}
-    _toPy = {'kind': 'kind', 'created': 'created', 'url': 'url', 'series': 'series', 'arch': 'arch'}
+    _toSchema = {'arch': 'arch', 'created': 'created', 'kind': 'kind', 'series': 'series', 'url': 'url'}
+    _toPy = {'arch': 'arch', 'created': 'created', 'kind': 'kind', 'series': 'series', 'url': 'url'}
     def __init__(self, arch=None, created=None, kind=None, series=None, url=None):
         '''
         arch : str
@@ -3207,8 +3363,8 @@ class ImageMetadata(Type):
 
 
 class ImageSpec(Type):
-    _toSchema = {'kind': 'kind', 'series': 'series', 'arch': 'arch'}
-    _toPy = {'kind': 'kind', 'series': 'series', 'arch': 'arch'}
+    _toSchema = {'arch': 'arch', 'kind': 'kind', 'series': 'series'}
+    _toPy = {'arch': 'arch', 'kind': 'kind', 'series': 'series'}
     def __init__(self, arch=None, kind=None, series=None):
         '''
         arch : str
@@ -3231,8 +3387,8 @@ class ListImageResult(Type):
 
 
 class CloudImageMetadata(Type):
-    _toSchema = {'image_id': 'image-id', 'source': 'source', 'stream': 'stream', 'root_storage_type': 'root-storage-type', 'virt_type': 'virt-type', 'series': 'series', 'arch': 'arch', 'priority': 'priority', 'region': 'region', 'root_storage_size': 'root-storage-size', 'version': 'version'}
-    _toPy = {'source': 'source', 'stream': 'stream', 'series': 'series', 'root-storage-size': 'root_storage_size', 'image-id': 'image_id', 'virt-type': 'virt_type', 'priority': 'priority', 'arch': 'arch', 'region': 'region', 'root-storage-type': 'root_storage_type', 'version': 'version'}
+    _toSchema = {'arch': 'arch', 'image_id': 'image-id', 'priority': 'priority', 'region': 'region', 'root_storage_size': 'root-storage-size', 'root_storage_type': 'root-storage-type', 'series': 'series', 'source': 'source', 'stream': 'stream', 'version': 'version', 'virt_type': 'virt-type'}
+    _toPy = {'arch': 'arch', 'image-id': 'image_id', 'priority': 'priority', 'region': 'region', 'root-storage-size': 'root_storage_size', 'root-storage-type': 'root_storage_type', 'series': 'series', 'source': 'source', 'stream': 'stream', 'version': 'version', 'virt-type': 'virt_type'}
     def __init__(self, arch=None, image_id=None, priority=None, region=None, root_storage_size=None, root_storage_type=None, series=None, source=None, stream=None, version=None, virt_type=None):
         '''
         arch : str
@@ -3271,8 +3427,8 @@ class CloudImageMetadataList(Type):
 
 
 class ImageMetadataFilter(Type):
-    _toSchema = {'stream': 'stream', 'root_storage_type': 'root-storage-type', 'virt_type': 'virt-type', 'series': 'series', 'region': 'region', 'arches': 'arches'}
-    _toPy = {'stream': 'stream', 'arches': 'arches', 'series': 'series', 'virt-type': 'virt_type', 'region': 'region', 'root-storage-type': 'root_storage_type'}
+    _toSchema = {'arches': 'arches', 'region': 'region', 'root_storage_type': 'root-storage-type', 'series': 'series', 'stream': 'stream', 'virt_type': 'virt-type'}
+    _toPy = {'arches': 'arches', 'region': 'region', 'root-storage-type': 'root_storage_type', 'series': 'series', 'stream': 'stream', 'virt-type': 'virt_type'}
     def __init__(self, arches=None, region=None, root_storage_type=None, series=None, stream=None, virt_type=None):
         '''
         arches : typing.Sequence<+T_co>[str]
@@ -3320,22 +3476,6 @@ class MetadataSaveParams(Type):
         self.metadata = [CloudImageMetadataList.from_json(o) for o in metadata or []]
 
 
-class EntityStatusArgs(Type):
-    _toSchema = {'info': 'info', 'data': 'data', 'tag': 'tag', 'status': 'status'}
-    _toPy = {'info': 'info', 'data': 'data', 'tag': 'tag', 'status': 'status'}
-    def __init__(self, data=None, info=None, status=None, tag=None):
-        '''
-        data : typing.Mapping<~KT, +VT_co>[str, typing.Any]
-        info : str
-        status : str
-        tag : str
-        '''
-        self.data = data
-        self.info = info
-        self.status = status
-        self.tag = tag
-
-
 class MachineAddresses(Type):
     _toSchema = {'addresses': 'addresses', 'tag': 'tag'}
     _toPy = {'addresses': 'addresses', 'tag': 'tag'}
@@ -3380,19 +3520,9 @@ class SetMachinesAddresses(Type):
         self.machine_addresses = [MachineAddresses.from_json(o) for o in machine_addresses or []]
 
 
-class SetStatus(Type):
-    _toSchema = {'entities': 'entities'}
-    _toPy = {'entities': 'entities'}
-    def __init__(self, entities=None):
-        '''
-        entities : typing.Sequence<+T_co>[~EntityStatusArgs]<~EntityStatusArgs>
-        '''
-        self.entities = [EntityStatusArgs.from_json(o) for o in entities or []]
-
-
 class StatusResult(Type):
-    _toSchema = {'info': 'info', 'data': 'data', 'since': 'since', 'error': 'error', 'life': 'life', 'status': 'status', 'id_': 'id'}
-    _toPy = {'info': 'info', 'data': 'data', 'since': 'since', 'error': 'error', 'life': 'life', 'status': 'status', 'id': 'id_'}
+    _toSchema = {'data': 'data', 'error': 'error', 'id_': 'id', 'info': 'info', 'life': 'life', 'since': 'since', 'status': 'status'}
+    _toPy = {'data': 'data', 'error': 'error', 'id': 'id_', 'info': 'info', 'life': 'life', 'since': 'since', 'status': 'status'}
     def __init__(self, data=None, error=None, id_=None, info=None, life=None, since=None, status=None):
         '''
         data : typing.Mapping<~KT, +VT_co>[str, typing.Any]
@@ -3436,7 +3566,7 @@ class ListSSHKeys(Type):
 
 class ModifyUserSSHKeys(Type):
     _toSchema = {'ssh_keys': 'ssh-keys', 'user': 'user'}
-    _toPy = {'user': 'user', 'ssh-keys': 'ssh_keys'}
+    _toPy = {'ssh-keys': 'ssh_keys', 'user': 'user'}
     def __init__(self, ssh_keys=None, user=None):
         '''
         ssh_keys : typing.Sequence<+T_co>[str]
@@ -3477,8 +3607,8 @@ class ClaimLeadershipBulkResults(Type):
 
 
 class ClaimLeadershipParams(Type):
-    _toSchema = {'unit_tag': 'unit-tag', 'duration': 'duration', 'application_tag': 'application-tag'}
-    _toPy = {'application-tag': 'application_tag', 'unit-tag': 'unit_tag', 'duration': 'duration'}
+    _toSchema = {'application_tag': 'application-tag', 'duration': 'duration', 'unit_tag': 'unit-tag'}
+    _toPy = {'application-tag': 'application_tag', 'duration': 'duration', 'unit-tag': 'unit_tag'}
     def __init__(self, application_tag=None, duration=None, unit_tag=None):
         '''
         application_tag : str
@@ -3501,8 +3631,8 @@ class LogForwardingGetLastSentParams(Type):
 
 
 class LogForwardingGetLastSentResult(Type):
-    _toSchema = {'record_id': 'record-id', 'record_timestamp': 'record-timestamp', 'err': 'err'}
-    _toPy = {'record-timestamp': 'record_timestamp', 'record-id': 'record_id', 'err': 'err'}
+    _toSchema = {'err': 'err', 'record_id': 'record-id', 'record_timestamp': 'record-timestamp'}
+    _toPy = {'err': 'err', 'record-id': 'record_id', 'record-timestamp': 'record_timestamp'}
     def __init__(self, err=None, record_id=None, record_timestamp=None):
         '''
         err : Error
@@ -3537,8 +3667,8 @@ class LogForwardingID(Type):
 
 
 class LogForwardingSetLastSentParam(Type):
-    _toSchema = {'record_id': 'record-id', 'logforwardingid': 'LogForwardingID', 'record_timestamp': 'record-timestamp'}
-    _toPy = {'record-id': 'record_id', 'LogForwardingID': 'logforwardingid', 'record-timestamp': 'record_timestamp'}
+    _toSchema = {'logforwardingid': 'LogForwardingID', 'record_id': 'record-id', 'record_timestamp': 'record-timestamp'}
+    _toPy = {'LogForwardingID': 'logforwardingid', 'record-id': 'record_id', 'record-timestamp': 'record_timestamp'}
     def __init__(self, logforwardingid=None, record_id=None, record_timestamp=None):
         '''
         logforwardingid : LogForwardingID
@@ -3561,8 +3691,8 @@ class LogForwardingSetLastSentParams(Type):
 
 
 class ActionExecutionResult(Type):
-    _toSchema = {'status': 'status', 'action_tag': 'action-tag', 'results': 'results', 'message': 'message'}
-    _toPy = {'status': 'status', 'results': 'results', 'action-tag': 'action_tag', 'message': 'message'}
+    _toSchema = {'action_tag': 'action-tag', 'message': 'message', 'results': 'results', 'status': 'status'}
+    _toPy = {'action-tag': 'action_tag', 'message': 'message', 'results': 'results', 'status': 'status'}
     def __init__(self, action_tag=None, message=None, results=None, status=None):
         '''
         action_tag : str
@@ -3586,6 +3716,26 @@ class ActionExecutionResults(Type):
         self.results = [ActionExecutionResult.from_json(o) for o in results or []]
 
 
+class ModelInstanceTypesConstraint(Type):
+    _toSchema = {'value': 'value'}
+    _toPy = {'value': 'value'}
+    def __init__(self, value=None):
+        '''
+        value : Value
+        '''
+        self.value = Value.from_json(value) if value else None
+
+
+class ModelInstanceTypesConstraints(Type):
+    _toSchema = {'constraints': 'constraints'}
+    _toPy = {'constraints': 'constraints'}
+    def __init__(self, constraints=None):
+        '''
+        constraints : typing.Sequence<+T_co>[~ModelInstanceTypesConstraint]<~ModelInstanceTypesConstraint>
+        '''
+        self.constraints = [ModelInstanceTypesConstraint.from_json(o) for o in constraints or []]
+
+
 class EntitiesResult(Type):
     _toSchema = {'entities': 'entities', 'error': 'error'}
     _toPy = {'entities': 'entities', 'error': 'error'}
@@ -3609,7 +3759,7 @@ class EntitiesResults(Type):
 
 
 class ProviderInterfaceInfo(Type):
-    _toSchema = {'provider_id': 'provider-id', 'mac_address': 'mac-address', 'interface_name': 'interface-name'}
+    _toSchema = {'interface_name': 'interface-name', 'mac_address': 'mac-address', 'provider_id': 'provider-id'}
     _toPy = {'interface-name': 'interface_name', 'mac-address': 'mac_address', 'provider-id': 'provider_id'}
     def __init__(self, interface_name=None, mac_address=None, provider_id=None):
         '''
@@ -3623,8 +3773,8 @@ class ProviderInterfaceInfo(Type):
 
 
 class ProviderInterfaceInfoResult(Type):
-    _toSchema = {'interfaces': 'interfaces', 'machine_tag': 'machine-tag', 'error': 'error'}
-    _toPy = {'interfaces': 'interfaces', 'machine-tag': 'machine_tag', 'error': 'error'}
+    _toSchema = {'error': 'error', 'interfaces': 'interfaces', 'machine_tag': 'machine-tag'}
+    _toPy = {'error': 'error', 'interfaces': 'interfaces', 'machine-tag': 'machine_tag'}
     def __init__(self, error=None, interfaces=None, machine_tag=None):
         '''
         error : Error
@@ -3647,8 +3797,8 @@ class ProviderInterfaceInfoResults(Type):
 
 
 class JobsResult(Type):
-    _toSchema = {'jobs': 'jobs', 'error': 'error'}
-    _toPy = {'jobs': 'jobs', 'error': 'error'}
+    _toSchema = {'error': 'error', 'jobs': 'jobs'}
+    _toPy = {'error': 'error', 'jobs': 'jobs'}
     def __init__(self, error=None, jobs=None):
         '''
         error : Error
@@ -3669,9 +3819,9 @@ class JobsResults(Type):
 
 
 class NetworkConfig(Type):
-    _toSchema = {'provider_address_id': 'provider-address-id', 'provider_id': 'provider-id', 'cidr': 'cidr', 'config_type': 'config-type', 'disabled': 'disabled', 'address': 'address', 'provider_vlan_id': 'provider-vlan-id', 'dns_servers': 'dns-servers', 'interface_type': 'interface-type', 'mac_address': 'mac-address', 'no_auto_start': 'no-auto-start', 'dns_search_domains': 'dns-search-domains', 'provider_subnet_id': 'provider-subnet-id', 'device_index': 'device-index', 'interface_name': 'interface-name', 'parent_interface_name': 'parent-interface-name', 'mtu': 'mtu', 'gateway_address': 'gateway-address', 'provider_space_id': 'provider-space-id', 'vlan_tag': 'vlan-tag'}
-    _toPy = {'provider-vlan-id': 'provider_vlan_id', 'interface-name': 'interface_name', 'gateway-address': 'gateway_address', 'no-auto-start': 'no_auto_start', 'address': 'address', 'parent-interface-name': 'parent_interface_name', 'provider-subnet-id': 'provider_subnet_id', 'dns-search-domains': 'dns_search_domains', 'dns-servers': 'dns_servers', 'interface-type': 'interface_type', 'provider-space-id': 'provider_space_id', 'mac-address': 'mac_address', 'device-index': 'device_index', 'disabled': 'disabled', 'config-type': 'config_type', 'provider-address-id': 'provider_address_id', 'mtu': 'mtu', 'cidr': 'cidr', 'vlan-tag': 'vlan_tag', 'provider-id': 'provider_id'}
-    def __init__(self, address=None, cidr=None, config_type=None, device_index=None, disabled=None, dns_search_domains=None, dns_servers=None, gateway_address=None, interface_name=None, interface_type=None, mac_address=None, mtu=None, no_auto_start=None, parent_interface_name=None, provider_address_id=None, provider_id=None, provider_space_id=None, provider_subnet_id=None, provider_vlan_id=None, vlan_tag=None):
+    _toSchema = {'address': 'address', 'cidr': 'cidr', 'config_type': 'config-type', 'device_index': 'device-index', 'disabled': 'disabled', 'dns_search_domains': 'dns-search-domains', 'dns_servers': 'dns-servers', 'gateway_address': 'gateway-address', 'interface_name': 'interface-name', 'interface_type': 'interface-type', 'mac_address': 'mac-address', 'mtu': 'mtu', 'no_auto_start': 'no-auto-start', 'parent_interface_name': 'parent-interface-name', 'provider_address_id': 'provider-address-id', 'provider_id': 'provider-id', 'provider_space_id': 'provider-space-id', 'provider_subnet_id': 'provider-subnet-id', 'provider_vlan_id': 'provider-vlan-id', 'routes': 'routes', 'vlan_tag': 'vlan-tag'}
+    _toPy = {'address': 'address', 'cidr': 'cidr', 'config-type': 'config_type', 'device-index': 'device_index', 'disabled': 'disabled', 'dns-search-domains': 'dns_search_domains', 'dns-servers': 'dns_servers', 'gateway-address': 'gateway_address', 'interface-name': 'interface_name', 'interface-type': 'interface_type', 'mac-address': 'mac_address', 'mtu': 'mtu', 'no-auto-start': 'no_auto_start', 'parent-interface-name': 'parent_interface_name', 'provider-address-id': 'provider_address_id', 'provider-id': 'provider_id', 'provider-space-id': 'provider_space_id', 'provider-subnet-id': 'provider_subnet_id', 'provider-vlan-id': 'provider_vlan_id', 'routes': 'routes', 'vlan-tag': 'vlan_tag'}
+    def __init__(self, address=None, cidr=None, config_type=None, device_index=None, disabled=None, dns_search_domains=None, dns_servers=None, gateway_address=None, interface_name=None, interface_type=None, mac_address=None, mtu=None, no_auto_start=None, parent_interface_name=None, provider_address_id=None, provider_id=None, provider_space_id=None, provider_subnet_id=None, provider_vlan_id=None, routes=None, vlan_tag=None):
         '''
         address : str
         cidr : str
@@ -3692,6 +3842,7 @@ class NetworkConfig(Type):
         provider_space_id : str
         provider_subnet_id : str
         provider_vlan_id : str
+        routes : typing.Sequence<+T_co>[~NetworkRoute]<~NetworkRoute>
         vlan_tag : int
         '''
         self.address = address
@@ -3713,9 +3864,24 @@ class NetworkConfig(Type):
         self.provider_space_id = provider_space_id
         self.provider_subnet_id = provider_subnet_id
         self.provider_vlan_id = provider_vlan_id
+        self.routes = [NetworkRoute.from_json(o) for o in routes or []]
         self.vlan_tag = vlan_tag
 
 
+class NetworkRoute(Type):
+    _toSchema = {'destination_cidr': 'destination-cidr', 'gateway_ip': 'gateway-ip', 'metric': 'metric'}
+    _toPy = {'destination-cidr': 'destination_cidr', 'gateway-ip': 'gateway_ip', 'metric': 'metric'}
+    def __init__(self, destination_cidr=None, gateway_ip=None, metric=None):
+        '''
+        destination_cidr : str
+        gateway_ip : str
+        metric : int
+        '''
+        self.destination_cidr = destination_cidr
+        self.gateway_ip = gateway_ip
+        self.metric = metric
+
+
 class SetMachineNetworkConfig(Type):
     _toSchema = {'config': 'config', 'tag': 'tag'}
     _toPy = {'config': 'config', 'tag': 'tag'}
@@ -3729,8 +3895,8 @@ class SetMachineNetworkConfig(Type):
 
 
 class MeterStatusResult(Type):
-    _toSchema = {'info': 'info', 'code': 'code', 'error': 'error'}
-    _toPy = {'info': 'info', 'code': 'code', 'error': 'error'}
+    _toSchema = {'code': 'code', 'error': 'error', 'info': 'info'}
+    _toPy = {'code': 'code', 'error': 'error', 'info': 'info'}
     def __init__(self, code=None, error=None, info=None):
         '''
         code : str
@@ -3753,8 +3919,8 @@ class MeterStatusResults(Type):
 
 
 class Metric(Type):
-    _toSchema = {'time': 'time', 'value': 'value', 'key': 'key'}
-    _toPy = {'time': 'time', 'value': 'value', 'key': 'key'}
+    _toSchema = {'key': 'key', 'time': 'time', 'value': 'value'}
+    _toPy = {'key': 'key', 'time': 'time', 'value': 'value'}
     def __init__(self, key=None, time=None, value=None):
         '''
         key : str
@@ -3767,8 +3933,8 @@ class Metric(Type):
 
 
 class MetricBatch(Type):
-    _toSchema = {'uuid': 'uuid', 'created': 'created', 'charm_url': 'charm-url', 'metrics': 'metrics'}
-    _toPy = {'uuid': 'uuid', 'charm-url': 'charm_url', 'created': 'created', 'metrics': 'metrics'}
+    _toSchema = {'charm_url': 'charm-url', 'created': 'created', 'metrics': 'metrics', 'uuid': 'uuid'}
+    _toPy = {'charm-url': 'charm_url', 'created': 'created', 'metrics': 'metrics', 'uuid': 'uuid'}
     def __init__(self, charm_url=None, created=None, metrics=None, uuid=None):
         '''
         charm_url : str
@@ -3805,8 +3971,8 @@ class MetricBatchParams(Type):
 
 
 class EntityMetrics(Type):
-    _toSchema = {'metrics': 'metrics', 'error': 'error'}
-    _toPy = {'metrics': 'metrics', 'error': 'error'}
+    _toSchema = {'error': 'error', 'metrics': 'metrics'}
+    _toPy = {'error': 'error', 'metrics': 'metrics'}
     def __init__(self, error=None, metrics=None):
         '''
         error : Error
@@ -3817,8 +3983,8 @@ class EntityMetrics(Type):
 
 
 class MeterStatusParam(Type):
-    _toSchema = {'info': 'info', 'tag': 'tag', 'code': 'code'}
-    _toPy = {'info': 'info', 'tag': 'tag', 'code': 'code'}
+    _toSchema = {'code': 'code', 'info': 'info', 'tag': 'tag'}
+    _toPy = {'code': 'code', 'info': 'info', 'tag': 'tag'}
     def __init__(self, code=None, info=None, tag=None):
         '''
         code : str
@@ -3841,16 +4007,18 @@ class MeterStatusParams(Type):
 
 
 class MetricResult(Type):
-    _toSchema = {'time': 'time', 'value': 'value', 'key': 'key'}
-    _toPy = {'time': 'time', 'value': 'value', 'key': 'key'}
-    def __init__(self, key=None, time=None, value=None):
+    _toSchema = {'key': 'key', 'time': 'time', 'unit': 'unit', 'value': 'value'}
+    _toPy = {'key': 'key', 'time': 'time', 'unit': 'unit', 'value': 'value'}
+    def __init__(self, key=None, time=None, unit=None, value=None):
         '''
         key : str
         time : str
+        unit : str
         value : str
         '''
         self.key = key
         self.time = time
+        self.unit = unit
         self.value = value
 
 
@@ -3865,8 +4033,8 @@ class MetricResults(Type):
 
 
 class PhaseResult(Type):
-    _toSchema = {'phase': 'phase', 'error': 'error'}
-    _toPy = {'phase': 'phase', 'error': 'error'}
+    _toSchema = {'error': 'error', 'phase': 'phase'}
+    _toPy = {'error': 'error', 'phase': 'phase'}
     def __init__(self, error=None, phase=None):
         '''
         error : Error
@@ -3887,8 +4055,8 @@ class PhaseResults(Type):
 
 
 class MasterMigrationStatus(Type):
-    _toSchema = {'phase': 'phase', 'phase_changed_time': 'phase-changed-time', 'migration_id': 'migration-id', 'spec': 'spec'}
-    _toPy = {'phase': 'phase', 'phase-changed-time': 'phase_changed_time', 'migration-id': 'migration_id', 'spec': 'spec'}
+    _toSchema = {'migration_id': 'migration-id', 'phase': 'phase', 'phase_changed_time': 'phase-changed-time', 'spec': 'spec'}
+    _toPy = {'migration-id': 'migration_id', 'phase': 'phase', 'phase-changed-time': 'phase_changed_time', 'spec': 'spec'}
     def __init__(self, migration_id=None, phase=None, phase_changed_time=None, spec=None):
         '''
         migration_id : str
@@ -3903,22 +4071,26 @@ class MasterMigrationStatus(Type):
 
 
 class MigrationModelInfo(Type):
-    _toSchema = {'agent_version': 'agent-version', 'uuid': 'uuid', 'name': 'name'}
-    _toPy = {'name': 'name', 'uuid': 'uuid', 'agent-version': 'agent_version'}
-    def __init__(self, agent_version=None, name=None, uuid=None):
+    _toSchema = {'agent_version': 'agent-version', 'controller_agent_version': 'controller-agent-version', 'name': 'name', 'owner_tag': 'owner-tag', 'uuid': 'uuid'}
+    _toPy = {'agent-version': 'agent_version', 'controller-agent-version': 'controller_agent_version', 'name': 'name', 'owner-tag': 'owner_tag', 'uuid': 'uuid'}
+    def __init__(self, agent_version=None, controller_agent_version=None, name=None, owner_tag=None, uuid=None):
         '''
         agent_version : Number
+        controller_agent_version : Number
         name : str
+        owner_tag : str
         uuid : str
         '''
         self.agent_version = Number.from_json(agent_version) if agent_version else None
+        self.controller_agent_version = Number.from_json(controller_agent_version) if controller_agent_version else None
         self.name = name
+        self.owner_tag = owner_tag
         self.uuid = uuid
 
 
 class MinionReports(Type):
-    _toSchema = {'unknown_sample': 'unknown-sample', 'phase': 'phase', 'failed': 'failed', 'success_count': 'success-count', 'migration_id': 'migration-id', 'unknown_count': 'unknown-count'}
-    _toPy = {'phase': 'phase', 'failed': 'failed', 'success-count': 'success_count', 'migration-id': 'migration_id', 'unknown-sample': 'unknown_sample', 'unknown-count': 'unknown_count'}
+    _toSchema = {'failed': 'failed', 'migration_id': 'migration-id', 'phase': 'phase', 'success_count': 'success-count', 'unknown_count': 'unknown-count', 'unknown_sample': 'unknown-sample'}
+    _toPy = {'failed': 'failed', 'migration-id': 'migration_id', 'phase': 'phase', 'success-count': 'success_count', 'unknown-count': 'unknown_count', 'unknown-sample': 'unknown_sample'}
     def __init__(self, failed=None, migration_id=None, phase=None, success_count=None, unknown_count=None, unknown_sample=None):
         '''
         failed : typing.Sequence<+T_co>[str]
@@ -3937,42 +4109,88 @@ class MinionReports(Type):
 
 
 class SerializedModel(Type):
-    _toSchema = {'charms': 'charms', 'bytes_': 'bytes', 'tools': 'tools'}
-    _toPy = {'charms': 'charms', 'tools': 'tools', 'bytes': 'bytes_'}
-    def __init__(self, bytes_=None, charms=None, tools=None):
+    _toSchema = {'bytes_': 'bytes', 'charms': 'charms', 'resources': 'resources', 'tools': 'tools'}
+    _toPy = {'bytes': 'bytes_', 'charms': 'charms', 'resources': 'resources', 'tools': 'tools'}
+    def __init__(self, bytes_=None, charms=None, resources=None, tools=None):
         '''
         bytes_ : typing.Sequence<+T_co>[int]
         charms : typing.Sequence<+T_co>[str]
+        resources : typing.Sequence<+T_co>[~SerializedModelResource]<~SerializedModelResource>
         tools : typing.Sequence<+T_co>[~SerializedModelTools]<~SerializedModelTools>
         '''
         self.bytes_ = bytes_
         self.charms = charms
+        self.resources = [SerializedModelResource.from_json(o) for o in resources or []]
         self.tools = [SerializedModelTools.from_json(o) for o in tools or []]
 
 
-class SerializedModelTools(Type):
-    _toSchema = {'uri': 'uri', 'version': 'version'}
-    _toPy = {'uri': 'uri', 'version': 'version'}
-    def __init__(self, uri=None, version=None):
+class SerializedModelResource(Type):
+    _toSchema = {'application': 'application', 'application_revision': 'application-revision', 'charmstore_revision': 'charmstore-revision', 'name': 'name', 'unit_revisions': 'unit-revisions'}
+    _toPy = {'application': 'application', 'application-revision': 'application_revision', 'charmstore-revision': 'charmstore_revision', 'name': 'name', 'unit-revisions': 'unit_revisions'}
+    def __init__(self, application=None, application_revision=None, charmstore_revision=None, name=None, unit_revisions=None):
         '''
-        uri : str
-        version : str
+        application : str
+        application_revision : SerializedModelResourceRevision
+        charmstore_revision : SerializedModelResourceRevision
+        name : str
+        unit_revisions : typing.Mapping<~KT, +VT_co>[str, ~SerializedModelResourceRevision]<~SerializedModelResourceRevision>
         '''
-        self.uri = uri
-        self.version = version
+        self.application = application
+        self.application_revision = SerializedModelResourceRevision.from_json(application_revision) if application_revision else None
+        self.charmstore_revision = SerializedModelResourceRevision.from_json(charmstore_revision) if charmstore_revision else None
+        self.name = name
+        self.unit_revisions = unit_revisions
 
 
-class SetMigrationPhaseArgs(Type):
-    _toSchema = {'phase': 'phase'}
-    _toPy = {'phase': 'phase'}
-    def __init__(self, phase=None):
-        '''
-        phase : str
+class SerializedModelResourceRevision(Type):
+    _toSchema = {'description': 'description', 'fingerprint': 'fingerprint', 'origin': 'origin', 'path': 'path', 'revision': 'revision', 'size': 'size', 'timestamp': 'timestamp', 'type_': 'type', 'username': 'username'}
+    _toPy = {'description': 'description', 'fingerprint': 'fingerprint', 'origin': 'origin', 'path': 'path', 'revision': 'revision', 'size': 'size', 'timestamp': 'timestamp', 'type': 'type_', 'username': 'username'}
+    def __init__(self, description=None, fingerprint=None, origin=None, path=None, revision=None, size=None, timestamp=None, type_=None, username=None):
         '''
-        self.phase = phase
-
-
-class SetMigrationStatusMessageArgs(Type):
+        description : str
+        fingerprint : str
+        origin : str
+        path : str
+        revision : int
+        size : int
+        timestamp : str
+        type_ : str
+        username : str
+        '''
+        self.description = description
+        self.fingerprint = fingerprint
+        self.origin = origin
+        self.path = path
+        self.revision = revision
+        self.size = size
+        self.timestamp = timestamp
+        self.type_ = type_
+        self.username = username
+
+
+class SerializedModelTools(Type):
+    _toSchema = {'uri': 'uri', 'version': 'version'}
+    _toPy = {'uri': 'uri', 'version': 'version'}
+    def __init__(self, uri=None, version=None):
+        '''
+        uri : str
+        version : str
+        '''
+        self.uri = uri
+        self.version = version
+
+
+class SetMigrationPhaseArgs(Type):
+    _toSchema = {'phase': 'phase'}
+    _toPy = {'phase': 'phase'}
+    def __init__(self, phase=None):
+        '''
+        phase : str
+        '''
+        self.phase = phase
+
+
+class SetMigrationStatusMessageArgs(Type):
     _toSchema = {'message': 'message'}
     _toPy = {'message': 'message'}
     def __init__(self, message=None):
@@ -3983,8 +4201,8 @@ class SetMigrationStatusMessageArgs(Type):
 
 
 class MinionReport(Type):
-    _toSchema = {'success': 'success', 'phase': 'phase', 'migration_id': 'migration-id'}
-    _toPy = {'success': 'success', 'phase': 'phase', 'migration-id': 'migration_id'}
+    _toSchema = {'migration_id': 'migration-id', 'phase': 'phase', 'success': 'success'}
+    _toPy = {'migration-id': 'migration_id', 'phase': 'phase', 'success': 'success'}
     def __init__(self, migration_id=None, phase=None, success=None):
         '''
         migration_id : str
@@ -3997,11 +4215,12 @@ class MinionReport(Type):
 
 
 class MigrationStatus(Type):
-    _toSchema = {'target_ca_cert': 'target-ca-cert', 'phase': 'phase', 'target_api_addrs': 'target-api-addrs', 'source_api_addrs': 'source-api-addrs', 'attempt': 'attempt', 'migration_id': 'migration-id', 'source_ca_cert': 'source-ca-cert'}
-    _toPy = {'phase': 'phase', 'source-ca-cert': 'source_ca_cert', 'target-api-addrs': 'target_api_addrs', 'target-ca-cert': 'target_ca_cert', 'source-api-addrs': 'source_api_addrs', 'attempt': 'attempt', 'migration-id': 'migration_id'}
-    def __init__(self, attempt=None, migration_id=None, phase=None, source_api_addrs=None, source_ca_cert=None, target_api_addrs=None, target_ca_cert=None):
+    _toSchema = {'attempt': 'attempt', 'external_control': 'external-control', 'migration_id': 'migration-id', 'phase': 'phase', 'source_api_addrs': 'source-api-addrs', 'source_ca_cert': 'source-ca-cert', 'target_api_addrs': 'target-api-addrs', 'target_ca_cert': 'target-ca-cert'}
+    _toPy = {'attempt': 'attempt', 'external-control': 'external_control', 'migration-id': 'migration_id', 'phase': 'phase', 'source-api-addrs': 'source_api_addrs', 'source-ca-cert': 'source_ca_cert', 'target-api-addrs': 'target_api_addrs', 'target-ca-cert': 'target_ca_cert'}
+    def __init__(self, attempt=None, external_control=None, migration_id=None, phase=None, source_api_addrs=None, source_ca_cert=None, target_api_addrs=None, target_ca_cert=None):
         '''
         attempt : int
+        external_control : bool
         migration_id : str
         phase : str
         source_api_addrs : typing.Sequence<+T_co>[str]
@@ -4010,6 +4229,7 @@ class MigrationStatus(Type):
         target_ca_cert : str
         '''
         self.attempt = attempt
+        self.external_control = external_control
         self.migration_id = migration_id
         self.phase = phase
         self.source_api_addrs = source_api_addrs
@@ -4018,37 +4238,31 @@ class MigrationStatus(Type):
         self.target_ca_cert = target_ca_cert
 
 
-class ModelArgs(Type):
-    _toSchema = {'model_tag': 'model-tag'}
-    _toPy = {'model-tag': 'model_tag'}
-    def __init__(self, model_tag=None):
+class AdoptResourcesArgs(Type):
+    _toSchema = {'model_tag': 'model-tag', 'source_controller_version': 'source-controller-version'}
+    _toPy = {'model-tag': 'model_tag', 'source-controller-version': 'source_controller_version'}
+    def __init__(self, model_tag=None, source_controller_version=None):
         '''
         model_tag : str
+        source_controller_version : Number
         '''
         self.model_tag = model_tag
+        self.source_controller_version = Number.from_json(source_controller_version) if source_controller_version else None
 
 
-class TargetPrechecksArgs(Type):
-    _toSchema = {'build': 'Build', 'patch': 'Patch', 'tag': 'Tag', 'minor': 'Minor', 'major': 'Major'}
-    _toPy = {'Tag': 'tag', 'Major': 'major', 'Patch': 'patch', 'Minor': 'minor', 'Build': 'build'}
-    def __init__(self, build=None, major=None, minor=None, patch=None, tag=None):
+class ModelArgs(Type):
+    _toSchema = {'model_tag': 'model-tag'}
+    _toPy = {'model-tag': 'model_tag'}
+    def __init__(self, model_tag=None):
         '''
-        build : int
-        major : int
-        minor : int
-        patch : int
-        tag : str
+        model_tag : str
         '''
-        self.build = build
-        self.major = major
-        self.minor = minor
-        self.patch = patch
-        self.tag = tag
+        self.model_tag = model_tag
 
 
 class MapResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -4069,8 +4283,8 @@ class MapResults(Type):
 
 
 class ModelCreateArgs(Type):
-    _toSchema = {'config': 'config', 'cloud_tag': 'cloud-tag', 'owner_tag': 'owner-tag', 'region': 'region', 'name': 'name', 'credential': 'credential'}
-    _toPy = {'config': 'config', 'region': 'region', 'name': 'name', 'owner-tag': 'owner_tag', 'cloud-tag': 'cloud_tag', 'credential': 'credential'}
+    _toSchema = {'cloud_tag': 'cloud-tag', 'config': 'config', 'credential': 'credential', 'name': 'name', 'owner_tag': 'owner-tag', 'region': 'region'}
+    _toPy = {'cloud-tag': 'cloud_tag', 'config': 'config', 'credential': 'credential', 'name': 'name', 'owner-tag': 'owner_tag', 'region': 'region'}
     def __init__(self, cloud_tag=None, config=None, credential=None, name=None, owner_tag=None, region=None):
         '''
         cloud_tag : str
@@ -4088,9 +4302,47 @@ class ModelCreateArgs(Type):
         self.region = region
 
 
+class ModelDefaultValues(Type):
+    _toSchema = {'cloud_region': 'cloud-region', 'cloud_tag': 'cloud-tag', 'config': 'config'}
+    _toPy = {'cloud-region': 'cloud_region', 'cloud-tag': 'cloud_tag', 'config': 'config'}
+    def __init__(self, cloud_region=None, cloud_tag=None, config=None):
+        '''
+        cloud_region : str
+        cloud_tag : str
+        config : typing.Mapping<~KT, +VT_co>[str, typing.Any]
+        '''
+        self.cloud_region = cloud_region
+        self.cloud_tag = cloud_tag
+        self.config = config
+
+
+class ModelDefaults(Type):
+    _toSchema = {'controller': 'controller', 'default': 'default', 'regions': 'regions'}
+    _toPy = {'controller': 'controller', 'default': 'default', 'regions': 'regions'}
+    def __init__(self, controller=None, default=None, regions=None):
+        '''
+        controller : typing.Mapping<~KT, +VT_co>[str, typing.Any]
+        default : typing.Mapping<~KT, +VT_co>[str, typing.Any]
+        regions : typing.Sequence<+T_co>[~RegionDefaults]<~RegionDefaults>
+        '''
+        self.controller = controller
+        self.default = default
+        self.regions = [RegionDefaults.from_json(o) for o in regions or []]
+
+
+class ModelDefaultsResult(Type):
+    _toSchema = {'config': 'config'}
+    _toPy = {'config': 'config'}
+    def __init__(self, config=None):
+        '''
+        config : typing.Mapping<~KT, +VT_co>[str, ~ModelDefaults]<~ModelDefaults>
+        '''
+        self.config = config
+
+
 class ModelInfoResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -4110,9 +4362,23 @@ class ModelInfoResults(Type):
         self.results = [ModelInfoResult.from_json(o) for o in results or []]
 
 
+class ModelUnsetKeys(Type):
+    _toSchema = {'cloud_region': 'cloud-region', 'cloud_tag': 'cloud-tag', 'keys': 'keys'}
+    _toPy = {'cloud-region': 'cloud_region', 'cloud-tag': 'cloud_tag', 'keys': 'keys'}
+    def __init__(self, cloud_region=None, cloud_tag=None, keys=None):
+        '''
+        cloud_region : str
+        cloud_tag : str
+        keys : typing.Sequence<+T_co>[str]
+        '''
+        self.cloud_region = cloud_region
+        self.cloud_tag = cloud_tag
+        self.keys = keys
+
+
 class ModifyModelAccess(Type):
-    _toSchema = {'model_tag': 'model-tag', 'access': 'access', 'action': 'action', 'user_tag': 'user-tag'}
-    _toPy = {'model-tag': 'model_tag', 'access': 'access', 'action': 'action', 'user-tag': 'user_tag'}
+    _toSchema = {'access': 'access', 'action': 'action', 'model_tag': 'model-tag', 'user_tag': 'user-tag'}
+    _toPy = {'access': 'access', 'action': 'action', 'model-tag': 'model_tag', 'user-tag': 'user_tag'}
     def __init__(self, access=None, action=None, model_tag=None, user_tag=None):
         '''
         access : str
@@ -4136,6 +4402,160 @@ class ModifyModelAccessRequest(Type):
         self.changes = [ModifyModelAccess.from_json(o) for o in changes or []]
 
 
+class RegionDefaults(Type):
+    _toSchema = {'region_name': 'region-name', 'value': 'value'}
+    _toPy = {'region-name': 'region_name', 'value': 'value'}
+    def __init__(self, region_name=None, value=None):
+        '''
+        region_name : str
+        value : typing.Mapping<~KT, +VT_co>[str, typing.Any]
+        '''
+        self.region_name = region_name
+        self.value = value
+
+
+class SetModelDefaults(Type):
+    _toSchema = {'config': 'config'}
+    _toPy = {'config': 'config'}
+    def __init__(self, config=None):
+        '''
+        config : typing.Sequence<+T_co>[~ModelDefaultValues]<~ModelDefaultValues>
+        '''
+        self.config = [ModelDefaultValues.from_json(o) for o in config or []]
+
+
+class UnsetModelDefaults(Type):
+    _toSchema = {'keys': 'keys'}
+    _toPy = {'keys': 'keys'}
+    def __init__(self, keys=None):
+        '''
+        keys : typing.Sequence<+T_co>[~ModelUnsetKeys]<~ModelUnsetKeys>
+        '''
+        self.keys = [ModelUnsetKeys.from_json(o) for o in keys or []]
+
+
+class EnvListArgs(Type):
+    _toSchema = {'patterns': 'patterns'}
+    _toPy = {'patterns': 'patterns'}
+    def __init__(self, patterns=None):
+        '''
+        patterns : typing.Sequence<+T_co>[str]
+        '''
+        self.patterns = patterns
+
+
+class EnvListResults(Type):
+    _toSchema = {'results': 'results'}
+    _toPy = {'results': 'results'}
+    def __init__(self, results=None):
+        '''
+        results : typing.Sequence<+T_co>[~Payload]<~Payload>
+        '''
+        self.results = [Payload.from_json(o) for o in results or []]
+
+
+class Payload(Type):
+    _toSchema = {'class_': 'class', 'id_': 'id', 'labels': 'labels', 'machine': 'machine', 'status': 'status', 'type_': 'type', 'unit': 'unit'}
+    _toPy = {'class': 'class_', 'id': 'id_', 'labels': 'labels', 'machine': 'machine', 'status': 'status', 'type': 'type_', 'unit': 'unit'}
+    def __init__(self, class_=None, id_=None, labels=None, machine=None, status=None, type_=None, unit=None):
+        '''
+        class_ : str
+        id_ : str
+        labels : typing.Sequence<+T_co>[str]
+        machine : str
+        status : str
+        type_ : str
+        unit : str
+        '''
+        self.class_ = class_
+        self.id_ = id_
+        self.labels = labels
+        self.machine = machine
+        self.status = status
+        self.type_ = type_
+        self.unit = unit
+
+
+class LookUpArg(Type):
+    _toSchema = {'id_': 'id', 'name': 'name'}
+    _toPy = {'id': 'id_', 'name': 'name'}
+    def __init__(self, id_=None, name=None):
+        '''
+        id_ : str
+        name : str
+        '''
+        self.id_ = id_
+        self.name = name
+
+
+class LookUpArgs(Type):
+    _toSchema = {'args': 'args'}
+    _toPy = {'args': 'args'}
+    def __init__(self, args=None):
+        '''
+        args : typing.Sequence<+T_co>[~LookUpArg]<~LookUpArg>
+        '''
+        self.args = [LookUpArg.from_json(o) for o in args or []]
+
+
+class PayloadResult(Type):
+    _toSchema = {'entity': 'Entity', 'error': 'error', 'not_found': 'not-found', 'payload': 'payload'}
+    _toPy = {'Entity': 'entity', 'error': 'error', 'not-found': 'not_found', 'payload': 'payload'}
+    def __init__(self, entity=None, error=None, not_found=None, payload=None):
+        '''
+        entity : Entity
+        error : Error
+        not_found : bool
+        payload : Payload
+        '''
+        self.entity = Entity.from_json(entity) if entity else None
+        self.error = Error.from_json(error) if error else None
+        self.not_found = not_found
+        self.payload = Payload.from_json(payload) if payload else None
+
+
+class PayloadResults(Type):
+    _toSchema = {'results': 'results'}
+    _toPy = {'results': 'results'}
+    def __init__(self, results=None):
+        '''
+        results : typing.Sequence<+T_co>[~PayloadResult]<~PayloadResult>
+        '''
+        self.results = [PayloadResult.from_json(o) for o in results or []]
+
+
+class SetStatusArg(Type):
+    _toSchema = {'entity': 'Entity', 'status': 'status'}
+    _toPy = {'Entity': 'entity', 'status': 'status'}
+    def __init__(self, entity=None, status=None):
+        '''
+        entity : Entity
+        status : str
+        '''
+        self.entity = Entity.from_json(entity) if entity else None
+        self.status = status
+
+
+class SetStatusArgs(Type):
+    _toSchema = {'args': 'args'}
+    _toPy = {'args': 'args'}
+    def __init__(self, args=None):
+        '''
+        args : typing.Sequence<+T_co>[~SetStatusArg]<~SetStatusArg>
+        '''
+        self.args = [SetStatusArg.from_json(o) for o in args or []]
+
+
+class TrackArgs(Type):
+    _toSchema = {'payloads': 'payloads'}
+    _toPy = {'payloads': 'payloads'}
+    def __init__(self, payloads=None):
+        '''
+        payloads : typing.Sequence<+T_co>[~Payload]<~Payload>
+        '''
+        self.payloads = [Payload.from_json(o) for o in payloads or []]
+
+
 class ConstraintsResult(Type):
     _toSchema = {'constraints': 'constraints', 'error': 'error'}
     _toPy = {'constraints': 'constraints', 'error': 'error'}
@@ -4159,8 +4579,8 @@ class ConstraintsResults(Type):
 
 
 class ContainerConfig(Type):
-    _toSchema = {'updatebehavior': 'UpdateBehavior', 'authorized_keys': 'authorized-keys', 'apt_mirror': 'apt-mirror', 'proxy': 'proxy', 'ssl_hostname_verification': 'ssl-hostname-verification', 'provider_type': 'provider-type', 'apt_proxy': 'apt-proxy'}
-    _toPy = {'ssl-hostname-verification': 'ssl_hostname_verification', 'apt-proxy': 'apt_proxy', 'proxy': 'proxy', 'apt-mirror': 'apt_mirror', 'UpdateBehavior': 'updatebehavior', 'authorized-keys': 'authorized_keys', 'provider-type': 'provider_type'}
+    _toSchema = {'apt_mirror': 'apt-mirror', 'apt_proxy': 'apt-proxy', 'authorized_keys': 'authorized-keys', 'provider_type': 'provider-type', 'proxy': 'proxy', 'ssl_hostname_verification': 'ssl-hostname-verification', 'updatebehavior': 'UpdateBehavior'}
+    _toPy = {'UpdateBehavior': 'updatebehavior', 'apt-mirror': 'apt_mirror', 'apt-proxy': 'apt_proxy', 'authorized-keys': 'authorized_keys', 'provider-type': 'provider_type', 'proxy': 'proxy', 'ssl-hostname-verification': 'ssl_hostname_verification'}
     def __init__(self, updatebehavior=None, apt_mirror=None, apt_proxy=None, authorized_keys=None, provider_type=None, proxy=None, ssl_hostname_verification=None):
         '''
         updatebehavior : UpdateBehavior
@@ -4200,9 +4620,21 @@ class ContainerManagerConfigParams(Type):
         self.type_ = type_
 
 
+class DeviceBridgeInfo(Type):
+    _toSchema = {'bridge_name': 'bridge-name', 'host_device_name': 'host-device-name'}
+    _toPy = {'bridge-name': 'bridge_name', 'host-device-name': 'host_device_name'}
+    def __init__(self, bridge_name=None, host_device_name=None):
+        '''
+        bridge_name : str
+        host_device_name : str
+        '''
+        self.bridge_name = bridge_name
+        self.host_device_name = host_device_name
+
+
 class DistributionGroupResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -4222,9 +4654,33 @@ class DistributionGroupResults(Type):
         self.results = [DistributionGroupResult.from_json(o) for o in results or []]
 
 
+class HostNetworkChange(Type):
+    _toSchema = {'error': 'error', 'new_bridges': 'new-bridges', 'reconfigure_delay': 'reconfigure-delay'}
+    _toPy = {'error': 'error', 'new-bridges': 'new_bridges', 'reconfigure-delay': 'reconfigure_delay'}
+    def __init__(self, error=None, new_bridges=None, reconfigure_delay=None):
+        '''
+        error : Error
+        new_bridges : typing.Sequence<+T_co>[~DeviceBridgeInfo]<~DeviceBridgeInfo>
+        reconfigure_delay : int
+        '''
+        self.error = Error.from_json(error) if error else None
+        self.new_bridges = [DeviceBridgeInfo.from_json(o) for o in new_bridges or []]
+        self.reconfigure_delay = reconfigure_delay
+
+
+class HostNetworkChangeResults(Type):
+    _toSchema = {'results': 'results'}
+    _toPy = {'results': 'results'}
+    def __init__(self, results=None):
+        '''
+        results : typing.Sequence<+T_co>[~HostNetworkChange]<~HostNetworkChange>
+        '''
+        self.results = [HostNetworkChange.from_json(o) for o in results or []]
+
+
 class InstanceInfo(Type):
-    _toSchema = {'volumes': 'volumes', 'nonce': 'nonce', 'characteristics': 'characteristics', 'instance_id': 'instance-id', 'network_config': 'network-config', 'tag': 'tag', 'volume_attachments': 'volume-attachments'}
-    _toPy = {'network-config': 'network_config', 'nonce': 'nonce', 'characteristics': 'characteristics', 'instance-id': 'instance_id', 'tag': 'tag', 'volumes': 'volumes', 'volume-attachments': 'volume_attachments'}
+    _toSchema = {'characteristics': 'characteristics', 'instance_id': 'instance-id', 'network_config': 'network-config', 'nonce': 'nonce', 'tag': 'tag', 'volume_attachments': 'volume-attachments', 'volumes': 'volumes'}
+    _toPy = {'characteristics': 'characteristics', 'instance-id': 'instance_id', 'network-config': 'network_config', 'nonce': 'nonce', 'tag': 'tag', 'volume-attachments': 'volume_attachments', 'volumes': 'volumes'}
     def __init__(self, characteristics=None, instance_id=None, network_config=None, nonce=None, tag=None, volume_attachments=None, volumes=None):
         '''
         characteristics : HardwareCharacteristics
@@ -4255,8 +4711,8 @@ class InstancesInfo(Type):
 
 
 class MachineContainers(Type):
-    _toSchema = {'machine_tag': 'machine-tag', 'container_types': 'container-types'}
-    _toPy = {'machine-tag': 'machine_tag', 'container-types': 'container_types'}
+    _toSchema = {'container_types': 'container-types', 'machine_tag': 'machine-tag'}
+    _toPy = {'container-types': 'container_types', 'machine-tag': 'machine_tag'}
     def __init__(self, container_types=None, machine_tag=None):
         '''
         container_types : typing.Sequence<+T_co>[str]
@@ -4277,8 +4733,8 @@ class MachineContainersParams(Type):
 
 
 class MachineNetworkConfigResult(Type):
-    _toSchema = {'info': 'info', 'error': 'error'}
-    _toPy = {'info': 'info', 'error': 'error'}
+    _toSchema = {'error': 'error', 'info': 'info'}
+    _toPy = {'error': 'error', 'info': 'info'}
     def __init__(self, error=None, info=None):
         '''
         error : Error
@@ -4299,8 +4755,8 @@ class MachineNetworkConfigResults(Type):
 
 
 class ProvisioningInfo(Type):
-    _toSchema = {'tags': 'tags', 'volumes': 'volumes', 'controller_config': 'controller-config', 'constraints': 'constraints', 'series': 'series', 'placement': 'placement', 'endpoint_bindings': 'endpoint-bindings', 'subnets_to_zones': 'subnets-to-zones', 'image_metadata': 'image-metadata', 'jobs': 'jobs'}
-    _toPy = {'image-metadata': 'image_metadata', 'volumes': 'volumes', 'constraints': 'constraints', 'series': 'series', 'subnets-to-zones': 'subnets_to_zones', 'placement': 'placement', 'controller-config': 'controller_config', 'endpoint-bindings': 'endpoint_bindings', 'jobs': 'jobs', 'tags': 'tags'}
+    _toSchema = {'constraints': 'constraints', 'controller_config': 'controller-config', 'endpoint_bindings': 'endpoint-bindings', 'image_metadata': 'image-metadata', 'jobs': 'jobs', 'placement': 'placement', 'series': 'series', 'subnets_to_zones': 'subnets-to-zones', 'tags': 'tags', 'volumes': 'volumes'}
+    _toPy = {'constraints': 'constraints', 'controller-config': 'controller_config', 'endpoint-bindings': 'endpoint_bindings', 'image-metadata': 'image_metadata', 'jobs': 'jobs', 'placement': 'placement', 'series': 'series', 'subnets-to-zones': 'subnets_to_zones', 'tags': 'tags', 'volumes': 'volumes'}
     def __init__(self, constraints=None, controller_config=None, endpoint_bindings=None, image_metadata=None, jobs=None, placement=None, series=None, subnets_to_zones=None, tags=None, volumes=None):
         '''
         constraints : Value
@@ -4327,8 +4783,8 @@ class ProvisioningInfo(Type):
 
 
 class ProvisioningInfoResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -4349,8 +4805,8 @@ class ProvisioningInfoResults(Type):
 
 
 class Settings(Type):
-    _toSchema = {'https': 'Https', 'ftp': 'Ftp', 'noproxy': 'NoProxy', 'http': 'Http'}
-    _toPy = {'Http': 'http', 'Https': 'https', 'Ftp': 'ftp', 'NoProxy': 'noproxy'}
+    _toSchema = {'ftp': 'Ftp', 'http': 'Http', 'https': 'Https', 'noproxy': 'NoProxy'}
+    _toPy = {'Ftp': 'ftp', 'Http': 'http', 'Https': 'https', 'NoProxy': 'noproxy'}
     def __init__(self, ftp=None, http=None, https=None, noproxy=None):
         '''
         ftp : str
@@ -4365,8 +4821,8 @@ class Settings(Type):
 
 
 class ToolsResult(Type):
-    _toSchema = {'disable_ssl_hostname_verification': 'disable-ssl-hostname-verification', 'tools': 'tools', 'error': 'error'}
-    _toPy = {'disable-ssl-hostname-verification': 'disable_ssl_hostname_verification', 'tools': 'tools', 'error': 'error'}
+    _toSchema = {'disable_ssl_hostname_verification': 'disable-ssl-hostname-verification', 'error': 'error', 'tools': 'tools'}
+    _toPy = {'disable-ssl-hostname-verification': 'disable_ssl_hostname_verification', 'error': 'error', 'tools': 'tools'}
     def __init__(self, disable_ssl_hostname_verification=None, error=None, tools=None):
         '''
         disable_ssl_hostname_verification : bool
@@ -4389,7 +4845,7 @@ class ToolsResults(Type):
 
 
 class UpdateBehavior(Type):
-    _toSchema = {'enable_os_upgrade': 'enable-os-upgrade', 'enable_os_refresh_update': 'enable-os-refresh-update'}
+    _toSchema = {'enable_os_refresh_update': 'enable-os-refresh-update', 'enable_os_upgrade': 'enable-os-upgrade'}
     _toPy = {'enable-os-refresh-update': 'enable_os_refresh_update', 'enable-os-upgrade': 'enable_os_upgrade'}
     def __init__(self, enable_os_refresh_update=None, enable_os_upgrade=None):
         '''
@@ -4413,8 +4869,8 @@ class Volume(Type):
 
 
 class VolumeAttachmentInfo(Type):
-    _toSchema = {'bus_address': 'bus-address', 'device_name': 'device-name', 'device_link': 'device-link', 'read_only': 'read-only'}
-    _toPy = {'device-link': 'device_link', 'read-only': 'read_only', 'device-name': 'device_name', 'bus-address': 'bus_address'}
+    _toSchema = {'bus_address': 'bus-address', 'device_link': 'device-link', 'device_name': 'device-name', 'read_only': 'read-only'}
+    _toPy = {'bus-address': 'bus_address', 'device-link': 'device_link', 'device-name': 'device_name', 'read-only': 'read_only'}
     def __init__(self, bus_address=None, device_link=None, device_name=None, read_only=None):
         '''
         bus_address : str
@@ -4429,8 +4885,8 @@ class VolumeAttachmentInfo(Type):
 
 
 class VolumeAttachmentParams(Type):
-    _toSchema = {'read_only': 'read-only', 'volume_id': 'volume-id', 'instance_id': 'instance-id', 'provider': 'provider', 'volume_tag': 'volume-tag', 'machine_tag': 'machine-tag'}
-    _toPy = {'instance-id': 'instance_id', 'volume-id': 'volume_id', 'read-only': 'read_only', 'machine-tag': 'machine_tag', 'provider': 'provider', 'volume-tag': 'volume_tag'}
+    _toSchema = {'instance_id': 'instance-id', 'machine_tag': 'machine-tag', 'provider': 'provider', 'read_only': 'read-only', 'volume_id': 'volume-id', 'volume_tag': 'volume-tag'}
+    _toPy = {'instance-id': 'instance_id', 'machine-tag': 'machine_tag', 'provider': 'provider', 'read-only': 'read_only', 'volume-id': 'volume_id', 'volume-tag': 'volume_tag'}
     def __init__(self, instance_id=None, machine_tag=None, provider=None, read_only=None, volume_id=None, volume_tag=None):
         '''
         instance_id : str
@@ -4449,8 +4905,8 @@ class VolumeAttachmentParams(Type):
 
 
 class VolumeInfo(Type):
-    _toSchema = {'hardware_id': 'hardware-id', 'persistent': 'persistent', 'volume_id': 'volume-id', 'size': 'size'}
-    _toPy = {'persistent': 'persistent', 'size': 'size', 'volume-id': 'volume_id', 'hardware-id': 'hardware_id'}
+    _toSchema = {'hardware_id': 'hardware-id', 'persistent': 'persistent', 'size': 'size', 'volume_id': 'volume-id'}
+    _toPy = {'hardware-id': 'hardware_id', 'persistent': 'persistent', 'size': 'size', 'volume-id': 'volume_id'}
     def __init__(self, hardware_id=None, persistent=None, size=None, volume_id=None):
         '''
         hardware_id : str
@@ -4465,8 +4921,8 @@ class VolumeInfo(Type):
 
 
 class VolumeParams(Type):
-    _toSchema = {'attachment': 'attachment', 'size': 'size', 'tags': 'tags', 'attributes': 'attributes', 'provider': 'provider', 'volume_tag': 'volume-tag'}
-    _toPy = {'attachment': 'attachment', 'size': 'size', 'tags': 'tags', 'attributes': 'attributes', 'provider': 'provider', 'volume-tag': 'volume_tag'}
+    _toSchema = {'attachment': 'attachment', 'attributes': 'attributes', 'provider': 'provider', 'size': 'size', 'tags': 'tags', 'volume_tag': 'volume-tag'}
+    _toPy = {'attachment': 'attachment', 'attributes': 'attributes', 'provider': 'provider', 'size': 'size', 'tags': 'tags', 'volume-tag': 'volume_tag'}
     def __init__(self, attachment=None, attributes=None, provider=None, size=None, tags=None, volume_tag=None):
         '''
         attachment : VolumeAttachmentParams
@@ -4485,8 +4941,8 @@ class VolumeParams(Type):
 
 
 class WatchContainer(Type):
-    _toSchema = {'machine_tag': 'machine-tag', 'container_type': 'container-type'}
-    _toPy = {'machine-tag': 'machine_tag', 'container-type': 'container_type'}
+    _toSchema = {'container_type': 'container-type', 'machine_tag': 'machine-tag'}
+    _toPy = {'container-type': 'container_type', 'machine-tag': 'machine_tag'}
     def __init__(self, container_type=None, machine_tag=None):
         '''
         container_type : str
@@ -4507,8 +4963,8 @@ class WatchContainers(Type):
 
 
 class ProxyConfig(Type):
-    _toSchema = {'https': 'https', 'ftp': 'ftp', 'no_proxy': 'no-proxy', 'http': 'http'}
-    _toPy = {'https': 'https', 'ftp': 'ftp', 'no-proxy': 'no_proxy', 'http': 'http'}
+    _toSchema = {'ftp': 'ftp', 'http': 'http', 'https': 'https', 'no_proxy': 'no-proxy'}
+    _toPy = {'ftp': 'ftp', 'http': 'http', 'https': 'https', 'no-proxy': 'no_proxy'}
     def __init__(self, ftp=None, http=None, https=None, no_proxy=None):
         '''
         ftp : str
@@ -4523,8 +4979,8 @@ class ProxyConfig(Type):
 
 
 class ProxyConfigResult(Type):
-    _toSchema = {'proxy_settings': 'proxy-settings', 'apt_proxy_settings': 'apt-proxy-settings', 'error': 'error'}
-    _toPy = {'proxy-settings': 'proxy_settings', 'error': 'error', 'apt-proxy-settings': 'apt_proxy_settings'}
+    _toSchema = {'apt_proxy_settings': 'apt-proxy-settings', 'error': 'error', 'proxy_settings': 'proxy-settings'}
+    _toPy = {'apt-proxy-settings': 'apt_proxy_settings', 'error': 'error', 'proxy-settings': 'proxy_settings'}
     def __init__(self, apt_proxy_settings=None, error=None, proxy_settings=None):
         '''
         apt_proxy_settings : ProxyConfig
@@ -4547,8 +5003,8 @@ class ProxyConfigResults(Type):
 
 
 class RebootActionResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -4569,8 +5025,8 @@ class RebootActionResults(Type):
 
 
 class RelationUnitsChange(Type):
-    _toSchema = {'departed': 'departed', 'changed': 'changed'}
-    _toPy = {'departed': 'departed', 'changed': 'changed'}
+    _toSchema = {'changed': 'changed', 'departed': 'departed'}
+    _toPy = {'changed': 'changed', 'departed': 'departed'}
     def __init__(self, changed=None, departed=None):
         '''
         changed : typing.Mapping<~KT, +VT_co>[str, ~UnitSettings]<~UnitSettings>
@@ -4581,8 +5037,8 @@ class RelationUnitsChange(Type):
 
 
 class RelationUnitsWatchResult(Type):
-    _toSchema = {'changes': 'changes', 'watcher_id': 'watcher-id', 'error': 'error'}
-    _toPy = {'watcher-id': 'watcher_id', 'changes': 'changes', 'error': 'error'}
+    _toSchema = {'changes': 'changes', 'error': 'error', 'watcher_id': 'watcher-id'}
+    _toPy = {'changes': 'changes', 'error': 'error', 'watcher-id': 'watcher_id'}
     def __init__(self, changes=None, error=None, watcher_id=None):
         '''
         changes : RelationUnitsChange
@@ -4604,9 +5060,237 @@ class UnitSettings(Type):
         self.version = version
 
 
+class RemoteApplicationChange(Type):
+    _toSchema = {'application_tag': 'application-tag', 'life': 'life', 'relations': 'relations'}
+    _toPy = {'application-tag': 'application_tag', 'life': 'life', 'relations': 'relations'}
+    def __init__(self, application_tag=None, life=None, relations=None):
+        '''
+        application_tag : str
+        life : str
+        relations : RemoteRelationsChange
+        '''
+        self.application_tag = application_tag
+        self.life = life
+        self.relations = RemoteRelationsChange.from_json(relations) if relations else None
+
+
+class RemoteApplicationWatchResult(Type):
+    _toSchema = {'change': 'change', 'error': 'error', 'id_': 'id'}
+    _toPy = {'change': 'change', 'error': 'error', 'id': 'id_'}
+    def __init__(self, change=None, error=None, id_=None):
+        '''
+        change : RemoteApplicationChange
+        error : Error
+        id_ : str
+        '''
+        self.change = RemoteApplicationChange.from_json(change) if change else None
+        self.error = Error.from_json(error) if error else None
+        self.id_ = id_
+
+
+class RemoteEntityId(Type):
+    _toSchema = {'model_uuid': 'model-uuid', 'token': 'token'}
+    _toPy = {'model-uuid': 'model_uuid', 'token': 'token'}
+    def __init__(self, model_uuid=None, token=None):
+        '''
+        model_uuid : str
+        token : str
+        '''
+        self.model_uuid = model_uuid
+        self.token = token
+
+
+class RemoteRelationChange(Type):
+    _toSchema = {'changed_units': 'changed-units', 'departed_units': 'departed-units', 'id_': 'id', 'life': 'life'}
+    _toPy = {'changed-units': 'changed_units', 'departed-units': 'departed_units', 'id': 'id_', 'life': 'life'}
+    def __init__(self, changed_units=None, departed_units=None, id_=None, life=None):
+        '''
+        changed_units : typing.Mapping<~KT, +VT_co>[str, ~RemoteRelationUnitChange]<~RemoteRelationUnitChange>
+        departed_units : typing.Sequence<+T_co>[str]
+        id_ : int
+        life : str
+        '''
+        self.changed_units = changed_units
+        self.departed_units = departed_units
+        self.id_ = id_
+        self.life = life
+
+
+class RemoteRelationUnitChange(Type):
+    _toSchema = {'settings': 'settings', 'unit_id': 'unit-id'}
+    _toPy = {'settings': 'settings', 'unit-id': 'unit_id'}
+    def __init__(self, settings=None, unit_id=None):
+        '''
+        settings : typing.Mapping<~KT, +VT_co>[str, typing.Any]
+        unit_id : RemoteEntityId
+        '''
+        self.settings = settings
+        self.unit_id = RemoteEntityId.from_json(unit_id) if unit_id else None
+
+
+class RemoteRelationsChange(Type):
+    _toSchema = {'changed': 'changed', 'initial': 'initial', 'removed': 'removed'}
+    _toPy = {'changed': 'changed', 'initial': 'initial', 'removed': 'removed'}
+    def __init__(self, changed=None, initial=None, removed=None):
+        '''
+        changed : typing.Sequence<+T_co>[~RemoteRelationChange]<~RemoteRelationChange>
+        initial : bool
+        removed : typing.Sequence<+T_co>[int]
+        '''
+        self.changed = [RemoteRelationChange.from_json(o) for o in changed or []]
+        self.initial = initial
+        self.removed = removed
+
+
+class RemoteRelationsWatchResult(Type):
+    _toSchema = {'change': 'change', 'error': 'error', 'remoterelationswatcherid': 'RemoteRelationsWatcherId'}
+    _toPy = {'RemoteRelationsWatcherId': 'remoterelationswatcherid', 'change': 'change', 'error': 'error'}
+    def __init__(self, remoterelationswatcherid=None, change=None, error=None):
+        '''
+        remoterelationswatcherid : str
+        change : RemoteRelationsChange
+        error : Error
+        '''
+        self.remoterelationswatcherid = remoterelationswatcherid
+        self.change = RemoteRelationsChange.from_json(change) if change else None
+        self.error = Error.from_json(error) if error else None
+
+
+class AddPendingResourcesArgs(Type):
+    _toSchema = {'addcharmwithauthorization': 'AddCharmWithAuthorization', 'entity': 'Entity', 'resources': 'Resources'}
+    _toPy = {'AddCharmWithAuthorization': 'addcharmwithauthorization', 'Entity': 'entity', 'Resources': 'resources'}
+    def __init__(self, addcharmwithauthorization=None, entity=None, resources=None):
+        '''
+        addcharmwithauthorization : AddCharmWithAuthorization
+        entity : Entity
+        resources : typing.Sequence<+T_co>[~CharmResource]<~CharmResource>
+        '''
+        self.addcharmwithauthorization = AddCharmWithAuthorization.from_json(addcharmwithauthorization) if addcharmwithauthorization else None
+        self.entity = Entity.from_json(entity) if entity else None
+        self.resources = [CharmResource.from_json(o) for o in resources or []]
+
+
+class AddPendingResourcesResult(Type):
+    _toSchema = {'errorresult': 'ErrorResult', 'pending_ids': 'pending-ids'}
+    _toPy = {'ErrorResult': 'errorresult', 'pending-ids': 'pending_ids'}
+    def __init__(self, errorresult=None, pending_ids=None):
+        '''
+        errorresult : ErrorResult
+        pending_ids : typing.Sequence<+T_co>[str]
+        '''
+        self.errorresult = ErrorResult.from_json(errorresult) if errorresult else None
+        self.pending_ids = pending_ids
+
+
+class CharmResource(Type):
+    _toSchema = {'description': 'description', 'fingerprint': 'fingerprint', 'name': 'name', 'origin': 'origin', 'path': 'path', 'revision': 'revision', 'size': 'size', 'type_': 'type'}
+    _toPy = {'description': 'description', 'fingerprint': 'fingerprint', 'name': 'name', 'origin': 'origin', 'path': 'path', 'revision': 'revision', 'size': 'size', 'type': 'type_'}
+    def __init__(self, description=None, fingerprint=None, name=None, origin=None, path=None, revision=None, size=None, type_=None):
+        '''
+        description : str
+        fingerprint : typing.Sequence<+T_co>[int]
+        name : str
+        origin : str
+        path : str
+        revision : int
+        size : int
+        type_ : str
+        '''
+        self.description = description
+        self.fingerprint = fingerprint
+        self.name = name
+        self.origin = origin
+        self.path = path
+        self.revision = revision
+        self.size = size
+        self.type_ = type_
+
+
+class ListResourcesArgs(Type):
+    _toSchema = {'entities': 'entities'}
+    _toPy = {'entities': 'entities'}
+    def __init__(self, entities=None):
+        '''
+        entities : typing.Sequence<+T_co>[~Entity]<~Entity>
+        '''
+        self.entities = [Entity.from_json(o) for o in entities or []]
+
+
+class Resource(Type):
+    _toSchema = {'application': 'application', 'charmresource': 'CharmResource', 'id_': 'id', 'pending_id': 'pending-id', 'timestamp': 'timestamp', 'username': 'username'}
+    _toPy = {'CharmResource': 'charmresource', 'application': 'application', 'id': 'id_', 'pending-id': 'pending_id', 'timestamp': 'timestamp', 'username': 'username'}
+    def __init__(self, charmresource=None, application=None, id_=None, pending_id=None, timestamp=None, username=None):
+        '''
+        charmresource : CharmResource
+        application : str
+        id_ : str
+        pending_id : str
+        timestamp : str
+        username : str
+        '''
+        self.charmresource = CharmResource.from_json(charmresource) if charmresource else None
+        self.application = application
+        self.id_ = id_
+        self.pending_id = pending_id
+        self.timestamp = timestamp
+        self.username = username
+
+
+class ResourcesResult(Type):
+    _toSchema = {'charm_store_resources': 'charm-store-resources', 'errorresult': 'ErrorResult', 'resources': 'resources', 'unit_resources': 'unit-resources'}
+    _toPy = {'ErrorResult': 'errorresult', 'charm-store-resources': 'charm_store_resources', 'resources': 'resources', 'unit-resources': 'unit_resources'}
+    def __init__(self, errorresult=None, charm_store_resources=None, resources=None, unit_resources=None):
+        '''
+        errorresult : ErrorResult
+        charm_store_resources : typing.Sequence<+T_co>[~CharmResource]<~CharmResource>
+        resources : typing.Sequence<+T_co>[~Resource]<~Resource>
+        unit_resources : typing.Sequence<+T_co>[~UnitResources]<~UnitResources>
+        '''
+        self.errorresult = ErrorResult.from_json(errorresult) if errorresult else None
+        self.charm_store_resources = [CharmResource.from_json(o) for o in charm_store_resources or []]
+        self.resources = [Resource.from_json(o) for o in resources or []]
+        self.unit_resources = [UnitResources.from_json(o) for o in unit_resources or []]
+
+
+class ResourcesResults(Type):
+    _toSchema = {'results': 'results'}
+    _toPy = {'results': 'results'}
+    def __init__(self, results=None):
+        '''
+        results : typing.Sequence<+T_co>[~ResourcesResult]<~ResourcesResult>
+        '''
+        self.results = [ResourcesResult.from_json(o) for o in results or []]
+
+
+class UnitResources(Type):
+    _toSchema = {'download_progress': 'download-progress', 'entity': 'Entity', 'resources': 'resources'}
+    _toPy = {'Entity': 'entity', 'download-progress': 'download_progress', 'resources': 'resources'}
+    def __init__(self, entity=None, download_progress=None, resources=None):
+        '''
+        entity : Entity
+        download_progress : typing.Mapping<~KT, +VT_co>[str, int]
+        resources : typing.Sequence<+T_co>[~Resource]<~Resource>
+        '''
+        self.entity = Entity.from_json(entity) if entity else None
+        self.download_progress = download_progress
+        self.resources = [Resource.from_json(o) for o in resources or []]
+
+
+class ResourceResult(Type):
+    _toSchema = {'errorresult': 'ErrorResult', 'resource': 'resource'}
+    _toPy = {'ErrorResult': 'errorresult', 'resource': 'resource'}
+    def __init__(self, errorresult=None, resource=None):
+        '''
+        errorresult : ErrorResult
+        resource : Resource
+        '''
+        self.errorresult = ErrorResult.from_json(errorresult) if errorresult else None
+        self.resource = Resource.from_json(resource) if resource else None
+
+
 class RetryStrategy(Type):
-    _toSchema = {'max_retry_time': 'max-retry-time', 'should_retry': 'should-retry', 'jitter_retry_time': 'jitter-retry-time', 'min_retry_time': 'min-retry-time', 'retry_time_factor': 'retry-time-factor'}
-    _toPy = {'max-retry-time': 'max_retry_time', 'min-retry-time': 'min_retry_time', 'jitter-retry-time': 'jitter_retry_time', 'should-retry': 'should_retry', 'retry-time-factor': 'retry_time_factor'}
+    _toSchema = {'jitter_retry_time': 'jitter-retry-time', 'max_retry_time': 'max-retry-time', 'min_retry_time': 'min-retry-time', 'retry_time_factor': 'retry-time-factor', 'should_retry': 'should-retry'}
+    _toPy = {'jitter-retry-time': 'jitter_retry_time', 'max-retry-time': 'max_retry_time', 'min-retry-time': 'min_retry_time', 'retry-time-factor': 'retry_time_factor', 'should-retry': 'should_retry'}
     def __init__(self, jitter_retry_time=None, max_retry_time=None, min_retry_time=None, retry_time_factor=None, should_retry=None):
         '''
         jitter_retry_time : bool
@@ -4623,8 +5307,8 @@ class RetryStrategy(Type):
 
 
 class RetryStrategyResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -4645,8 +5329,8 @@ class RetryStrategyResults(Type):
 
 
 class SSHAddressResult(Type):
-    _toSchema = {'error': 'error', 'address': 'address'}
-    _toPy = {'error': 'error', 'address': 'address'}
+    _toSchema = {'address': 'address', 'error': 'error'}
+    _toPy = {'address': 'address', 'error': 'error'}
     def __init__(self, address=None, error=None):
         '''
         address : str
@@ -4666,6 +5350,28 @@ class SSHAddressResults(Type):
         self.results = [SSHAddressResult.from_json(o) for o in results or []]
 
 
+class SSHAddressesResult(Type):
+    _toSchema = {'addresses': 'addresses', 'error': 'error'}
+    _toPy = {'addresses': 'addresses', 'error': 'error'}
+    def __init__(self, addresses=None, error=None):
+        '''
+        addresses : typing.Sequence<+T_co>[str]
+        error : Error
+        '''
+        self.addresses = addresses
+        self.error = Error.from_json(error) if error else None
+
+
+class SSHAddressesResults(Type):
+    _toSchema = {'results': 'results'}
+    _toPy = {'results': 'results'}
+    def __init__(self, results=None):
+        '''
+        results : typing.Sequence<+T_co>[~SSHAddressesResult]<~SSHAddressesResult>
+        '''
+        self.results = [SSHAddressesResult.from_json(o) for o in results or []]
+
+
 class SSHProxyResult(Type):
     _toSchema = {'use_proxy': 'use-proxy'}
     _toPy = {'use-proxy': 'use_proxy'}
@@ -4677,8 +5383,8 @@ class SSHProxyResult(Type):
 
 
 class SSHPublicKeysResult(Type):
-    _toSchema = {'public_keys': 'public-keys', 'error': 'error'}
-    _toPy = {'public-keys': 'public_keys', 'error': 'error'}
+    _toSchema = {'error': 'error', 'public_keys': 'public-keys'}
+    _toPy = {'error': 'error', 'public-keys': 'public_keys'}
     def __init__(self, error=None, public_keys=None):
         '''
         error : Error
@@ -4699,8 +5405,8 @@ class SSHPublicKeysResults(Type):
 
 
 class SingularClaim(Type):
-    _toSchema = {'model_tag': 'model-tag', 'duration': 'duration', 'controller_tag': 'controller-tag'}
-    _toPy = {'model-tag': 'model_tag', 'controller-tag': 'controller_tag', 'duration': 'duration'}
+    _toSchema = {'controller_tag': 'controller-tag', 'duration': 'duration', 'model_tag': 'model-tag'}
+    _toPy = {'controller-tag': 'controller_tag', 'duration': 'duration', 'model-tag': 'model_tag'}
     def __init__(self, controller_tag=None, duration=None, model_tag=None):
         '''
         controller_tag : str
@@ -4733,8 +5439,8 @@ class ListSpacesResults(Type):
 
 
 class Space(Type):
-    _toSchema = {'name': 'name', 'subnets': 'subnets', 'error': 'error'}
-    _toPy = {'name': 'name', 'subnets': 'subnets', 'error': 'error'}
+    _toSchema = {'error': 'error', 'name': 'name', 'subnets': 'subnets'}
+    _toPy = {'error': 'error', 'name': 'name', 'subnets': 'subnets'}
     def __init__(self, error=None, name=None, subnets=None):
         '''
         error : Error
@@ -4747,7 +5453,7 @@ class Space(Type):
 
 
 class StatusHistoryPruneArgs(Type):
-    _toSchema = {'max_history_time': 'max-history-time', 'max_history_mb': 'max-history-mb'}
+    _toSchema = {'max_history_mb': 'max-history-mb', 'max_history_time': 'max-history-time'}
     _toPy = {'max-history-mb': 'max_history_mb', 'max-history-time': 'max_history_time'}
     def __init__(self, max_history_mb=None, max_history_time=None):
         '''
@@ -4759,8 +5465,8 @@ class StatusHistoryPruneArgs(Type):
 
 
 class FilesystemAttachmentInfo(Type):
-    _toSchema = {'read_only': 'read-only', 'mount_point': 'mount-point'}
-    _toPy = {'read-only': 'read_only', 'mount-point': 'mount_point'}
+    _toSchema = {'mount_point': 'mount-point', 'read_only': 'read-only'}
+    _toPy = {'mount-point': 'mount_point', 'read-only': 'read_only'}
     def __init__(self, mount_point=None, read_only=None):
         '''
         mount_point : str
@@ -4771,8 +5477,8 @@ class FilesystemAttachmentInfo(Type):
 
 
 class FilesystemDetails(Type):
-    _toSchema = {'info': 'info', 'machine_attachments': 'machine-attachments', 'status': 'status', 'storage': 'storage', 'filesystem_tag': 'filesystem-tag', 'volume_tag': 'volume-tag'}
-    _toPy = {'info': 'info', 'status': 'status', 'storage': 'storage', 'machine-attachments': 'machine_attachments', 'volume-tag': 'volume_tag', 'filesystem-tag': 'filesystem_tag'}
+    _toSchema = {'filesystem_tag': 'filesystem-tag', 'info': 'info', 'machine_attachments': 'machine-attachments', 'status': 'status', 'storage': 'storage', 'volume_tag': 'volume-tag'}
+    _toPy = {'filesystem-tag': 'filesystem_tag', 'info': 'info', 'machine-attachments': 'machine_attachments', 'status': 'status', 'storage': 'storage', 'volume-tag': 'volume_tag'}
     def __init__(self, filesystem_tag=None, info=None, machine_attachments=None, status=None, storage=None, volume_tag=None):
         '''
         filesystem_tag : str
@@ -4791,8 +5497,8 @@ class FilesystemDetails(Type):
 
 
 class FilesystemDetailsListResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -4833,8 +5539,8 @@ class FilesystemFilters(Type):
 
 
 class FilesystemInfo(Type):
-    _toSchema = {'size': 'size', 'filesystem_id': 'filesystem-id'}
-    _toPy = {'size': 'size', 'filesystem-id': 'filesystem_id'}
+    _toSchema = {'filesystem_id': 'filesystem-id', 'size': 'size'}
+    _toPy = {'filesystem-id': 'filesystem_id', 'size': 'size'}
     def __init__(self, filesystem_id=None, size=None):
         '''
         filesystem_id : str
@@ -4845,8 +5551,8 @@ class FilesystemInfo(Type):
 
 
 class StorageAddParams(Type):
-    _toSchema = {'name': 'name', 'unit': 'unit', 'storage': 'storage'}
-    _toPy = {'name': 'name', 'unit': 'unit', 'storage': 'storage'}
+    _toSchema = {'name': 'name', 'storage': 'storage', 'unit': 'unit'}
+    _toPy = {'name': 'name', 'storage': 'storage', 'unit': 'unit'}
     def __init__(self, name=None, storage=None, unit=None):
         '''
         name : str
@@ -4859,8 +5565,8 @@ class StorageAddParams(Type):
 
 
 class StorageAttachmentDetails(Type):
-    _toSchema = {'unit_tag': 'unit-tag', 'machine_tag': 'machine-tag', 'storage_tag': 'storage-tag', 'location': 'location'}
-    _toPy = {'unit-tag': 'unit_tag', 'machine-tag': 'machine_tag', 'storage-tag': 'storage_tag', 'location': 'location'}
+    _toSchema = {'location': 'location', 'machine_tag': 'machine-tag', 'storage_tag': 'storage-tag', 'unit_tag': 'unit-tag'}
+    _toPy = {'location': 'location', 'machine-tag': 'machine_tag', 'storage-tag': 'storage_tag', 'unit-tag': 'unit_tag'}
     def __init__(self, location=None, machine_tag=None, storage_tag=None, unit_tag=None):
         '''
         location : str
@@ -4874,23 +5580,9 @@ class StorageAttachmentDetails(Type):
         self.unit_tag = unit_tag
 
 
-class StorageConstraints(Type):
-    _toSchema = {'size': 'size', 'pool': 'pool', 'count': 'count'}
-    _toPy = {'size': 'size', 'pool': 'pool', 'count': 'count'}
-    def __init__(self, count=None, pool=None, size=None):
-        '''
-        count : int
-        pool : str
-        size : int
-        '''
-        self.count = count
-        self.pool = pool
-        self.size = size
-
-
 class StorageDetails(Type):
-    _toSchema = {'kind': 'kind', 'owner_tag': 'owner-tag', 'status': 'status', 'persistent': 'persistent', 'storage_tag': 'storage-tag', 'attachments': 'attachments'}
-    _toPy = {'kind': 'kind', 'storage-tag': 'storage_tag', 'status': 'status', 'owner-tag': 'owner_tag', 'persistent': 'persistent', 'attachments': 'attachments'}
+    _toSchema = {'attachments': 'attachments', 'kind': 'kind', 'owner_tag': 'owner-tag', 'persistent': 'persistent', 'status': 'status', 'storage_tag': 'storage-tag'}
+    _toPy = {'attachments': 'attachments', 'kind': 'kind', 'owner-tag': 'owner_tag', 'persistent': 'persistent', 'status': 'status', 'storage-tag': 'storage_tag'}
     def __init__(self, attachments=None, kind=None, owner_tag=None, persistent=None, status=None, storage_tag=None):
         '''
         attachments : typing.Mapping<~KT, +VT_co>[str, ~StorageAttachmentDetails]<~StorageAttachmentDetails>
@@ -4909,8 +5601,8 @@ class StorageDetails(Type):
 
 
 class StorageDetailsListResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -4931,8 +5623,8 @@ class StorageDetailsListResults(Type):
 
 
 class StorageDetailsResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -4973,8 +5665,8 @@ class StorageFilters(Type):
 
 
 class StoragePool(Type):
-    _toSchema = {'name': 'name', 'attrs': 'attrs', 'provider': 'provider'}
-    _toPy = {'name': 'name', 'attrs': 'attrs', 'provider': 'provider'}
+    _toSchema = {'attrs': 'attrs', 'name': 'name', 'provider': 'provider'}
+    _toPy = {'attrs': 'attrs', 'name': 'name', 'provider': 'provider'}
     def __init__(self, attrs=None, name=None, provider=None):
         '''
         attrs : typing.Mapping<~KT, +VT_co>[str, typing.Any]
@@ -5009,8 +5701,8 @@ class StoragePoolFilters(Type):
 
 
 class StoragePoolsResult(Type):
-    _toSchema = {'storage_pools': 'storage-pools', 'error': 'error'}
-    _toPy = {'storage-pools': 'storage_pools', 'error': 'error'}
+    _toSchema = {'error': 'error', 'storage_pools': 'storage-pools'}
+    _toPy = {'error': 'error', 'storage-pools': 'storage_pools'}
     def __init__(self, error=None, storage_pools=None):
         '''
         error : Error
@@ -5041,8 +5733,8 @@ class StoragesAddParams(Type):
 
 
 class VolumeDetails(Type):
-    _toSchema = {'info': 'info', 'machine_attachments': 'machine-attachments', 'volume_tag': 'volume-tag', 'status': 'status', 'storage': 'storage'}
-    _toPy = {'info': 'info', 'status': 'status', 'machine-attachments': 'machine_attachments', 'volume-tag': 'volume_tag', 'storage': 'storage'}
+    _toSchema = {'info': 'info', 'machine_attachments': 'machine-attachments', 'status': 'status', 'storage': 'storage', 'volume_tag': 'volume-tag'}
+    _toPy = {'info': 'info', 'machine-attachments': 'machine_attachments', 'status': 'status', 'storage': 'storage', 'volume-tag': 'volume_tag'}
     def __init__(self, info=None, machine_attachments=None, status=None, storage=None, volume_tag=None):
         '''
         info : VolumeInfo
@@ -5059,8 +5751,8 @@ class VolumeDetails(Type):
 
 
 class VolumeDetailsListResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5101,8 +5793,8 @@ class VolumeFilters(Type):
 
 
 class BlockDeviceResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5123,8 +5815,8 @@ class BlockDeviceResults(Type):
 
 
 class Filesystem(Type):
-    _toSchema = {'info': 'info', 'filesystem_tag': 'filesystem-tag', 'volume_tag': 'volume-tag'}
-    _toPy = {'info': 'info', 'volume-tag': 'volume_tag', 'filesystem-tag': 'filesystem_tag'}
+    _toSchema = {'filesystem_tag': 'filesystem-tag', 'info': 'info', 'volume_tag': 'volume-tag'}
+    _toPy = {'filesystem-tag': 'filesystem_tag', 'info': 'info', 'volume-tag': 'volume_tag'}
     def __init__(self, filesystem_tag=None, info=None, volume_tag=None):
         '''
         filesystem_tag : str
@@ -5137,8 +5829,8 @@ class Filesystem(Type):
 
 
 class FilesystemAttachment(Type):
-    _toSchema = {'info': 'info', 'filesystem_tag': 'filesystem-tag', 'machine_tag': 'machine-tag'}
-    _toPy = {'info': 'info', 'machine-tag': 'machine_tag', 'filesystem-tag': 'filesystem_tag'}
+    _toSchema = {'filesystem_tag': 'filesystem-tag', 'info': 'info', 'machine_tag': 'machine-tag'}
+    _toPy = {'filesystem-tag': 'filesystem_tag', 'info': 'info', 'machine-tag': 'machine_tag'}
     def __init__(self, filesystem_tag=None, info=None, machine_tag=None):
         '''
         filesystem_tag : str
@@ -5151,8 +5843,8 @@ class FilesystemAttachment(Type):
 
 
 class FilesystemAttachmentParams(Type):
-    _toSchema = {'read_only': 'read-only', 'machine_tag': 'machine-tag', 'instance_id': 'instance-id', 'filesystem_id': 'filesystem-id', 'filesystem_tag': 'filesystem-tag', 'mount_point': 'mount-point', 'provider': 'provider'}
-    _toPy = {'instance-id': 'instance_id', 'provider': 'provider', 'read-only': 'read_only', 'machine-tag': 'machine_tag', 'filesystem-id': 'filesystem_id', 'mount-point': 'mount_point', 'filesystem-tag': 'filesystem_tag'}
+    _toSchema = {'filesystem_id': 'filesystem-id', 'filesystem_tag': 'filesystem-tag', 'instance_id': 'instance-id', 'machine_tag': 'machine-tag', 'mount_point': 'mount-point', 'provider': 'provider', 'read_only': 'read-only'}
+    _toPy = {'filesystem-id': 'filesystem_id', 'filesystem-tag': 'filesystem_tag', 'instance-id': 'instance_id', 'machine-tag': 'machine_tag', 'mount-point': 'mount_point', 'provider': 'provider', 'read-only': 'read_only'}
     def __init__(self, filesystem_id=None, filesystem_tag=None, instance_id=None, machine_tag=None, mount_point=None, provider=None, read_only=None):
         '''
         filesystem_id : str
@@ -5173,8 +5865,8 @@ class FilesystemAttachmentParams(Type):
 
 
 class FilesystemAttachmentParamsResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5195,8 +5887,8 @@ class FilesystemAttachmentParamsResults(Type):
 
 
 class FilesystemAttachmentResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5227,8 +5919,8 @@ class FilesystemAttachments(Type):
 
 
 class FilesystemParams(Type):
-    _toSchema = {'attachment': 'attachment', 'size': 'size', 'tags': 'tags', 'attributes': 'attributes', 'filesystem_tag': 'filesystem-tag', 'volume_tag': 'volume-tag', 'provider': 'provider'}
-    _toPy = {'attachment': 'attachment', 'size': 'size', 'tags': 'tags', 'attributes': 'attributes', 'provider': 'provider', 'volume-tag': 'volume_tag', 'filesystem-tag': 'filesystem_tag'}
+    _toSchema = {'attachment': 'attachment', 'attributes': 'attributes', 'filesystem_tag': 'filesystem-tag', 'provider': 'provider', 'size': 'size', 'tags': 'tags', 'volume_tag': 'volume-tag'}
+    _toPy = {'attachment': 'attachment', 'attributes': 'attributes', 'filesystem-tag': 'filesystem_tag', 'provider': 'provider', 'size': 'size', 'tags': 'tags', 'volume-tag': 'volume_tag'}
     def __init__(self, attachment=None, attributes=None, filesystem_tag=None, provider=None, size=None, tags=None, volume_tag=None):
         '''
         attachment : FilesystemAttachmentParams
@@ -5249,8 +5941,8 @@ class FilesystemParams(Type):
 
 
 class FilesystemParamsResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5271,8 +5963,8 @@ class FilesystemParamsResults(Type):
 
 
 class FilesystemResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5337,8 +6029,8 @@ class VolumeAttachment(Type):
 
 
 class VolumeAttachmentParamsResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5359,8 +6051,8 @@ class VolumeAttachmentParamsResults(Type):
 
 
 class VolumeAttachmentResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5391,8 +6083,8 @@ class VolumeAttachments(Type):
 
 
 class VolumeParamsResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5413,8 +6105,8 @@ class VolumeParamsResults(Type):
 
 
 class VolumeResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5445,8 +6137,8 @@ class Volumes(Type):
 
 
 class SpaceResult(Type):
-    _toSchema = {'tag': 'tag', 'error': 'error'}
-    _toPy = {'tag': 'tag', 'error': 'error'}
+    _toSchema = {'error': 'error', 'tag': 'tag'}
+    _toPy = {'error': 'error', 'tag': 'tag'}
     def __init__(self, error=None, tag=None):
         '''
         error : Error
@@ -5467,8 +6159,8 @@ class SpaceResults(Type):
 
 
 class ZoneResult(Type):
-    _toSchema = {'name': 'name', 'available': 'available', 'error': 'error'}
-    _toPy = {'name': 'name', 'available': 'available', 'error': 'error'}
+    _toSchema = {'available': 'available', 'error': 'error', 'name': 'name'}
+    _toPy = {'available': 'available', 'error': 'error', 'name': 'name'}
     def __init__(self, available=None, error=None, name=None):
         '''
         available : bool
@@ -5491,8 +6183,8 @@ class ZoneResults(Type):
 
 
 class UndertakerModelInfo(Type):
-    _toSchema = {'is_system': 'is-system', 'life': 'life', 'uuid': 'uuid', 'global_name': 'global-name', 'name': 'name'}
-    _toPy = {'global-name': 'global_name', 'is-system': 'is_system', 'uuid': 'uuid', 'life': 'life', 'name': 'name'}
+    _toSchema = {'global_name': 'global-name', 'is_system': 'is-system', 'life': 'life', 'name': 'name', 'uuid': 'uuid'}
+    _toPy = {'global-name': 'global_name', 'is-system': 'is_system', 'life': 'life', 'name': 'name', 'uuid': 'uuid'}
     def __init__(self, global_name=None, is_system=None, life=None, name=None, uuid=None):
         '''
         global_name : str
@@ -5509,8 +6201,8 @@ class UndertakerModelInfo(Type):
 
 
 class UndertakerModelInfoResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5521,8 +6213,8 @@ class UndertakerModelInfoResult(Type):
 
 
 class ApplicationStatusResult(Type):
-    _toSchema = {'application': 'application', 'units': 'units', 'error': 'error'}
-    _toPy = {'application': 'application', 'units': 'units', 'error': 'error'}
+    _toSchema = {'application': 'application', 'error': 'error', 'units': 'units'}
+    _toPy = {'application': 'application', 'error': 'error', 'units': 'units'}
     def __init__(self, application=None, error=None, units=None):
         '''
         application : StatusResult
@@ -5555,8 +6247,8 @@ class CharmURLs(Type):
 
 
 class ConfigSettingsResult(Type):
-    _toSchema = {'settings': 'settings', 'error': 'error'}
-    _toPy = {'settings': 'settings', 'error': 'error'}
+    _toSchema = {'error': 'error', 'settings': 'settings'}
+    _toPy = {'error': 'error', 'settings': 'settings'}
     def __init__(self, error=None, settings=None):
         '''
         error : Error
@@ -5577,8 +6269,8 @@ class ConfigSettingsResults(Type):
 
 
 class Endpoint(Type):
-    _toSchema = {'relation': 'relation', 'application_name': 'application-name'}
-    _toPy = {'relation': 'relation', 'application-name': 'application_name'}
+    _toSchema = {'application_name': 'application-name', 'relation': 'relation'}
+    _toPy = {'application-name': 'application_name', 'relation': 'relation'}
     def __init__(self, application_name=None, relation=None):
         '''
         application_name : str
@@ -5609,7 +6301,7 @@ class EntitiesPortRanges(Type):
 
 
 class EntityCharmURL(Type):
-    _toSchema = {'tag': 'tag', 'charm_url': 'charm-url'}
+    _toSchema = {'charm_url': 'charm-url', 'tag': 'tag'}
     _toPy = {'charm-url': 'charm_url', 'tag': 'tag'}
     def __init__(self, charm_url=None, tag=None):
         '''
@@ -5621,8 +6313,8 @@ class EntityCharmURL(Type):
 
 
 class EntityPortRange(Type):
-    _toSchema = {'from_port': 'from-port', 'to_port': 'to-port', 'tag': 'tag', 'protocol': 'protocol'}
-    _toPy = {'from-port': 'from_port', 'tag': 'tag', 'protocol': 'protocol', 'to-port': 'to_port'}
+    _toSchema = {'from_port': 'from-port', 'protocol': 'protocol', 'tag': 'tag', 'to_port': 'to-port'}
+    _toPy = {'from-port': 'from_port', 'protocol': 'protocol', 'tag': 'tag', 'to-port': 'to_port'}
     def __init__(self, from_port=None, protocol=None, tag=None, to_port=None):
         '''
         from_port : int
@@ -5669,8 +6361,8 @@ class GetLeadershipSettingsBulkResults(Type):
 
 
 class GetLeadershipSettingsResult(Type):
-    _toSchema = {'settings': 'settings', 'error': 'error'}
-    _toPy = {'settings': 'settings', 'error': 'error'}
+    _toSchema = {'error': 'error', 'settings': 'settings'}
+    _toPy = {'error': 'error', 'settings': 'settings'}
     def __init__(self, error=None, settings=None):
         '''
         error : Error
@@ -5681,8 +6373,8 @@ class GetLeadershipSettingsResult(Type):
 
 
 class IntResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5713,7 +6405,7 @@ class MergeLeadershipSettingsBulkParams(Type):
 
 
 class MergeLeadershipSettingsParam(Type):
-    _toSchema = {'settings': 'settings', 'application_tag': 'application-tag'}
+    _toSchema = {'application_tag': 'application-tag', 'settings': 'settings'}
     _toPy = {'application-tag': 'application_tag', 'settings': 'settings'}
     def __init__(self, application_tag=None, settings=None):
         '''
@@ -5725,8 +6417,8 @@ class MergeLeadershipSettingsParam(Type):
 
 
 class ModelResult(Type):
-    _toSchema = {'name': 'name', 'uuid': 'uuid', 'error': 'error'}
-    _toPy = {'name': 'name', 'uuid': 'uuid', 'error': 'error'}
+    _toSchema = {'error': 'error', 'name': 'name', 'uuid': 'uuid'}
+    _toPy = {'error': 'error', 'name': 'name', 'uuid': 'uuid'}
     def __init__(self, error=None, name=None, uuid=None):
         '''
         error : Error
@@ -5749,8 +6441,8 @@ class RelationIds(Type):
 
 
 class RelationResult(Type):
-    _toSchema = {'life': 'life', 'endpoint': 'endpoint', 'id_': 'id', 'key': 'key', 'error': 'error'}
-    _toPy = {'life': 'life', 'endpoint': 'endpoint', 'id': 'id_', 'key': 'key', 'error': 'error'}
+    _toSchema = {'endpoint': 'endpoint', 'error': 'error', 'id_': 'id', 'key': 'key', 'life': 'life'}
+    _toPy = {'endpoint': 'endpoint', 'error': 'error', 'id': 'id_', 'key': 'key', 'life': 'life'}
     def __init__(self, endpoint=None, error=None, id_=None, key=None, life=None):
         '''
         endpoint : Endpoint
@@ -5789,8 +6481,8 @@ class RelationUnit(Type):
 
 
 class RelationUnitPair(Type):
-    _toSchema = {'relation': 'relation', 'local_unit': 'local-unit', 'remote_unit': 'remote-unit'}
-    _toPy = {'remote-unit': 'remote_unit', 'local-unit': 'local_unit', 'relation': 'relation'}
+    _toSchema = {'local_unit': 'local-unit', 'relation': 'relation', 'remote_unit': 'remote-unit'}
+    _toPy = {'local-unit': 'local_unit', 'relation': 'relation', 'remote-unit': 'remote_unit'}
     def __init__(self, local_unit=None, relation=None, remote_unit=None):
         '''
         local_unit : str
@@ -5857,8 +6549,8 @@ class RelationUnitsWatchResults(Type):
 
 
 class ResolvedModeResult(Type):
-    _toSchema = {'mode': 'mode', 'error': 'error'}
-    _toPy = {'mode': 'mode', 'error': 'error'}
+    _toSchema = {'error': 'error', 'mode': 'mode'}
+    _toPy = {'error': 'error', 'mode': 'mode'}
     def __init__(self, error=None, mode=None):
         '''
         error : Error
@@ -5879,8 +6571,8 @@ class ResolvedModeResults(Type):
 
 
 class SettingsResult(Type):
-    _toSchema = {'settings': 'settings', 'error': 'error'}
-    _toPy = {'settings': 'settings', 'error': 'error'}
+    _toSchema = {'error': 'error', 'settings': 'settings'}
+    _toPy = {'error': 'error', 'settings': 'settings'}
     def __init__(self, error=None, settings=None):
         '''
         error : Error
@@ -5901,8 +6593,8 @@ class SettingsResults(Type):
 
 
 class StorageAttachment(Type):
-    _toSchema = {'kind': 'kind', 'owner_tag': 'owner-tag', 'location': 'location', 'life': 'life', 'storage_tag': 'storage-tag', 'unit_tag': 'unit-tag'}
-    _toPy = {'kind': 'kind', 'storage-tag': 'storage_tag', 'location': 'location', 'life': 'life', 'owner-tag': 'owner_tag', 'unit-tag': 'unit_tag'}
+    _toSchema = {'kind': 'kind', 'life': 'life', 'location': 'location', 'owner_tag': 'owner-tag', 'storage_tag': 'storage-tag', 'unit_tag': 'unit-tag'}
+    _toPy = {'kind': 'kind', 'life': 'life', 'location': 'location', 'owner-tag': 'owner_tag', 'storage-tag': 'storage_tag', 'unit-tag': 'unit_tag'}
     def __init__(self, kind=None, life=None, location=None, owner_tag=None, storage_tag=None, unit_tag=None):
         '''
         kind : int
@@ -5922,7 +6614,7 @@ class StorageAttachment(Type):
 
 class StorageAttachmentId(Type):
     _toSchema = {'storage_tag': 'storage-tag', 'unit_tag': 'unit-tag'}
-    _toPy = {'unit-tag': 'unit_tag', 'storage-tag': 'storage_tag'}
+    _toPy = {'storage-tag': 'storage_tag', 'unit-tag': 'unit_tag'}
     def __init__(self, storage_tag=None, unit_tag=None):
         '''
         storage_tag : str
@@ -5943,8 +6635,8 @@ class StorageAttachmentIds(Type):
 
 
 class StorageAttachmentIdsResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5965,8 +6657,8 @@ class StorageAttachmentIdsResults(Type):
 
 
 class StorageAttachmentResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -5987,8 +6679,8 @@ class StorageAttachmentResults(Type):
 
 
 class StringBoolResult(Type):
-    _toSchema = {'result': 'result', 'ok': 'ok', 'error': 'error'}
-    _toPy = {'result': 'result', 'ok': 'ok', 'error': 'error'}
+    _toSchema = {'error': 'error', 'ok': 'ok', 'result': 'result'}
+    _toPy = {'error': 'error', 'ok': 'ok', 'result': 'result'}
     def __init__(self, error=None, ok=None, result=None):
         '''
         error : Error
@@ -6023,8 +6715,8 @@ class UnitNetworkConfig(Type):
 
 
 class UnitNetworkConfigResult(Type):
-    _toSchema = {'info': 'info', 'error': 'error'}
-    _toPy = {'info': 'info', 'error': 'error'}
+    _toSchema = {'error': 'error', 'info': 'info'}
+    _toPy = {'error': 'error', 'info': 'info'}
     def __init__(self, error=None, info=None):
         '''
         error : Error
@@ -6076,9 +6768,19 @@ class EntityVersion(Type):
         self.tools = Version.from_json(tools) if tools else None
 
 
+class Version(Type):
+    _toSchema = {'version': 'version'}
+    _toPy = {'version': 'version'}
+    def __init__(self, version=None):
+        '''
+        version : Binary
+        '''
+        self.version = Binary.from_json(version) if version else None
+
+
 class VersionResult(Type):
-    _toSchema = {'version': 'version', 'error': 'error'}
-    _toPy = {'version': 'version', 'error': 'error'}
+    _toSchema = {'error': 'error', 'version': 'version'}
+    _toPy = {'error': 'error', 'version': 'version'}
     def __init__(self, error=None, version=None):
         '''
         error : Error
@@ -6099,7 +6801,7 @@ class VersionResults(Type):
 
 
 class AddUser(Type):
-    _toSchema = {'display_name': 'display-name', 'username': 'username', 'password': 'password'}
+    _toSchema = {'display_name': 'display-name', 'password': 'password', 'username': 'username'}
     _toPy = {'display-name': 'display_name', 'password': 'password', 'username': 'username'}
     def __init__(self, display_name=None, password=None, username=None):
         '''
@@ -6113,8 +6815,8 @@ class AddUser(Type):
 
 
 class AddUserResult(Type):
-    _toSchema = {'secret_key': 'secret-key', 'tag': 'tag', 'error': 'error'}
-    _toPy = {'tag': 'tag', 'secret-key': 'secret_key', 'error': 'error'}
+    _toSchema = {'error': 'error', 'secret_key': 'secret-key', 'tag': 'tag'}
+    _toPy = {'error': 'error', 'secret-key': 'secret_key', 'tag': 'tag'}
     def __init__(self, error=None, secret_key=None, tag=None):
         '''
         error : Error
@@ -6146,31 +6848,9 @@ class AddUsers(Type):
         self.users = [AddUser.from_json(o) for o in users or []]
 
 
-class MacaroonResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
-    def __init__(self, error=None, result=None):
-        '''
-        error : Error
-        result : Macaroon
-        '''
-        self.error = Error.from_json(error) if error else None
-        self.result = Macaroon.from_json(result) if result else None
-
-
-class MacaroonResults(Type):
-    _toSchema = {'results': 'results'}
-    _toPy = {'results': 'results'}
-    def __init__(self, results=None):
-        '''
-        results : typing.Sequence<+T_co>[~MacaroonResult]<~MacaroonResult>
-        '''
-        self.results = [MacaroonResult.from_json(o) for o in results or []]
-
-
 class UserInfo(Type):
-    _toSchema = {'display_name': 'display-name', 'username': 'username', 'last_connection': 'last-connection', 'disabled': 'disabled', 'access': 'access', 'created_by': 'created-by', 'date_created': 'date-created'}
-    _toPy = {'last-connection': 'last_connection', 'username': 'username', 'disabled': 'disabled', 'date-created': 'date_created', 'created-by': 'created_by', 'access': 'access', 'display-name': 'display_name'}
+    _toSchema = {'access': 'access', 'created_by': 'created-by', 'date_created': 'date-created', 'disabled': 'disabled', 'display_name': 'display-name', 'last_connection': 'last-connection', 'username': 'username'}
+    _toPy = {'access': 'access', 'created-by': 'created_by', 'date-created': 'date_created', 'disabled': 'disabled', 'display-name': 'display_name', 'last-connection': 'last_connection', 'username': 'username'}
     def __init__(self, access=None, created_by=None, date_created=None, disabled=None, display_name=None, last_connection=None, username=None):
         '''
         access : str
@@ -6191,7 +6871,7 @@ class UserInfo(Type):
 
 
 class UserInfoRequest(Type):
-    _toSchema = {'include_disabled': 'include-disabled', 'entities': 'entities'}
+    _toSchema = {'entities': 'entities', 'include_disabled': 'include-disabled'}
     _toPy = {'entities': 'entities', 'include-disabled': 'include_disabled'}
     def __init__(self, entities=None, include_disabled=None):
         '''
@@ -6203,8 +6883,8 @@ class UserInfoRequest(Type):
 
 
 class UserInfoResult(Type):
-    _toSchema = {'result': 'result', 'error': 'error'}
-    _toPy = {'result': 'result', 'error': 'error'}
+    _toSchema = {'error': 'error', 'result': 'result'}
+    _toPy = {'error': 'error', 'result': 'result'}
     def __init__(self, error=None, result=None):
         '''
         error : Error
@@ -6388,9 +7068,9 @@ class ActionFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ActionResult]<~ActionResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Action', request='Actions', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Action', request='Actions', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -6403,9 +7083,9 @@ class ActionFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ApplicationCharmActionsResult]<~ApplicationCharmActionsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Action', request='ApplicationsCharmsActions', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Action', request='ApplicationsCharmsActions', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -6418,9 +7098,9 @@ class ActionFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ActionResult]<~ActionResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Action', request='Cancel', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Action', request='Cancel', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -6433,9 +7113,9 @@ class ActionFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ActionResult]<~ActionResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Action', request='Enqueue', version=2, params=params)
-        params['actions'] = actions
+        _params = dict()
+        msg = dict(type='Action', request='Enqueue', version=2, params=_params)
+        _params['actions'] = actions
         reply = await self.rpc(msg)
         return reply
 
@@ -6448,9 +7128,9 @@ class ActionFacade(Type):
         Returns -> typing.Sequence<+T_co>[~Entity]<~Entity>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Action', request='FindActionTagsByPrefix', version=2, params=params)
-        params['prefixes'] = prefixes
+        _params = dict()
+        msg = dict(type='Action', request='FindActionTagsByPrefix', version=2, params=_params)
+        _params['prefixes'] = prefixes
         reply = await self.rpc(msg)
         return reply
 
@@ -6463,9 +7143,9 @@ class ActionFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ActionsByName]<~ActionsByName>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Action', request='FindActionsByNames', version=2, params=params)
-        params['names'] = names
+        _params = dict()
+        msg = dict(type='Action', request='FindActionsByNames', version=2, params=_params)
+        _params['names'] = names
         reply = await self.rpc(msg)
         return reply
 
@@ -6478,9 +7158,9 @@ class ActionFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ActionsByReceiver]<~ActionsByReceiver>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Action', request='ListAll', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Action', request='ListAll', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -6493,9 +7173,9 @@ class ActionFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ActionsByReceiver]<~ActionsByReceiver>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Action', request='ListCompleted', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Action', request='ListCompleted', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -6508,9 +7188,9 @@ class ActionFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ActionsByReceiver]<~ActionsByReceiver>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Action', request='ListPending', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Action', request='ListPending', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -6523,9 +7203,9 @@ class ActionFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ActionsByReceiver]<~ActionsByReceiver>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Action', request='ListRunning', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Action', request='ListRunning', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -6542,13 +7222,13 @@ class ActionFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ActionResult]<~ActionResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Action', request='Run', version=2, params=params)
-        params['applications'] = applications
-        params['commands'] = commands
-        params['machines'] = machines
-        params['timeout'] = timeout
-        params['units'] = units
+        _params = dict()
+        msg = dict(type='Action', request='Run', version=2, params=_params)
+        _params['applications'] = applications
+        _params['commands'] = commands
+        _params['machines'] = machines
+        _params['timeout'] = timeout
+        _params['units'] = units
         reply = await self.rpc(msg)
         return reply
 
@@ -6565,13 +7245,13 @@ class ActionFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ActionResult]<~ActionResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Action', request='RunOnAllMachines', version=2, params=params)
-        params['applications'] = applications
-        params['commands'] = commands
-        params['machines'] = machines
-        params['timeout'] = timeout
-        params['units'] = units
+        _params = dict()
+        msg = dict(type='Action', request='RunOnAllMachines', version=2, params=_params)
+        _params['applications'] = applications
+        _params['commands'] = commands
+        _params['machines'] = machines
+        _params['timeout'] = timeout
+        _params['units'] = units
         reply = await self.rpc(msg)
         return reply
 
@@ -6674,11 +7354,17 @@ class AgentFacade(Type):
                                                                      'type': 'object'}},
                                            'required': ['config'],
                                            'type': 'object'},
+                     'ModelTag': {'additionalProperties': False, 'type': 'object'},
                      'NotifyWatchResult': {'additionalProperties': False,
                                            'properties': {'NotifyWatcherId': {'type': 'string'},
                                                           'error': {'$ref': '#/definitions/Error'}},
                                            'required': ['NotifyWatcherId'],
                                            'type': 'object'},
+                     'NotifyWatchResults': {'additionalProperties': False,
+                                            'properties': {'results': {'items': {'$ref': '#/definitions/NotifyWatchResult'},
+                                                                       'type': 'array'}},
+                                            'required': ['results'],
+                                            'type': 'object'},
                      'StateServingInfo': {'additionalProperties': False,
                                           'properties': {'api-port': {'type': 'integer'},
                                                          'ca-private-key': {'type': 'string'},
@@ -6703,6 +7389,9 @@ class AgentFacade(Type):
                                   'type': 'object'},
                     'ControllerConfig': {'properties': {'Result': {'$ref': '#/definitions/ControllerConfigResult'}},
                                          'type': 'object'},
+                    'GetCloudSpec': {'properties': {'Params': {'$ref': '#/definitions/ModelTag'},
+                                                    'Result': {'$ref': '#/definitions/CloudSpecResult'}},
+                                     'type': 'object'},
                     'GetEntities': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
                                                    'Result': {'$ref': '#/definitions/AgentGetEntitiesResults'}},
                                     'type': 'object'},
@@ -6715,6 +7404,9 @@ class AgentFacade(Type):
                                      'type': 'object'},
                     'StateServingInfo': {'properties': {'Result': {'$ref': '#/definitions/StateServingInfo'}},
                                          'type': 'object'},
+                    'WatchCredentials': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
+                                                        'Result': {'$ref': '#/definitions/NotifyWatchResults'}},
+                                         'type': 'object'},
                     'WatchForModelConfigChanges': {'properties': {'Result': {'$ref': '#/definitions/NotifyWatchResult'}},
                                                    'type': 'object'}},
      'type': 'object'}
@@ -6727,9 +7419,9 @@ class AgentFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Agent', request='ClearReboot', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Agent', request='ClearReboot', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -6742,9 +7434,9 @@ class AgentFacade(Type):
         Returns -> typing.Sequence<+T_co>[~CloudSpecResult]<~CloudSpecResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Agent', request='CloudSpec', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Agent', request='CloudSpec', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -6757,8 +7449,23 @@ class AgentFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, typing.Any]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Agent', request='ControllerConfig', version=2, params=params)
+        _params = dict()
+        msg = dict(type='Agent', request='ControllerConfig', version=2, params=_params)
+
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(CloudSpecResult)
+    async def GetCloudSpec(self):
+        '''
+
+        Returns -> typing.Union[_ForwardRef('Error'), _ForwardRef('CloudSpec')]
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Agent', request='GetCloudSpec', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -6772,9 +7479,9 @@ class AgentFacade(Type):
         Returns -> typing.Sequence<+T_co>[~AgentGetEntitiesResult]<~AgentGetEntitiesResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Agent', request='GetEntities', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Agent', request='GetEntities', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -6787,8 +7494,8 @@ class AgentFacade(Type):
         Returns -> bool
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Agent', request='IsMaster', version=2, params=params)
+        _params = dict()
+        msg = dict(type='Agent', request='IsMaster', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -6802,8 +7509,8 @@ class AgentFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, typing.Any]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Agent', request='ModelConfig', version=2, params=params)
+        _params = dict()
+        msg = dict(type='Agent', request='ModelConfig', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -6817,9 +7524,9 @@ class AgentFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Agent', request='SetPasswords', version=2, params=params)
-        params['changes'] = changes
+        _params = dict()
+        msg = dict(type='Agent', request='SetPasswords', version=2, params=_params)
+        _params['changes'] = changes
         reply = await self.rpc(msg)
         return reply
 
@@ -6832,9 +7539,24 @@ class AgentFacade(Type):
         Returns -> typing.Union[int, str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Agent', request='StateServingInfo', version=2, params=params)
+        _params = dict()
+        msg = dict(type='Agent', request='StateServingInfo', version=2, params=_params)
+
+        reply = await self.rpc(msg)
+        return reply
 
+
+
+    @ReturnMapping(NotifyWatchResults)
+    async def WatchCredentials(self, entities):
+        '''
+        entities : typing.Sequence<+T_co>[~Entity]<~Entity>
+        Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Agent', request='WatchCredentials', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -6847,8 +7569,8 @@ class AgentFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Agent', request='WatchForModelConfigChanges', version=2, params=params)
+        _params = dict()
+        msg = dict(type='Agent', request='WatchForModelConfigChanges', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -6867,8 +7589,8 @@ class AgentToolsFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='AgentTools', request='UpdateToolsAvailable', version=1, params=params)
+        _params = dict()
+        msg = dict(type='AgentTools', request='UpdateToolsAvailable', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -6901,8 +7623,8 @@ class AllModelWatcherFacade(Type):
         Returns -> typing.Sequence<+T_co>[~Delta]<~Delta>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='AllModelWatcher', request='Next', version=2, params=params)
+        _params = dict()
+        msg = dict(type='AllModelWatcher', request='Next', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -6916,8 +7638,8 @@ class AllModelWatcherFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='AllModelWatcher', request='Stop', version=2, params=params)
+        _params = dict()
+        msg = dict(type='AllModelWatcher', request='Stop', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -6950,8 +7672,8 @@ class AllWatcherFacade(Type):
         Returns -> typing.Sequence<+T_co>[~Delta]<~Delta>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='AllWatcher', request='Next', version=1, params=params)
+        _params = dict()
+        msg = dict(type='AllWatcher', request='Next', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -6965,8 +7687,8 @@ class AllWatcherFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='AllWatcher', request='Stop', version=1, params=params)
+        _params = dict()
+        msg = dict(type='AllWatcher', request='Stop', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -7042,9 +7764,9 @@ class AnnotationsFacade(Type):
         Returns -> typing.Sequence<+T_co>[~AnnotationsGetResult]<~AnnotationsGetResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Annotations', request='Get', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Annotations', request='Get', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -7057,16 +7779,16 @@ class AnnotationsFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Annotations', request='Set', version=2, params=params)
-        params['annotations'] = annotations
+        _params = dict()
+        msg = dict(type='Annotations', request='Set', version=2, params=_params)
+        _params['annotations'] = annotations
         reply = await self.rpc(msg)
         return reply
 
 
 class ApplicationFacade(Type):
     name = 'Application'
-    version = 1
+    version = 3
     schema =     {'definitions': {'AddApplicationUnits': {'additionalProperties': False,
                                              'properties': {'application': {'type': 'string'},
                                                             'num-units': {'type': 'integer'},
@@ -7174,10 +7896,15 @@ class ApplicationFacade(Type):
                                              'properties': {'application': {'type': 'string'},
                                                             'channel': {'type': 'string'},
                                                             'charm-url': {'type': 'string'},
+                                                            'config-settings': {'patternProperties': {'.*': {'type': 'string'}},
+                                                                                'type': 'object'},
+                                                            'config-settings-yaml': {'type': 'string'},
                                                             'force-series': {'type': 'boolean'},
                                                             'force-units': {'type': 'boolean'},
                                                             'resource-ids': {'patternProperties': {'.*': {'type': 'string'}},
-                                                                             'type': 'object'}},
+                                                                             'type': 'object'},
+                                                            'storage-constraints': {'patternProperties': {'.*': {'$ref': '#/definitions/StorageConstraints'}},
+                                                                                    'type': 'object'}},
                                              'required': ['application',
                                                           'charm-url',
                                                           'channel',
@@ -7282,6 +8009,11 @@ class ApplicationFacade(Type):
                                                        'constraints': {'$ref': '#/definitions/Value'}},
                                         'required': ['application', 'constraints'],
                                         'type': 'object'},
+                     'StorageConstraints': {'additionalProperties': False,
+                                            'properties': {'count': {'type': 'integer'},
+                                                           'pool': {'type': 'string'},
+                                                           'size': {'type': 'integer'}},
+                                            'type': 'object'},
                      'StringResult': {'additionalProperties': False,
                                       'properties': {'error': {'$ref': '#/definitions/Error'},
                                                      'result': {'type': 'string'}},
@@ -7290,7 +8022,7 @@ class ApplicationFacade(Type):
                      'Value': {'additionalProperties': False,
                                'properties': {'arch': {'type': 'string'},
                                               'container': {'type': 'string'},
-                                              'cpu-cores': {'type': 'integer'},
+                                              'cores': {'type': 'integer'},
                                               'cpu-power': {'type': 'integer'},
                                               'instance-type': {'type': 'string'},
                                               'mem': {'type': 'integer'},
@@ -7355,9 +8087,9 @@ class ApplicationFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, ~CharmRelation]<~CharmRelation>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='AddRelation', version=1, params=params)
-        params['endpoints'] = endpoints
+        _params = dict()
+        msg = dict(type='Application', request='AddRelation', version=3, params=_params)
+        _params['endpoints'] = endpoints
         reply = await self.rpc(msg)
         return reply
 
@@ -7372,11 +8104,11 @@ class ApplicationFacade(Type):
         Returns -> typing.Sequence<+T_co>[str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='AddUnits', version=1, params=params)
-        params['application'] = application
-        params['num-units'] = num_units
-        params['placement'] = placement
+        _params = dict()
+        msg = dict(type='Application', request='AddUnits', version=3, params=_params)
+        _params['application'] = application
+        _params['num-units'] = num_units
+        _params['placement'] = placement
         reply = await self.rpc(msg)
         return reply
 
@@ -7389,9 +8121,9 @@ class ApplicationFacade(Type):
         Returns -> typing.Sequence<+T_co>[str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='CharmRelations', version=1, params=params)
-        params['application'] = application
+        _params = dict()
+        msg = dict(type='Application', request='CharmRelations', version=3, params=_params)
+        _params['application'] = application
         reply = await self.rpc(msg)
         return reply
 
@@ -7404,9 +8136,9 @@ class ApplicationFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='Deploy', version=1, params=params)
-        params['applications'] = applications
+        _params = dict()
+        msg = dict(type='Application', request='Deploy', version=3, params=_params)
+        _params['applications'] = applications
         reply = await self.rpc(msg)
         return reply
 
@@ -7419,9 +8151,9 @@ class ApplicationFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='Destroy', version=1, params=params)
-        params['application'] = application
+        _params = dict()
+        msg = dict(type='Application', request='Destroy', version=3, params=_params)
+        _params['application'] = application
         reply = await self.rpc(msg)
         return reply
 
@@ -7434,9 +8166,9 @@ class ApplicationFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='DestroyRelation', version=1, params=params)
-        params['endpoints'] = endpoints
+        _params = dict()
+        msg = dict(type='Application', request='DestroyRelation', version=3, params=_params)
+        _params['endpoints'] = endpoints
         reply = await self.rpc(msg)
         return reply
 
@@ -7449,9 +8181,9 @@ class ApplicationFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='DestroyUnits', version=1, params=params)
-        params['unit-names'] = unit_names
+        _params = dict()
+        msg = dict(type='Application', request='DestroyUnits', version=3, params=_params)
+        _params['unit-names'] = unit_names
         reply = await self.rpc(msg)
         return reply
 
@@ -7464,9 +8196,9 @@ class ApplicationFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='Expose', version=1, params=params)
-        params['application'] = application
+        _params = dict()
+        msg = dict(type='Application', request='Expose', version=3, params=_params)
+        _params['application'] = application
         reply = await self.rpc(msg)
         return reply
 
@@ -7479,9 +8211,9 @@ class ApplicationFacade(Type):
         Returns -> typing.Union[str, typing.Mapping<~KT, +VT_co>[str, typing.Any], _ForwardRef('Value')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='Get', version=1, params=params)
-        params['application'] = application
+        _params = dict()
+        msg = dict(type='Application', request='Get', version=3, params=_params)
+        _params['application'] = application
         reply = await self.rpc(msg)
         return reply
 
@@ -7494,9 +8226,9 @@ class ApplicationFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='GetCharmURL', version=1, params=params)
-        params['application'] = application
+        _params = dict()
+        msg = dict(type='Application', request='GetCharmURL', version=3, params=_params)
+        _params['application'] = application
         reply = await self.rpc(msg)
         return reply
 
@@ -7509,9 +8241,9 @@ class ApplicationFacade(Type):
         Returns -> Value
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='GetConstraints', version=1, params=params)
-        params['application'] = application
+        _params = dict()
+        msg = dict(type='Application', request='GetConstraints', version=3, params=_params)
+        _params['application'] = application
         reply = await self.rpc(msg)
         return reply
 
@@ -7525,35 +8257,41 @@ class ApplicationFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='Set', version=1, params=params)
-        params['application'] = application
-        params['options'] = options
+        _params = dict()
+        msg = dict(type='Application', request='Set', version=3, params=_params)
+        _params['application'] = application
+        _params['options'] = options
         reply = await self.rpc(msg)
         return reply
 
 
 
     @ReturnMapping(None)
-    async def SetCharm(self, application, channel, charm_url, force_series, force_units, resource_ids):
+    async def SetCharm(self, application, channel, charm_url, config_settings, config_settings_yaml, force_series, force_units, resource_ids, storage_constraints):
         '''
         application : str
         channel : str
         charm_url : str
+        config_settings : typing.Mapping<~KT, +VT_co>[str, str]
+        config_settings_yaml : str
         force_series : bool
         force_units : bool
         resource_ids : typing.Mapping<~KT, +VT_co>[str, str]
+        storage_constraints : typing.Mapping<~KT, +VT_co>[str, ~StorageConstraints]<~StorageConstraints>
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='SetCharm', version=1, params=params)
-        params['application'] = application
-        params['channel'] = channel
-        params['charm-url'] = charm_url
-        params['force-series'] = force_series
-        params['force-units'] = force_units
-        params['resource-ids'] = resource_ids
+        _params = dict()
+        msg = dict(type='Application', request='SetCharm', version=3, params=_params)
+        _params['application'] = application
+        _params['channel'] = channel
+        _params['charm-url'] = charm_url
+        _params['config-settings'] = config_settings
+        _params['config-settings-yaml'] = config_settings_yaml
+        _params['force-series'] = force_series
+        _params['force-units'] = force_units
+        _params['resource-ids'] = resource_ids
+        _params['storage-constraints'] = storage_constraints
         reply = await self.rpc(msg)
         return reply
 
@@ -7567,10 +8305,10 @@ class ApplicationFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='SetConstraints', version=1, params=params)
-        params['application'] = application
-        params['constraints'] = constraints
+        _params = dict()
+        msg = dict(type='Application', request='SetConstraints', version=3, params=_params)
+        _params['application'] = application
+        _params['constraints'] = constraints
         reply = await self.rpc(msg)
         return reply
 
@@ -7583,9 +8321,9 @@ class ApplicationFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='SetMetricCredentials', version=1, params=params)
-        params['creds'] = creds
+        _params = dict()
+        msg = dict(type='Application', request='SetMetricCredentials', version=3, params=_params)
+        _params['creds'] = creds
         reply = await self.rpc(msg)
         return reply
 
@@ -7598,9 +8336,9 @@ class ApplicationFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='Unexpose', version=1, params=params)
-        params['application'] = application
+        _params = dict()
+        msg = dict(type='Application', request='Unexpose', version=3, params=_params)
+        _params['application'] = application
         reply = await self.rpc(msg)
         return reply
 
@@ -7614,10 +8352,10 @@ class ApplicationFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='Unset', version=1, params=params)
-        params['application'] = application
-        params['options'] = options
+        _params = dict()
+        msg = dict(type='Application', request='Unset', version=3, params=_params)
+        _params['application'] = application
+        _params['options'] = options
         reply = await self.rpc(msg)
         return reply
 
@@ -7637,16 +8375,16 @@ class ApplicationFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Application', request='Update', version=1, params=params)
-        params['application'] = application
-        params['charm-url'] = charm_url
-        params['constraints'] = constraints
-        params['force-charm-url'] = force_charm_url
-        params['force-series'] = force_series
-        params['min-units'] = min_units
-        params['settings'] = settings
-        params['settings-yaml'] = settings_yaml
+        _params = dict()
+        msg = dict(type='Application', request='Update', version=3, params=_params)
+        _params['application'] = application
+        _params['charm-url'] = charm_url
+        _params['constraints'] = constraints
+        _params['force-charm-url'] = force_charm_url
+        _params['force-series'] = force_series
+        _params['min-units'] = min_units
+        _params['settings'] = settings
+        _params['settings-yaml'] = settings_yaml
         reply = await self.rpc(msg)
         return reply
 
@@ -7704,9 +8442,9 @@ class ApplicationScalerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ApplicationScaler', request='Rescale', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='ApplicationScaler', request='Rescale', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -7719,8 +8457,8 @@ class ApplicationScalerFacade(Type):
         Returns -> typing.Union[typing.Sequence<+T_co>[str], _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ApplicationScaler', request='Watch', version=1, params=params)
+        _params = dict()
+        msg = dict(type='ApplicationScaler', request='Watch', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -7824,9 +8562,9 @@ class BackupsFacade(Type):
         Returns -> typing.Union[str, int, _ForwardRef('Number')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Backups', request='Create', version=1, params=params)
-        params['notes'] = notes
+        _params = dict()
+        msg = dict(type='Backups', request='Create', version=1, params=_params)
+        _params['notes'] = notes
         reply = await self.rpc(msg)
         return reply
 
@@ -7839,8 +8577,8 @@ class BackupsFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Backups', request='FinishRestore', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Backups', request='FinishRestore', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -7854,9 +8592,9 @@ class BackupsFacade(Type):
         Returns -> typing.Union[str, int, _ForwardRef('Number')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Backups', request='Info', version=1, params=params)
-        params['id'] = id_
+        _params = dict()
+        msg = dict(type='Backups', request='Info', version=1, params=_params)
+        _params['id'] = id_
         reply = await self.rpc(msg)
         return reply
 
@@ -7869,8 +8607,8 @@ class BackupsFacade(Type):
         Returns -> typing.Sequence<+T_co>[~BackupsMetadataResult]<~BackupsMetadataResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Backups', request='List', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Backups', request='List', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -7884,8 +8622,8 @@ class BackupsFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Backups', request='PrepareRestore', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Backups', request='PrepareRestore', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -7899,9 +8637,9 @@ class BackupsFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Backups', request='Remove', version=1, params=params)
-        params['id'] = id_
+        _params = dict()
+        msg = dict(type='Backups', request='Remove', version=1, params=_params)
+        _params['id'] = id_
         reply = await self.rpc(msg)
         return reply
 
@@ -7914,9 +8652,9 @@ class BackupsFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Backups', request='Restore', version=1, params=params)
-        params['backup-id'] = backup_id
+        _params = dict()
+        msg = dict(type='Backups', request='Restore', version=1, params=_params)
+        _params['backup-id'] = backup_id
         reply = await self.rpc(msg)
         return reply
 
@@ -7977,8 +8715,8 @@ class BlockFacade(Type):
         Returns -> typing.Sequence<+T_co>[~BlockResult]<~BlockResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Block', request='List', version=2, params=params)
+        _params = dict()
+        msg = dict(type='Block', request='List', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -7993,10 +8731,10 @@ class BlockFacade(Type):
         Returns -> Error
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Block', request='SwitchBlockOff', version=2, params=params)
-        params['message'] = message
-        params['type'] = type_
+        _params = dict()
+        msg = dict(type='Block', request='SwitchBlockOff', version=2, params=_params)
+        _params['message'] = message
+        _params['type'] = type_
         reply = await self.rpc(msg)
         return reply
 
@@ -8010,10 +8748,56 @@ class BlockFacade(Type):
         Returns -> Error
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Block', request='SwitchBlockOn', version=2, params=params)
-        params['message'] = message
-        params['type'] = type_
+        _params = dict()
+        msg = dict(type='Block', request='SwitchBlockOn', version=2, params=_params)
+        _params['message'] = message
+        _params['type'] = type_
+        reply = await self.rpc(msg)
+        return reply
+
+
+class BundleFacade(Type):
+    name = 'Bundle'
+    version = 1
+    schema =     {'definitions': {'BundleChange': {'additionalProperties': False,
+                                      'properties': {'args': {'items': {'additionalProperties': True,
+                                                                        'type': 'object'},
+                                                              'type': 'array'},
+                                                     'id': {'type': 'string'},
+                                                     'method': {'type': 'string'},
+                                                     'requires': {'items': {'type': 'string'},
+                                                                  'type': 'array'}},
+                                      'required': ['id',
+                                                   'method',
+                                                   'args',
+                                                   'requires'],
+                                      'type': 'object'},
+                     'BundleChangesParams': {'additionalProperties': False,
+                                             'properties': {'yaml': {'type': 'string'}},
+                                             'required': ['yaml'],
+                                             'type': 'object'},
+                     'BundleChangesResults': {'additionalProperties': False,
+                                              'properties': {'changes': {'items': {'$ref': '#/definitions/BundleChange'},
+                                                                         'type': 'array'},
+                                                             'errors': {'items': {'type': 'string'},
+                                                                        'type': 'array'}},
+                                              'type': 'object'}},
+     'properties': {'GetChanges': {'properties': {'Params': {'$ref': '#/definitions/BundleChangesParams'},
+                                                  'Result': {'$ref': '#/definitions/BundleChangesResults'}},
+                                   'type': 'object'}},
+     'type': 'object'}
+    
+
+    @ReturnMapping(BundleChangesResults)
+    async def GetChanges(self, yaml):
+        '''
+        yaml : str
+        Returns -> typing.Sequence<+T_co>[~BundleChange]<~BundleChange>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Bundle', request='GetChanges', version=1, params=_params)
+        _params['yaml'] = yaml
         reply = await self.rpc(msg)
         return reply
 
@@ -8047,8 +8831,8 @@ class CharmRevisionUpdaterFacade(Type):
         Returns -> Error
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='CharmRevisionUpdater', request='UpdateLatestRevisions', version=2, params=params)
+        _params = dict()
+        msg = dict(type='CharmRevisionUpdater', request='UpdateLatestRevisions', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -8118,8 +8902,9 @@ class CharmsFacade(Type):
                                      'type': 'object'},
                      'CharmMetrics': {'additionalProperties': False,
                                       'properties': {'metrics': {'patternProperties': {'.*': {'$ref': '#/definitions/CharmMetric'}},
-                                                                 'type': 'object'}},
-                                      'required': ['metrics'],
+                                                                 'type': 'object'},
+                                                     'plan': {'$ref': '#/definitions/CharmPlan'}},
+                                      'required': ['metrics', 'plan'],
                                       'type': 'object'},
                      'CharmOption': {'additionalProperties': False,
                                      'properties': {'default': {'additionalProperties': True,
@@ -8133,6 +8918,10 @@ class CharmsFacade(Type):
                                                           'type': {'type': 'string'}},
                                            'required': ['name', 'type'],
                                            'type': 'object'},
+                     'CharmPlan': {'additionalProperties': False,
+                                   'properties': {'required': {'type': 'boolean'}},
+                                   'required': ['required'],
+                                   'type': 'object'},
                      'CharmRelation': {'additionalProperties': False,
                                        'properties': {'interface': {'type': 'string'},
                                                       'limit': {'type': 'integer'},
@@ -8215,9 +9004,9 @@ class CharmsFacade(Type):
         Returns -> typing.Union[_ForwardRef('CharmActions'), typing.Mapping<~KT, +VT_co>[str, ~CharmOption]<~CharmOption>, _ForwardRef('CharmMeta'), _ForwardRef('CharmMetrics'), int, str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Charms', request='CharmInfo', version=2, params=params)
-        params['url'] = url
+        _params = dict()
+        msg = dict(type='Charms', request='CharmInfo', version=2, params=_params)
+        _params['url'] = url
         reply = await self.rpc(msg)
         return reply
 
@@ -8230,9 +9019,9 @@ class CharmsFacade(Type):
         Returns -> bool
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Charms', request='IsMetered', version=2, params=params)
-        params['url'] = url
+        _params = dict()
+        msg = dict(type='Charms', request='IsMetered', version=2, params=_params)
+        _params['url'] = url
         reply = await self.rpc(msg)
         return reply
 
@@ -8245,9 +9034,9 @@ class CharmsFacade(Type):
         Returns -> typing.Sequence<+T_co>[str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Charms', request='List', version=2, params=params)
-        params['names'] = names
+        _params = dict()
+        msg = dict(type='Charms', request='List', version=2, params=_params)
+        _params['names'] = names
         reply = await self.rpc(msg)
         return reply
 
@@ -8284,8 +9073,8 @@ class CleanerFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Cleaner', request='Cleanup', version=2, params=params)
+        _params = dict()
+        msg = dict(type='Cleaner', request='Cleanup', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -8299,8 +9088,8 @@ class CleanerFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Cleaner', request='WatchCleanups', version=2, params=params)
+        _params = dict()
+        msg = dict(type='Cleaner', request='WatchCleanups', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -8420,19 +9209,29 @@ class ClientFacade(Type):
                                                'Series': {'type': 'string'}},
                                 'required': ['Number', 'Series', 'Arch'],
                                 'type': 'object'},
-                     'BundleChangesChange': {'additionalProperties': False,
-                                             'properties': {'args': {'items': {'additionalProperties': True,
-                                                                               'type': 'object'},
-                                                                     'type': 'array'},
-                                                            'id': {'type': 'string'},
-                                                            'method': {'type': 'string'},
-                                                            'requires': {'items': {'type': 'string'},
-                                                                         'type': 'array'}},
-                                             'required': ['id',
-                                                          'method',
-                                                          'args',
-                                                          'requires'],
+                     'BundleChange': {'additionalProperties': False,
+                                      'properties': {'args': {'items': {'additionalProperties': True,
+                                                                        'type': 'object'},
+                                                              'type': 'array'},
+                                                     'id': {'type': 'string'},
+                                                     'method': {'type': 'string'},
+                                                     'requires': {'items': {'type': 'string'},
+                                                                  'type': 'array'}},
+                                      'required': ['id',
+                                                   'method',
+                                                   'args',
+                                                   'requires'],
+                                      'type': 'object'},
+                     'BundleChangesParams': {'additionalProperties': False,
+                                             'properties': {'yaml': {'type': 'string'}},
+                                             'required': ['yaml'],
                                              'type': 'object'},
+                     'BundleChangesResults': {'additionalProperties': False,
+                                              'properties': {'changes': {'items': {'$ref': '#/definitions/BundleChange'},
+                                                                         'type': 'array'},
+                                                             'errors': {'items': {'type': 'string'},
+                                                                        'type': 'array'}},
+                                              'type': 'object'},
                      'ConfigValue': {'additionalProperties': False,
                                      'properties': {'source': {'type': 'string'},
                                                     'value': {'additionalProperties': True,
@@ -8544,22 +9343,15 @@ class ClientFacade(Type):
                                                                 'type': 'object'},
                                                    'model': {'$ref': '#/definitions/ModelStatusInfo'},
                                                    'relations': {'items': {'$ref': '#/definitions/RelationStatus'},
-                                                                 'type': 'array'}},
+                                                                 'type': 'array'},
+                                                   'remote-applications': {'patternProperties': {'.*': {'$ref': '#/definitions/RemoteApplicationStatus'}},
+                                                                           'type': 'object'}},
                                     'required': ['model',
                                                  'machines',
                                                  'applications',
+                                                 'remote-applications',
                                                  'relations'],
                                     'type': 'object'},
-                     'GetBundleChangesParams': {'additionalProperties': False,
-                                                'properties': {'yaml': {'type': 'string'}},
-                                                'required': ['yaml'],
-                                                'type': 'object'},
-                     'GetBundleChangesResults': {'additionalProperties': False,
-                                                 'properties': {'changes': {'items': {'$ref': '#/definitions/BundleChangesChange'},
-                                                                            'type': 'array'},
-                                                                'errors': {'items': {'type': 'string'},
-                                                                           'type': 'array'}},
-                                                 'type': 'object'},
                      'GetConstraintsResults': {'additionalProperties': False,
                                                'properties': {'constraints': {'$ref': '#/definitions/Value'}},
                                                'required': ['constraints'],
@@ -8586,8 +9378,19 @@ class ClientFacade(Type):
                                   'required': ['Address', 'port'],
                                   'type': 'object'},
                      'Macaroon': {'additionalProperties': False, 'type': 'object'},
+                     'MachineHardware': {'additionalProperties': False,
+                                         'properties': {'arch': {'type': 'string'},
+                                                        'availability-zone': {'type': 'string'},
+                                                        'cores': {'type': 'integer'},
+                                                        'cpu-power': {'type': 'integer'},
+                                                        'mem': {'type': 'integer'},
+                                                        'root-disk': {'type': 'integer'},
+                                                        'tags': {'items': {'type': 'string'},
+                                                                 'type': 'array'}},
+                                         'type': 'object'},
                      'MachineStatus': {'additionalProperties': False,
                                        'properties': {'agent-status': {'$ref': '#/definitions/DetailedStatus'},
+                                                      'constraints': {'type': 'string'},
                                                       'containers': {'patternProperties': {'.*': {'$ref': '#/definitions/MachineStatus'}},
                                                                      'type': 'object'},
                                                       'dns-name': {'type': 'string'},
@@ -8596,6 +9399,8 @@ class ClientFacade(Type):
                                                       'id': {'type': 'string'},
                                                       'instance-id': {'type': 'string'},
                                                       'instance-status': {'$ref': '#/definitions/DetailedStatus'},
+                                                      'ip-addresses': {'items': {'type': 'string'},
+                                                                       'type': 'array'},
                                                       'jobs': {'items': {'type': 'string'},
                                                                'type': 'array'},
                                                       'series': {'type': 'string'},
@@ -8603,10 +9408,12 @@ class ClientFacade(Type):
                                        'required': ['agent-status',
                                                     'instance-status',
                                                     'dns-name',
+                                                    'ip-addresses',
                                                     'instance-id',
                                                     'series',
                                                     'id',
                                                     'containers',
+                                                    'constraints',
                                                     'hardware',
                                                     'jobs',
                                                     'has-vote',
@@ -8622,34 +9429,16 @@ class ClientFacade(Type):
                                                                       'type': 'object'}},
                                             'required': ['config'],
                                             'type': 'object'},
-                     'ModelDefaultValues': {'additionalProperties': False,
-                                            'properties': {'cloud-region': {'type': 'string'},
-                                                           'cloud-tag': {'type': 'string'},
-                                                           'config': {'patternProperties': {'.*': {'additionalProperties': True,
-                                                                                                   'type': 'object'}},
-                                                                      'type': 'object'}},
-                                            'required': ['config'],
-                                            'type': 'object'},
-                     'ModelDefaults': {'additionalProperties': False,
-                                       'properties': {'controller': {'additionalProperties': True,
-                                                                     'type': 'object'},
-                                                      'default': {'additionalProperties': True,
-                                                                  'type': 'object'},
-                                                      'regions': {'items': {'$ref': '#/definitions/RegionDefaults'},
-                                                                  'type': 'array'}},
-                                       'type': 'object'},
-                     'ModelDefaultsResult': {'additionalProperties': False,
-                                             'properties': {'config': {'patternProperties': {'.*': {'$ref': '#/definitions/ModelDefaults'}},
-                                                                       'type': 'object'}},
-                                             'required': ['config'],
-                                             'type': 'object'},
                      'ModelInfo': {'additionalProperties': False,
-                                   'properties': {'cloud': {'type': 'string'},
-                                                  'cloud-credential-tag': {'type': 'string'},
+                                   'properties': {'cloud-credential-tag': {'type': 'string'},
                                                   'cloud-region': {'type': 'string'},
+                                                  'cloud-tag': {'type': 'string'},
                                                   'controller-uuid': {'type': 'string'},
                                                   'default-series': {'type': 'string'},
                                                   'life': {'type': 'string'},
+                                                  'machines': {'items': {'$ref': '#/definitions/ModelMachineInfo'},
+                                                               'type': 'array'},
+                                                  'migration': {'$ref': '#/definitions/ModelMigrationStatus'},
                                                   'name': {'type': 'string'},
                                                   'owner-tag': {'type': 'string'},
                                                   'provider-type': {'type': 'string'},
@@ -8662,12 +9451,30 @@ class ClientFacade(Type):
                                                 'controller-uuid',
                                                 'provider-type',
                                                 'default-series',
-                                                'cloud',
+                                                'cloud-tag',
                                                 'owner-tag',
                                                 'life',
                                                 'status',
-                                                'users'],
+                                                'users',
+                                                'machines'],
                                    'type': 'object'},
+                     'ModelMachineInfo': {'additionalProperties': False,
+                                          'properties': {'hardware': {'$ref': '#/definitions/MachineHardware'},
+                                                         'has-vote': {'type': 'boolean'},
+                                                         'id': {'type': 'string'},
+                                                         'instance-id': {'type': 'string'},
+                                                         'status': {'type': 'string'},
+                                                         'wants-vote': {'type': 'boolean'}},
+                                          'required': ['id'],
+                                          'type': 'object'},
+                     'ModelMigrationStatus': {'additionalProperties': False,
+                                              'properties': {'end': {'format': 'date-time',
+                                                                     'type': 'string'},
+                                                             'start': {'format': 'date-time',
+                                                                       'type': 'string'},
+                                                             'status': {'type': 'string'}},
+                                              'required': ['status', 'start'],
+                                              'type': 'object'},
                      'ModelSet': {'additionalProperties': False,
                                   'properties': {'config': {'patternProperties': {'.*': {'additionalProperties': True,
                                                                                          'type': 'object'}},
@@ -8676,13 +9483,13 @@ class ClientFacade(Type):
                                   'type': 'object'},
                      'ModelStatusInfo': {'additionalProperties': False,
                                          'properties': {'available-version': {'type': 'string'},
-                                                        'cloud': {'type': 'string'},
+                                                        'cloud-tag': {'type': 'string'},
                                                         'migration': {'type': 'string'},
                                                         'name': {'type': 'string'},
                                                         'region': {'type': 'string'},
                                                         'version': {'type': 'string'}},
                                          'required': ['name',
-                                                      'cloud',
+                                                      'cloud-tag',
                                                       'version',
                                                       'available-version'],
                                          'type': 'object'},
@@ -8691,13 +9498,6 @@ class ClientFacade(Type):
                                                             'type': 'array'}},
                                     'required': ['keys'],
                                     'type': 'object'},
-                     'ModelUnsetKeys': {'additionalProperties': False,
-                                        'properties': {'cloud-region': {'type': 'string'},
-                                                       'cloud-tag': {'type': 'string'},
-                                                       'keys': {'items': {'type': 'string'},
-                                                                'type': 'array'}},
-                                        'required': ['keys'],
-                                        'type': 'object'},
                      'ModelUserInfo': {'additionalProperties': False,
                                        'properties': {'access': {'type': 'string'},
                                                       'display-name': {'type': 'string'},
@@ -8765,12 +9565,6 @@ class ClientFacade(Type):
                                               'properties': {'public-address': {'type': 'string'}},
                                               'required': ['public-address'],
                                               'type': 'object'},
-                     'RegionDefaults': {'additionalProperties': False,
-                                        'properties': {'region-name': {'type': 'string'},
-                                                       'value': {'additionalProperties': True,
-                                                                 'type': 'object'}},
-                                        'required': ['region-name', 'value'],
-                                        'type': 'object'},
                      'RelationStatus': {'additionalProperties': False,
                                         'properties': {'endpoints': {'items': {'$ref': '#/definitions/EndpointStatus'},
                                                                      'type': 'array'},
@@ -8784,6 +9578,37 @@ class ClientFacade(Type):
                                                      'scope',
                                                      'endpoints'],
                                         'type': 'object'},
+                     'RemoteApplicationStatus': {'additionalProperties': False,
+                                                 'properties': {'application-name': {'type': 'string'},
+                                                                'application-url': {'type': 'string'},
+                                                                'endpoints': {'items': {'$ref': '#/definitions/RemoteEndpoint'},
+                                                                              'type': 'array'},
+                                                                'err': {'additionalProperties': True,
+                                                                        'type': 'object'},
+                                                                'life': {'type': 'string'},
+                                                                'relations': {'patternProperties': {'.*': {'items': {'type': 'string'},
+                                                                                                           'type': 'array'}},
+                                                                              'type': 'object'},
+                                                                'status': {'$ref': '#/definitions/DetailedStatus'}},
+                                                 'required': ['application-url',
+                                                              'application-name',
+                                                              'endpoints',
+                                                              'life',
+                                                              'relations',
+                                                              'status'],
+                                                 'type': 'object'},
+                     'RemoteEndpoint': {'additionalProperties': False,
+                                        'properties': {'interface': {'type': 'string'},
+                                                       'limit': {'type': 'integer'},
+                                                       'name': {'type': 'string'},
+                                                       'role': {'type': 'string'},
+                                                       'scope': {'type': 'string'}},
+                                        'required': ['name',
+                                                     'role',
+                                                     'interface',
+                                                     'limit',
+                                                     'scope'],
+                                        'type': 'object'},
                      'ResolveCharmResult': {'additionalProperties': False,
                                             'properties': {'error': {'type': 'string'},
                                                            'url': {'type': 'string'}},
@@ -8812,11 +9637,6 @@ class ClientFacade(Type):
                                               'properties': {'version': {'$ref': '#/definitions/Number'}},
                                               'required': ['version'],
                                               'type': 'object'},
-                     'SetModelDefaults': {'additionalProperties': False,
-                                          'properties': {'config': {'items': {'$ref': '#/definitions/ModelDefaultValues'},
-                                                                    'type': 'array'}},
-                                          'required': ['config'],
-                                          'type': 'object'},
                      'StatusHistoryFilter': {'additionalProperties': False,
                                              'properties': {'date': {'format': 'date-time',
                                                                      'type': 'string'},
@@ -8864,6 +9684,7 @@ class ClientFacade(Type):
                      'UnitStatus': {'additionalProperties': False,
                                     'properties': {'agent-status': {'$ref': '#/definitions/DetailedStatus'},
                                                    'charm': {'type': 'string'},
+                                                   'leader': {'type': 'boolean'},
                                                    'machine': {'type': 'string'},
                                                    'opened-ports': {'items': {'type': 'string'},
                                                                     'type': 'array'},
@@ -8881,15 +9702,10 @@ class ClientFacade(Type):
                                                  'charm',
                                                  'subordinates'],
                                     'type': 'object'},
-                     'UnsetModelDefaults': {'additionalProperties': False,
-                                            'properties': {'keys': {'items': {'$ref': '#/definitions/ModelUnsetKeys'},
-                                                                    'type': 'array'}},
-                                            'required': ['keys'],
-                                            'type': 'object'},
                      'Value': {'additionalProperties': False,
                                'properties': {'arch': {'type': 'string'},
                                               'container': {'type': 'string'},
-                                              'cpu-cores': {'type': 'integer'},
+                                              'cores': {'type': 'integer'},
                                               'cpu-power': {'type': 'integer'},
                                               'instance-type': {'type': 'string'},
                                               'mem': {'type': 'integer'},
@@ -8923,16 +9739,14 @@ class ClientFacade(Type):
                     'FullStatus': {'properties': {'Params': {'$ref': '#/definitions/StatusParams'},
                                                   'Result': {'$ref': '#/definitions/FullStatus'}},
                                    'type': 'object'},
-                    'GetBundleChanges': {'properties': {'Params': {'$ref': '#/definitions/GetBundleChangesParams'},
-                                                        'Result': {'$ref': '#/definitions/GetBundleChangesResults'}},
+                    'GetBundleChanges': {'properties': {'Params': {'$ref': '#/definitions/BundleChangesParams'},
+                                                        'Result': {'$ref': '#/definitions/BundleChangesResults'}},
                                          'type': 'object'},
                     'GetModelConstraints': {'properties': {'Result': {'$ref': '#/definitions/GetConstraintsResults'}},
                                             'type': 'object'},
                     'InjectMachines': {'properties': {'Params': {'$ref': '#/definitions/AddMachines'},
                                                       'Result': {'$ref': '#/definitions/AddMachinesResults'}},
                                        'type': 'object'},
-                    'ModelDefaults': {'properties': {'Result': {'$ref': '#/definitions/ModelDefaultsResult'}},
-                                      'type': 'object'},
                     'ModelGet': {'properties': {'Result': {'$ref': '#/definitions/ModelConfigResults'}},
                                  'type': 'object'},
                     'ModelInfo': {'properties': {'Result': {'$ref': '#/definitions/ModelInfo'}},
@@ -8964,15 +9778,9 @@ class ClientFacade(Type):
                                              'type': 'object'},
                     'SetModelConstraints': {'properties': {'Params': {'$ref': '#/definitions/SetConstraints'}},
                                             'type': 'object'},
-                    'SetModelDefaults': {'properties': {'Params': {'$ref': '#/definitions/SetModelDefaults'},
-                                                        'Result': {'$ref': '#/definitions/ErrorResults'}},
-                                         'type': 'object'},
                     'StatusHistory': {'properties': {'Params': {'$ref': '#/definitions/StatusHistoryRequests'},
                                                      'Result': {'$ref': '#/definitions/StatusHistoryResults'}},
                                       'type': 'object'},
-                    'UnsetModelDefaults': {'properties': {'Params': {'$ref': '#/definitions/UnsetModelDefaults'},
-                                                          'Result': {'$ref': '#/definitions/ErrorResults'}},
-                                           'type': 'object'},
                     'WatchAll': {'properties': {'Result': {'$ref': '#/definitions/AllWatcherId'}},
                                  'type': 'object'}},
      'type': 'object'}
@@ -8985,8 +9793,8 @@ class ClientFacade(Type):
         Returns -> typing.Sequence<+T_co>[~HostPort]<~HostPort>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='APIHostPorts', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Client', request='APIHostPorts', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -9000,8 +9808,8 @@ class ClientFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='AbortCurrentUpgrade', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Client', request='AbortCurrentUpgrade', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -9016,10 +9824,10 @@ class ClientFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='AddCharm', version=1, params=params)
-        params['channel'] = channel
-        params['url'] = url
+        _params = dict()
+        msg = dict(type='Client', request='AddCharm', version=1, params=_params)
+        _params['channel'] = channel
+        _params['url'] = url
         reply = await self.rpc(msg)
         return reply
 
@@ -9034,11 +9842,11 @@ class ClientFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='AddCharmWithAuthorization', version=1, params=params)
-        params['channel'] = channel
-        params['macaroon'] = macaroon
-        params['url'] = url
+        _params = dict()
+        msg = dict(type='Client', request='AddCharmWithAuthorization', version=1, params=_params)
+        _params['channel'] = channel
+        _params['macaroon'] = macaroon
+        _params['url'] = url
         reply = await self.rpc(msg)
         return reply
 
@@ -9051,9 +9859,9 @@ class ClientFacade(Type):
         Returns -> typing.Sequence<+T_co>[~AddMachinesResult]<~AddMachinesResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='AddMachines', version=1, params=params)
-        params['params'] = params
+        _params = dict()
+        msg = dict(type='Client', request='AddMachines', version=1, params=_params)
+        _params['params'] = params
         reply = await self.rpc(msg)
         return reply
 
@@ -9066,9 +9874,9 @@ class ClientFacade(Type):
         Returns -> typing.Sequence<+T_co>[~AddMachinesResult]<~AddMachinesResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='AddMachinesV2', version=1, params=params)
-        params['params'] = params
+        _params = dict()
+        msg = dict(type='Client', request='AddMachinesV2', version=1, params=_params)
+        _params['params'] = params
         reply = await self.rpc(msg)
         return reply
 
@@ -9081,8 +9889,8 @@ class ClientFacade(Type):
         Returns -> Number
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='AgentVersion', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Client', request='AgentVersion', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -9097,10 +9905,10 @@ class ClientFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='DestroyMachines', version=1, params=params)
-        params['force'] = force
-        params['machine-names'] = machine_names
+        _params = dict()
+        msg = dict(type='Client', request='DestroyMachines', version=1, params=_params)
+        _params['force'] = force
+        _params['machine-names'] = machine_names
         reply = await self.rpc(msg)
         return reply
 
@@ -9117,13 +9925,13 @@ class ClientFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), typing.Sequence<+T_co>[~Tools]<~Tools>]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='FindTools', version=1, params=params)
-        params['arch'] = arch
-        params['major'] = major
-        params['minor'] = minor
-        params['number'] = number
-        params['series'] = series
+        _params = dict()
+        msg = dict(type='Client', request='FindTools', version=1, params=_params)
+        _params['arch'] = arch
+        _params['major'] = major
+        _params['minor'] = minor
+        _params['number'] = number
+        _params['series'] = series
         reply = await self.rpc(msg)
         return reply
 
@@ -9133,27 +9941,27 @@ class ClientFacade(Type):
     async def FullStatus(self, patterns):
         '''
         patterns : typing.Sequence<+T_co>[str]
-        Returns -> typing.Union[typing.Mapping<~KT, +VT_co>[str, ~MachineStatus]<~MachineStatus>, _ForwardRef('ModelStatusInfo'), typing.Sequence<+T_co>[~RelationStatus]<~RelationStatus>]
+        Returns -> typing.Union[_ForwardRef('ModelStatusInfo'), typing.Sequence<+T_co>[~RelationStatus]<~RelationStatus>, typing.Mapping<~KT, +VT_co>[str, ~RemoteApplicationStatus]<~RemoteApplicationStatus>]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='FullStatus', version=1, params=params)
-        params['patterns'] = patterns
+        _params = dict()
+        msg = dict(type='Client', request='FullStatus', version=1, params=_params)
+        _params['patterns'] = patterns
         reply = await self.rpc(msg)
         return reply
 
 
 
-    @ReturnMapping(GetBundleChangesResults)
+    @ReturnMapping(BundleChangesResults)
     async def GetBundleChanges(self, yaml):
         '''
         yaml : str
-        Returns -> typing.Sequence<+T_co>[~BundleChangesChange]<~BundleChangesChange>
+        Returns -> typing.Sequence<+T_co>[~BundleChange]<~BundleChange>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='GetBundleChanges', version=1, params=params)
-        params['yaml'] = yaml
+        _params = dict()
+        msg = dict(type='Client', request='GetBundleChanges', version=1, params=_params)
+        _params['yaml'] = yaml
         reply = await self.rpc(msg)
         return reply
 
@@ -9166,8 +9974,8 @@ class ClientFacade(Type):
         Returns -> Value
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='GetModelConstraints', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Client', request='GetModelConstraints', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -9181,24 +9989,9 @@ class ClientFacade(Type):
         Returns -> typing.Sequence<+T_co>[~AddMachinesResult]<~AddMachinesResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='InjectMachines', version=1, params=params)
-        params['params'] = params
-        reply = await self.rpc(msg)
-        return reply
-
-
-
-    @ReturnMapping(ModelDefaultsResult)
-    async def ModelDefaults(self):
-        '''
-
-        Returns -> typing.Mapping<~KT, +VT_co>[str, ~ModelDefaults]<~ModelDefaults>
-        '''
-        # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='ModelDefaults', version=1, params=params)
-
+        _params = dict()
+        msg = dict(type='Client', request='InjectMachines', version=1, params=_params)
+        _params['params'] = params
         reply = await self.rpc(msg)
         return reply
 
@@ -9211,8 +10004,8 @@ class ClientFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, ~ConfigValue]<~ConfigValue>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='ModelGet', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Client', request='ModelGet', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -9223,11 +10016,11 @@ class ClientFacade(Type):
     async def ModelInfo(self):
         '''
 
-        Returns -> typing.Union[_ForwardRef('EntityStatus'), typing.Sequence<+T_co>[~ModelUserInfo]<~ModelUserInfo>]
+        Returns -> typing.Union[_ForwardRef('ModelMigrationStatus'), _ForwardRef('EntityStatus'), typing.Sequence<+T_co>[~ModelUserInfo]<~ModelUserInfo>]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='ModelInfo', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Client', request='ModelInfo', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -9241,9 +10034,9 @@ class ClientFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='ModelSet', version=1, params=params)
-        params['config'] = config
+        _params = dict()
+        msg = dict(type='Client', request='ModelSet', version=1, params=_params)
+        _params['config'] = config
         reply = await self.rpc(msg)
         return reply
 
@@ -9256,9 +10049,9 @@ class ClientFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='ModelUnset', version=1, params=params)
-        params['keys'] = keys
+        _params = dict()
+        msg = dict(type='Client', request='ModelUnset', version=1, params=_params)
+        _params['keys'] = keys
         reply = await self.rpc(msg)
         return reply
 
@@ -9271,8 +10064,8 @@ class ClientFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ModelUserInfoResult]<~ModelUserInfoResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='ModelUserInfo', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Client', request='ModelUserInfo', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -9286,9 +10079,9 @@ class ClientFacade(Type):
         Returns -> str
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='PrivateAddress', version=1, params=params)
-        params['target'] = target
+        _params = dict()
+        msg = dict(type='Client', request='PrivateAddress', version=1, params=_params)
+        _params['target'] = target
         reply = await self.rpc(msg)
         return reply
 
@@ -9304,12 +10097,12 @@ class ClientFacade(Type):
         Returns -> str
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='ProvisioningScript', version=1, params=params)
-        params['data-dir'] = data_dir
-        params['disable-package-commands'] = disable_package_commands
-        params['machine-id'] = machine_id
-        params['nonce'] = nonce
+        _params = dict()
+        msg = dict(type='Client', request='ProvisioningScript', version=1, params=_params)
+        _params['data-dir'] = data_dir
+        _params['disable-package-commands'] = disable_package_commands
+        _params['machine-id'] = machine_id
+        _params['nonce'] = nonce
         reply = await self.rpc(msg)
         return reply
 
@@ -9322,9 +10115,9 @@ class ClientFacade(Type):
         Returns -> str
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='PublicAddress', version=1, params=params)
-        params['target'] = target
+        _params = dict()
+        msg = dict(type='Client', request='PublicAddress', version=1, params=_params)
+        _params['target'] = target
         reply = await self.rpc(msg)
         return reply
 
@@ -9337,9 +10130,9 @@ class ClientFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ResolveCharmResult]<~ResolveCharmResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='ResolveCharms', version=1, params=params)
-        params['references'] = references
+        _params = dict()
+        msg = dict(type='Client', request='ResolveCharms', version=1, params=_params)
+        _params['references'] = references
         reply = await self.rpc(msg)
         return reply
 
@@ -9353,10 +10146,10 @@ class ClientFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='Resolved', version=1, params=params)
-        params['retry'] = retry
-        params['unit-name'] = unit_name
+        _params = dict()
+        msg = dict(type='Client', request='Resolved', version=1, params=_params)
+        _params['retry'] = retry
+        _params['unit-name'] = unit_name
         reply = await self.rpc(msg)
         return reply
 
@@ -9369,32 +10162,24 @@ class ClientFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='RetryProvisioning', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Client', request='RetryProvisioning', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
 
 
     @ReturnMapping(None)
-    async def SetModelAgentVersion(self, build, major, minor, patch, tag):
+    async def SetModelAgentVersion(self, version):
         '''
-        build : int
-        major : int
-        minor : int
-        patch : int
-        tag : str
+        version : Number
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='SetModelAgentVersion', version=1, params=params)
-        params['Build'] = build
-        params['Major'] = major
-        params['Minor'] = minor
-        params['Patch'] = patch
-        params['Tag'] = tag
+        _params = dict()
+        msg = dict(type='Client', request='SetModelAgentVersion', version=1, params=_params)
+        _params['version'] = version
         reply = await self.rpc(msg)
         return reply
 
@@ -9408,25 +10193,10 @@ class ClientFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='SetModelConstraints', version=1, params=params)
-        params['application'] = application
-        params['constraints'] = constraints
-        reply = await self.rpc(msg)
-        return reply
-
-
-
-    @ReturnMapping(ErrorResults)
-    async def SetModelDefaults(self, config):
-        '''
-        config : typing.Sequence<+T_co>[~ModelDefaultValues]<~ModelDefaultValues>
-        Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
-        '''
-        # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='SetModelDefaults', version=1, params=params)
-        params['config'] = config
+        _params = dict()
+        msg = dict(type='Client', request='SetModelConstraints', version=1, params=_params)
+        _params['application'] = application
+        _params['constraints'] = constraints
         reply = await self.rpc(msg)
         return reply
 
@@ -9439,24 +10209,9 @@ class ClientFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StatusHistoryResult]<~StatusHistoryResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='StatusHistory', version=1, params=params)
-        params['requests'] = requests
-        reply = await self.rpc(msg)
-        return reply
-
-
-
-    @ReturnMapping(ErrorResults)
-    async def UnsetModelDefaults(self, keys):
-        '''
-        keys : typing.Sequence<+T_co>[~ModelUnsetKeys]<~ModelUnsetKeys>
-        Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
-        '''
-        # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='UnsetModelDefaults', version=1, params=params)
-        params['keys'] = keys
+        _params = dict()
+        msg = dict(type='Client', request='StatusHistory', version=1, params=_params)
+        _params['requests'] = requests
         reply = await self.rpc(msg)
         return reply
 
@@ -9469,8 +10224,8 @@ class ClientFacade(Type):
         Returns -> str
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Client', request='WatchAll', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Client', request='WatchAll', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -9506,6 +10261,18 @@ class CloudFacade(Type):
                                                 'properties': {'results': {'items': {'$ref': '#/definitions/CloudCredentialResult'},
                                                                            'type': 'array'}},
                                                 'type': 'object'},
+                     'CloudInstanceTypesConstraint': {'additionalProperties': False,
+                                                      'properties': {'cloud-tag': {'type': 'string'},
+                                                                     'constraints': {'$ref': '#/definitions/Value'},
+                                                                     'region': {'type': 'string'}},
+                                                      'required': ['cloud-tag',
+                                                                   'region'],
+                                                      'type': 'object'},
+                     'CloudInstanceTypesConstraints': {'additionalProperties': False,
+                                                       'properties': {'constraints': {'items': {'$ref': '#/definitions/CloudInstanceTypesConstraint'},
+                                                                                      'type': 'array'}},
+                                                       'required': ['constraints'],
+                                                       'type': 'object'},
                      'CloudRegion': {'additionalProperties': False,
                                      'properties': {'endpoint': {'type': 'string'},
                                                     'identity-endpoint': {'type': 'string'},
@@ -9552,6 +10319,31 @@ class CloudFacade(Type):
                                                                  'type': 'array'}},
                                       'required': ['results'],
                                       'type': 'object'},
+                     'InstanceType': {'additionalProperties': False,
+                                      'properties': {'arches': {'items': {'type': 'string'},
+                                                                'type': 'array'},
+                                                     'cost': {'type': 'integer'},
+                                                     'cpu-cores': {'type': 'integer'},
+                                                     'deprecated': {'type': 'boolean'},
+                                                     'memory': {'type': 'integer'},
+                                                     'name': {'type': 'string'},
+                                                     'root-disk': {'type': 'integer'},
+                                                     'virt-type': {'type': 'string'}},
+                                      'required': ['arches', 'cpu-cores', 'memory'],
+                                      'type': 'object'},
+                     'InstanceTypesResult': {'additionalProperties': False,
+                                             'properties': {'cost-currency': {'type': 'string'},
+                                                            'cost-divisor': {'type': 'integer'},
+                                                            'cost-unit': {'type': 'string'},
+                                                            'error': {'$ref': '#/definitions/Error'},
+                                                            'instance-types': {'items': {'$ref': '#/definitions/InstanceType'},
+                                                                               'type': 'array'}},
+                                             'type': 'object'},
+                     'InstanceTypesResults': {'additionalProperties': False,
+                                              'properties': {'results': {'items': {'$ref': '#/definitions/InstanceTypesResult'},
+                                                                         'type': 'array'}},
+                                              'required': ['results'],
+                                              'type': 'object'},
                      'Macaroon': {'additionalProperties': False, 'type': 'object'},
                      'StringResult': {'additionalProperties': False,
                                       'properties': {'error': {'$ref': '#/definitions/Error'},
@@ -9585,7 +10377,21 @@ class CloudFacade(Type):
                      'UserClouds': {'additionalProperties': False,
                                     'properties': {'user-clouds': {'items': {'$ref': '#/definitions/UserCloud'},
                                                                    'type': 'array'}},
-                                    'type': 'object'}},
+                                    'type': 'object'},
+                     'Value': {'additionalProperties': False,
+                               'properties': {'arch': {'type': 'string'},
+                                              'container': {'type': 'string'},
+                                              'cores': {'type': 'integer'},
+                                              'cpu-power': {'type': 'integer'},
+                                              'instance-type': {'type': 'string'},
+                                              'mem': {'type': 'integer'},
+                                              'root-disk': {'type': 'integer'},
+                                              'spaces': {'items': {'type': 'string'},
+                                                         'type': 'array'},
+                                              'tags': {'items': {'type': 'string'},
+                                                       'type': 'array'},
+                                              'virt-type': {'type': 'string'}},
+                               'type': 'object'}},
      'properties': {'Cloud': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
                                              'Result': {'$ref': '#/definitions/CloudResults'}},
                               'type': 'object'},
@@ -9596,6 +10402,9 @@ class CloudFacade(Type):
                                    'type': 'object'},
                     'DefaultCloud': {'properties': {'Result': {'$ref': '#/definitions/StringResult'}},
                                      'type': 'object'},
+                    'InstanceTypes': {'properties': {'Params': {'$ref': '#/definitions/CloudInstanceTypesConstraints'},
+                                                     'Result': {'$ref': '#/definitions/InstanceTypesResults'}},
+                                      'type': 'object'},
                     'RevokeCredentials': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
                                                          'Result': {'$ref': '#/definitions/ErrorResults'}},
                                           'type': 'object'},
@@ -9615,9 +10424,9 @@ class CloudFacade(Type):
         Returns -> typing.Sequence<+T_co>[~CloudResult]<~CloudResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Cloud', request='Cloud', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Cloud', request='Cloud', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -9630,8 +10439,8 @@ class CloudFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, ~Cloud]<~Cloud>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Cloud', request='Clouds', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Cloud', request='Clouds', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -9645,9 +10454,9 @@ class CloudFacade(Type):
         Returns -> typing.Sequence<+T_co>[~CloudCredentialResult]<~CloudCredentialResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Cloud', request='Credential', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Cloud', request='Credential', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -9660,9 +10469,24 @@ class CloudFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Cloud', request='DefaultCloud', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Cloud', request='DefaultCloud', version=1, params=_params)
+
+        reply = await self.rpc(msg)
+        return reply
 
+
+
+    @ReturnMapping(InstanceTypesResults)
+    async def InstanceTypes(self, constraints):
+        '''
+        constraints : typing.Sequence<+T_co>[~CloudInstanceTypesConstraint]<~CloudInstanceTypesConstraint>
+        Returns -> typing.Sequence<+T_co>[~InstanceTypesResult]<~InstanceTypesResult>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Cloud', request='InstanceTypes', version=1, params=_params)
+        _params['constraints'] = constraints
         reply = await self.rpc(msg)
         return reply
 
@@ -9675,9 +10499,9 @@ class CloudFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Cloud', request='RevokeCredentials', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Cloud', request='RevokeCredentials', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -9690,9 +10514,9 @@ class CloudFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Cloud', request='UpdateCredentials', version=1, params=params)
-        params['credentials'] = credentials
+        _params = dict()
+        msg = dict(type='Cloud', request='UpdateCredentials', version=1, params=_params)
+        _params['credentials'] = credentials
         reply = await self.rpc(msg)
         return reply
 
@@ -9705,9 +10529,9 @@ class CloudFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsResult]<~StringsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Cloud', request='UserCredentials', version=1, params=params)
-        params['user-clouds'] = user_clouds
+        _params = dict()
+        msg = dict(type='Cloud', request='UserCredentials', version=1, params=_params)
+        _params['user-clouds'] = user_clouds
         reply = await self.rpc(msg)
         return reply
 
@@ -9788,6 +10612,21 @@ class ControllerFacade(Type):
                                                                  'type': 'array'}},
                                       'required': ['results'],
                                       'type': 'object'},
+                     'HostedModelConfig': {'additionalProperties': False,
+                                           'properties': {'cloud-spec': {'$ref': '#/definitions/CloudSpec'},
+                                                          'config': {'patternProperties': {'.*': {'additionalProperties': True,
+                                                                                                  'type': 'object'}},
+                                                                     'type': 'object'},
+                                                          'error': {'$ref': '#/definitions/Error'},
+                                                          'name': {'type': 'string'},
+                                                          'owner': {'type': 'string'}},
+                                           'required': ['name', 'owner'],
+                                           'type': 'object'},
+                     'HostedModelConfigsResults': {'additionalProperties': False,
+                                                   'properties': {'models': {'items': {'$ref': '#/definitions/HostedModelConfig'},
+                                                                             'type': 'array'}},
+                                                   'required': ['models'],
+                                                   'type': 'object'},
                      'InitiateMigrationArgs': {'additionalProperties': False,
                                                'properties': {'specs': {'items': {'$ref': '#/definitions/MigrationSpec'},
                                                                         'type': 'array'}},
@@ -9806,10 +10645,25 @@ class ControllerFacade(Type):
                                                   'required': ['results'],
                                                   'type': 'object'},
                      'Macaroon': {'additionalProperties': False, 'type': 'object'},
+                     'MachineHardware': {'additionalProperties': False,
+                                         'properties': {'arch': {'type': 'string'},
+                                                        'availability-zone': {'type': 'string'},
+                                                        'cores': {'type': 'integer'},
+                                                        'cpu-power': {'type': 'integer'},
+                                                        'mem': {'type': 'integer'},
+                                                        'root-disk': {'type': 'integer'},
+                                                        'tags': {'items': {'type': 'string'},
+                                                                 'type': 'array'}},
+                                         'type': 'object'},
                      'MigrationSpec': {'additionalProperties': False,
-                                       'properties': {'model-tag': {'type': 'string'},
+                                       'properties': {'external-control': {'type': 'boolean'},
+                                                      'model-tag': {'type': 'string'},
+                                                      'skip-initial-prechecks': {'type': 'boolean'},
                                                       'target-info': {'$ref': '#/definitions/MigrationTargetInfo'}},
-                                       'required': ['model-tag', 'target-info'],
+                                       'required': ['model-tag',
+                                                    'target-info',
+                                                    'external-control',
+                                                    'skip-initial-prechecks'],
                                        'type': 'object'},
                      'MigrationTargetInfo': {'additionalProperties': False,
                                              'properties': {'addrs': {'items': {'type': 'string'},
@@ -9817,7 +10671,7 @@ class ControllerFacade(Type):
                                                             'auth-tag': {'type': 'string'},
                                                             'ca-cert': {'type': 'string'},
                                                             'controller-tag': {'type': 'string'},
-                                                            'macaroon': {'type': 'string'},
+                                                            'macaroons': {'type': 'string'},
                                                             'password': {'type': 'string'}},
                                              'required': ['controller-tag',
                                                           'addrs',
@@ -9850,10 +10704,21 @@ class ControllerFacade(Type):
                                                                       'type': 'object'}},
                                             'required': ['config'],
                                             'type': 'object'},
+                     'ModelMachineInfo': {'additionalProperties': False,
+                                          'properties': {'hardware': {'$ref': '#/definitions/MachineHardware'},
+                                                         'has-vote': {'type': 'boolean'},
+                                                         'id': {'type': 'string'},
+                                                         'instance-id': {'type': 'string'},
+                                                         'status': {'type': 'string'},
+                                                         'wants-vote': {'type': 'boolean'}},
+                                          'required': ['id'],
+                                          'type': 'object'},
                      'ModelStatus': {'additionalProperties': False,
                                      'properties': {'application-count': {'type': 'integer'},
                                                     'hosted-machine-count': {'type': 'integer'},
                                                     'life': {'type': 'string'},
+                                                    'machines': {'items': {'$ref': '#/definitions/ModelMachineInfo'},
+                                                                 'type': 'array'},
                                                     'model-tag': {'type': 'string'},
                                                     'owner-tag': {'type': 'string'}},
                                      'required': ['model-tag',
@@ -9867,6 +10732,7 @@ class ControllerFacade(Type):
                                                                       'type': 'array'}},
                                             'required': ['models'],
                                             'type': 'object'},
+                     'ModelTag': {'additionalProperties': False, 'type': 'object'},
                      'ModifyControllerAccess': {'additionalProperties': False,
                                                 'properties': {'access': {'type': 'string'},
                                                                'action': {'type': 'string'},
@@ -9917,9 +10783,14 @@ class ControllerFacade(Type):
                                          'type': 'object'},
                     'DestroyController': {'properties': {'Params': {'$ref': '#/definitions/DestroyControllerArgs'}},
                                           'type': 'object'},
+                    'GetCloudSpec': {'properties': {'Params': {'$ref': '#/definitions/ModelTag'},
+                                                    'Result': {'$ref': '#/definitions/CloudSpecResult'}},
+                                     'type': 'object'},
                     'GetControllerAccess': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
                                                            'Result': {'$ref': '#/definitions/UserAccessResults'}},
                                             'type': 'object'},
+                    'HostedModelConfigs': {'properties': {'Result': {'$ref': '#/definitions/HostedModelConfigsResults'}},
+                                           'type': 'object'},
                     'InitiateMigration': {'properties': {'Params': {'$ref': '#/definitions/InitiateMigrationArgs'},
                                                          'Result': {'$ref': '#/definitions/InitiateMigrationResults'}},
                                           'type': 'object'},
@@ -9947,8 +10818,8 @@ class ControllerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~UserModel]<~UserModel>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Controller', request='AllModels', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Controller', request='AllModels', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -9962,9 +10833,9 @@ class ControllerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~CloudSpecResult]<~CloudSpecResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Controller', request='CloudSpec', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Controller', request='CloudSpec', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -9977,8 +10848,8 @@ class ControllerFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, typing.Any]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Controller', request='ControllerConfig', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Controller', request='ControllerConfig', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -9992,9 +10863,24 @@ class ControllerFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Controller', request='DestroyController', version=3, params=params)
-        params['destroy-models'] = destroy_models
+        _params = dict()
+        msg = dict(type='Controller', request='DestroyController', version=3, params=_params)
+        _params['destroy-models'] = destroy_models
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(CloudSpecResult)
+    async def GetCloudSpec(self):
+        '''
+
+        Returns -> typing.Union[_ForwardRef('Error'), _ForwardRef('CloudSpec')]
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Controller', request='GetCloudSpec', version=3, params=_params)
+
         reply = await self.rpc(msg)
         return reply
 
@@ -10007,9 +10893,24 @@ class ControllerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~UserAccessResult]<~UserAccessResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Controller', request='GetControllerAccess', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Controller', request='GetControllerAccess', version=3, params=_params)
+        _params['entities'] = entities
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(HostedModelConfigsResults)
+    async def HostedModelConfigs(self):
+        '''
+
+        Returns -> typing.Sequence<+T_co>[~HostedModelConfig]<~HostedModelConfig>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Controller', request='HostedModelConfigs', version=3, params=_params)
+
         reply = await self.rpc(msg)
         return reply
 
@@ -10022,9 +10923,9 @@ class ControllerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~InitiateMigrationResult]<~InitiateMigrationResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Controller', request='InitiateMigration', version=3, params=params)
-        params['specs'] = specs
+        _params = dict()
+        msg = dict(type='Controller', request='InitiateMigration', version=3, params=_params)
+        _params['specs'] = specs
         reply = await self.rpc(msg)
         return reply
 
@@ -10037,8 +10938,8 @@ class ControllerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ModelBlockInfo]<~ModelBlockInfo>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Controller', request='ListBlockedModels', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Controller', request='ListBlockedModels', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10052,8 +10953,8 @@ class ControllerFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, ~ConfigValue]<~ConfigValue>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Controller', request='ModelConfig', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Controller', request='ModelConfig', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10067,9 +10968,9 @@ class ControllerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ModelStatus]<~ModelStatus>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Controller', request='ModelStatus', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Controller', request='ModelStatus', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -10082,9 +10983,9 @@ class ControllerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Controller', request='ModifyControllerAccess', version=3, params=params)
-        params['changes'] = changes
+        _params = dict()
+        msg = dict(type='Controller', request='ModifyControllerAccess', version=3, params=_params)
+        _params['changes'] = changes
         reply = await self.rpc(msg)
         return reply
 
@@ -10097,9 +10998,9 @@ class ControllerFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Controller', request='RemoveBlocks', version=3, params=params)
-        params['all'] = all_
+        _params = dict()
+        msg = dict(type='Controller', request='RemoveBlocks', version=3, params=_params)
+        _params['all'] = all_
         reply = await self.rpc(msg)
         return reply
 
@@ -10112,8 +11013,8 @@ class ControllerFacade(Type):
         Returns -> str
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Controller', request='WatchAllModels', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Controller', request='WatchAllModels', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10167,6 +11068,18 @@ class DeployerFacade(Type):
                                                                     'type': 'array'}},
                                          'required': ['changes'],
                                          'type': 'object'},
+                     'EntityStatusArgs': {'additionalProperties': False,
+                                          'properties': {'data': {'patternProperties': {'.*': {'additionalProperties': True,
+                                                                                               'type': 'object'}},
+                                                                  'type': 'object'},
+                                                         'info': {'type': 'string'},
+                                                         'status': {'type': 'string'},
+                                                         'tag': {'type': 'string'}},
+                                          'required': ['tag',
+                                                       'status',
+                                                       'info',
+                                                       'data'],
+                                          'type': 'object'},
                      'Error': {'additionalProperties': False,
                                'properties': {'code': {'type': 'string'},
                                               'info': {'$ref': '#/definitions/ErrorInfo'},
@@ -10206,6 +11119,11 @@ class DeployerFacade(Type):
                                                           'error': {'$ref': '#/definitions/Error'}},
                                            'required': ['NotifyWatcherId'],
                                            'type': 'object'},
+                     'SetStatus': {'additionalProperties': False,
+                                   'properties': {'entities': {'items': {'$ref': '#/definitions/EntityStatusArgs'},
+                                                               'type': 'array'}},
+                                   'required': ['entities'],
+                                   'type': 'object'},
                      'StringResult': {'additionalProperties': False,
                                       'properties': {'error': {'$ref': '#/definitions/Error'},
                                                      'result': {'type': 'string'}},
@@ -10247,8 +11165,14 @@ class DeployerFacade(Type):
                     'SetPasswords': {'properties': {'Params': {'$ref': '#/definitions/EntityPasswords'},
                                                     'Result': {'$ref': '#/definitions/ErrorResults'}},
                                      'type': 'object'},
+                    'SetStatus': {'properties': {'Params': {'$ref': '#/definitions/SetStatus'},
+                                                 'Result': {'$ref': '#/definitions/ErrorResults'}},
+                                  'type': 'object'},
                     'StateAddresses': {'properties': {'Result': {'$ref': '#/definitions/StringsResult'}},
                                        'type': 'object'},
+                    'UpdateStatus': {'properties': {'Params': {'$ref': '#/definitions/SetStatus'},
+                                                    'Result': {'$ref': '#/definitions/ErrorResults'}},
+                                     'type': 'object'},
                     'WatchAPIHostPorts': {'properties': {'Result': {'$ref': '#/definitions/NotifyWatchResult'}},
                                           'type': 'object'},
                     'WatchUnits': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
@@ -10264,8 +11188,8 @@ class DeployerFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), typing.Sequence<+T_co>[str]]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Deployer', request='APIAddresses', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Deployer', request='APIAddresses', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10279,8 +11203,8 @@ class DeployerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~HostPort]<~HostPort>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Deployer', request='APIHostPorts', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Deployer', request='APIHostPorts', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10294,8 +11218,8 @@ class DeployerFacade(Type):
         Returns -> typing.Sequence<+T_co>[int]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Deployer', request='CACert', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Deployer', request='CACert', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10309,8 +11233,8 @@ class DeployerFacade(Type):
         Returns -> typing.Sequence<+T_co>[str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Deployer', request='ConnectionInfo', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Deployer', request='ConnectionInfo', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10324,9 +11248,9 @@ class DeployerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~LifeResult]<~LifeResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Deployer', request='Life', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Deployer', request='Life', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -10339,8 +11263,8 @@ class DeployerFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Deployer', request='ModelUUID', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Deployer', request='ModelUUID', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10354,9 +11278,9 @@ class DeployerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Deployer', request='Remove', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Deployer', request='Remove', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -10369,24 +11293,54 @@ class DeployerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Deployer', request='SetPasswords', version=1, params=params)
-        params['changes'] = changes
+        _params = dict()
+        msg = dict(type='Deployer', request='SetPasswords', version=1, params=_params)
+        _params['changes'] = changes
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(ErrorResults)
+    async def SetStatus(self, entities):
+        '''
+        entities : typing.Sequence<+T_co>[~EntityStatusArgs]<~EntityStatusArgs>
+        Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Deployer', request='SetStatus', version=1, params=_params)
+        _params['entities'] = entities
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(StringsResult)
+    async def StateAddresses(self):
+        '''
+
+        Returns -> typing.Union[_ForwardRef('Error'), typing.Sequence<+T_co>[str]]
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Deployer', request='StateAddresses', version=1, params=_params)
+
         reply = await self.rpc(msg)
         return reply
 
 
 
-    @ReturnMapping(StringsResult)
-    async def StateAddresses(self):
+    @ReturnMapping(ErrorResults)
+    async def UpdateStatus(self, entities):
         '''
-
-        Returns -> typing.Union[_ForwardRef('Error'), typing.Sequence<+T_co>[str]]
+        entities : typing.Sequence<+T_co>[~EntityStatusArgs]<~EntityStatusArgs>
+        Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Deployer', request='StateAddresses', version=1, params=params)
-
+        _params = dict()
+        msg = dict(type='Deployer', request='UpdateStatus', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -10399,8 +11353,8 @@ class DeployerFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Deployer', request='WatchAPIHostPorts', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Deployer', request='WatchAPIHostPorts', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10414,9 +11368,9 @@ class DeployerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsWatchResult]<~StringsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Deployer', request='WatchUnits', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Deployer', request='WatchUnits', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -10539,9 +11493,9 @@ class DiscoverSpacesFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='DiscoverSpaces', request='AddSubnets', version=2, params=params)
-        params['subnets'] = subnets
+        _params = dict()
+        msg = dict(type='DiscoverSpaces', request='AddSubnets', version=2, params=_params)
+        _params['subnets'] = subnets
         reply = await self.rpc(msg)
         return reply
 
@@ -10554,9 +11508,9 @@ class DiscoverSpacesFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='DiscoverSpaces', request='CreateSpaces', version=2, params=params)
-        params['spaces'] = spaces
+        _params = dict()
+        msg = dict(type='DiscoverSpaces', request='CreateSpaces', version=2, params=_params)
+        _params['spaces'] = spaces
         reply = await self.rpc(msg)
         return reply
 
@@ -10569,8 +11523,8 @@ class DiscoverSpacesFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ProviderSpace]<~ProviderSpace>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='DiscoverSpaces', request='ListSpaces', version=2, params=params)
+        _params = dict()
+        msg = dict(type='DiscoverSpaces', request='ListSpaces', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10585,10 +11539,10 @@ class DiscoverSpacesFacade(Type):
         Returns -> typing.Sequence<+T_co>[~Subnet]<~Subnet>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='DiscoverSpaces', request='ListSubnets', version=2, params=params)
-        params['space-tag'] = space_tag
-        params['zone'] = zone
+        _params = dict()
+        msg = dict(type='DiscoverSpaces', request='ListSubnets', version=2, params=_params)
+        _params['space-tag'] = space_tag
+        _params['zone'] = zone
         reply = await self.rpc(msg)
         return reply
 
@@ -10601,8 +11555,8 @@ class DiscoverSpacesFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, typing.Any]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='DiscoverSpaces', request='ModelConfig', version=2, params=params)
+        _params = dict()
+        msg = dict(type='DiscoverSpaces', request='ModelConfig', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10677,9 +11631,9 @@ class DiskManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='DiskManager', request='SetMachineBlockDevices', version=2, params=params)
-        params['machine-block-devices'] = machine_block_devices
+        _params = dict()
+        msg = dict(type='DiskManager', request='SetMachineBlockDevices', version=2, params=_params)
+        _params['machine-block-devices'] = machine_block_devices
         reply = await self.rpc(msg)
         return reply
 
@@ -10718,8 +11672,8 @@ class EntityWatcherFacade(Type):
         Returns -> typing.Union[typing.Sequence<+T_co>[str], _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='EntityWatcher', request='Next', version=2, params=params)
+        _params = dict()
+        msg = dict(type='EntityWatcher', request='Next', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10733,8 +11687,8 @@ class EntityWatcherFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='EntityWatcher', request='Stop', version=2, params=params)
+        _params = dict()
+        msg = dict(type='EntityWatcher', request='Stop', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10781,8 +11735,8 @@ class FilesystemAttachmentsWatcherFacade(Type):
         Returns -> typing.Union[typing.Sequence<+T_co>[~MachineStorageId]<~MachineStorageId>, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='FilesystemAttachmentsWatcher', request='Next', version=2, params=params)
+        _params = dict()
+        msg = dict(type='FilesystemAttachmentsWatcher', request='Next', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10796,8 +11750,8 @@ class FilesystemAttachmentsWatcherFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='FilesystemAttachmentsWatcher', request='Stop', version=2, params=params)
+        _params = dict()
+        msg = dict(type='FilesystemAttachmentsWatcher', request='Stop', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -10907,6 +11861,7 @@ class FirewallerFacade(Type):
                                                                      'type': 'object'}},
                                            'required': ['config'],
                                            'type': 'object'},
+                     'ModelTag': {'additionalProperties': False, 'type': 'object'},
                      'NotifyWatchResult': {'additionalProperties': False,
                                            'properties': {'NotifyWatcherId': {'type': 'string'},
                                                           'error': {'$ref': '#/definitions/Error'}},
@@ -10961,6 +11916,9 @@ class FirewallerFacade(Type):
                     'GetAssignedMachine': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
                                                           'Result': {'$ref': '#/definitions/StringResults'}},
                                            'type': 'object'},
+                    'GetCloudSpec': {'properties': {'Params': {'$ref': '#/definitions/ModelTag'},
+                                                    'Result': {'$ref': '#/definitions/CloudSpecResult'}},
+                                     'type': 'object'},
                     'GetExposed': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
                                                   'Result': {'$ref': '#/definitions/BoolResults'}},
                                    'type': 'object'},
@@ -11001,9 +11959,9 @@ class FirewallerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~CloudSpecResult]<~CloudSpecResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Firewaller', request='CloudSpec', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Firewaller', request='CloudSpec', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11016,9 +11974,24 @@ class FirewallerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringResult]<~StringResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Firewaller', request='GetAssignedMachine', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Firewaller', request='GetAssignedMachine', version=3, params=_params)
+        _params['entities'] = entities
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(CloudSpecResult)
+    async def GetCloudSpec(self):
+        '''
+
+        Returns -> typing.Union[_ForwardRef('Error'), _ForwardRef('CloudSpec')]
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Firewaller', request='GetCloudSpec', version=3, params=_params)
+
         reply = await self.rpc(msg)
         return reply
 
@@ -11031,9 +12004,9 @@ class FirewallerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~BoolResult]<~BoolResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Firewaller', request='GetExposed', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Firewaller', request='GetExposed', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11046,9 +12019,9 @@ class FirewallerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsResult]<~StringsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Firewaller', request='GetMachineActiveSubnets', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Firewaller', request='GetMachineActiveSubnets', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11061,9 +12034,9 @@ class FirewallerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~MachinePortsResult]<~MachinePortsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Firewaller', request='GetMachinePorts', version=3, params=params)
-        params['params'] = params
+        _params = dict()
+        msg = dict(type='Firewaller', request='GetMachinePorts', version=3, params=_params)
+        _params['params'] = params
         reply = await self.rpc(msg)
         return reply
 
@@ -11076,9 +12049,9 @@ class FirewallerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringResult]<~StringResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Firewaller', request='InstanceId', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Firewaller', request='InstanceId', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11091,9 +12064,9 @@ class FirewallerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~LifeResult]<~LifeResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Firewaller', request='Life', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Firewaller', request='Life', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11106,8 +12079,8 @@ class FirewallerFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, typing.Any]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Firewaller', request='ModelConfig', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Firewaller', request='ModelConfig', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -11121,9 +12094,9 @@ class FirewallerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Firewaller', request='Watch', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Firewaller', request='Watch', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11136,8 +12109,8 @@ class FirewallerFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Firewaller', request='WatchForModelConfigChanges', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Firewaller', request='WatchForModelConfigChanges', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -11151,8 +12124,8 @@ class FirewallerFacade(Type):
         Returns -> typing.Union[typing.Sequence<+T_co>[str], _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Firewaller', request='WatchModelMachines', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Firewaller', request='WatchModelMachines', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -11166,9 +12139,9 @@ class FirewallerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsWatchResult]<~StringsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Firewaller', request='WatchOpenedPorts', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Firewaller', request='WatchOpenedPorts', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11181,9 +12154,9 @@ class FirewallerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsWatchResult]<~StringsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Firewaller', request='WatchUnits', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Firewaller', request='WatchUnits', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11229,13 +12202,11 @@ class HighAvailabilityFacade(Type):
                                             'type': 'object'},
                      'ControllersSpec': {'additionalProperties': False,
                                          'properties': {'constraints': {'$ref': '#/definitions/Value'},
-                                                        'model-tag': {'type': 'string'},
                                                         'num-controllers': {'type': 'integer'},
                                                         'placement': {'items': {'type': 'string'},
                                                                       'type': 'array'},
                                                         'series': {'type': 'string'}},
-                                         'required': ['model-tag',
-                                                      'num-controllers'],
+                                         'required': ['num-controllers'],
                                          'type': 'object'},
                      'ControllersSpecs': {'additionalProperties': False,
                                           'properties': {'specs': {'items': {'$ref': '#/definitions/ControllersSpec'},
@@ -11290,19 +12261,29 @@ class HighAvailabilityFacade(Type):
                                                           'master',
                                                           'ha-members'],
                                              'type': 'object'},
+                     'MongoVersion': {'additionalProperties': False,
+                                      'properties': {'engine': {'type': 'string'},
+                                                     'major': {'type': 'integer'},
+                                                     'minor': {'type': 'integer'},
+                                                     'patch': {'type': 'string'}},
+                                      'required': ['major',
+                                                   'minor',
+                                                   'patch',
+                                                   'engine'],
+                                      'type': 'object'},
                      'ResumeReplicationParams': {'additionalProperties': False,
                                                  'properties': {'members': {'items': {'$ref': '#/definitions/Member'},
                                                                             'type': 'array'}},
                                                  'required': ['members'],
                                                  'type': 'object'},
                      'UpgradeMongoParams': {'additionalProperties': False,
-                                            'properties': {'target': {'$ref': '#/definitions/Version'}},
+                                            'properties': {'target': {'$ref': '#/definitions/MongoVersion'}},
                                             'required': ['target'],
                                             'type': 'object'},
                      'Value': {'additionalProperties': False,
                                'properties': {'arch': {'type': 'string'},
                                               'container': {'type': 'string'},
-                                              'cpu-cores': {'type': 'integer'},
+                                              'cores': {'type': 'integer'},
                                               'cpu-power': {'type': 'integer'},
                                               'instance-type': {'type': 'string'},
                                               'mem': {'type': 'integer'},
@@ -11312,17 +12293,7 @@ class HighAvailabilityFacade(Type):
                                               'tags': {'items': {'type': 'string'},
                                                        'type': 'array'},
                                               'virt-type': {'type': 'string'}},
-                               'type': 'object'},
-                     'Version': {'additionalProperties': False,
-                                 'properties': {'Major': {'type': 'integer'},
-                                                'Minor': {'type': 'integer'},
-                                                'Patch': {'type': 'string'},
-                                                'StorageEngine': {'type': 'string'}},
-                                 'required': ['Major',
-                                              'Minor',
-                                              'Patch',
-                                              'StorageEngine'],
-                                 'type': 'object'}},
+                               'type': 'object'}},
      'properties': {'EnableHA': {'properties': {'Params': {'$ref': '#/definitions/ControllersSpecs'},
                                                 'Result': {'$ref': '#/definitions/ControllersChangeResults'}},
                                  'type': 'object'},
@@ -11341,9 +12312,9 @@ class HighAvailabilityFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ControllersChangeResult]<~ControllersChangeResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='HighAvailability', request='EnableHA', version=2, params=params)
-        params['specs'] = specs
+        _params = dict()
+        msg = dict(type='HighAvailability', request='EnableHA', version=2, params=_params)
+        _params['specs'] = specs
         reply = await self.rpc(msg)
         return reply
 
@@ -11356,30 +12327,24 @@ class HighAvailabilityFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='HighAvailability', request='ResumeHAReplicationAfterUpgrade', version=2, params=params)
-        params['members'] = members
+        _params = dict()
+        msg = dict(type='HighAvailability', request='ResumeHAReplicationAfterUpgrade', version=2, params=_params)
+        _params['members'] = members
         reply = await self.rpc(msg)
         return reply
 
 
 
     @ReturnMapping(MongoUpgradeResults)
-    async def StopHAReplicationForUpgrade(self, major, minor, patch, storageengine):
+    async def StopHAReplicationForUpgrade(self, target):
         '''
-        major : int
-        minor : int
-        patch : str
-        storageengine : str
+        target : MongoVersion
         Returns -> typing.Union[_ForwardRef('HAMember'), typing.Sequence<+T_co>[~Member]<~Member>]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='HighAvailability', request='StopHAReplicationForUpgrade', version=2, params=params)
-        params['Major'] = major
-        params['Minor'] = minor
-        params['Patch'] = patch
-        params['StorageEngine'] = storageengine
+        _params = dict()
+        msg = dict(type='HighAvailability', request='StopHAReplicationForUpgrade', version=2, params=_params)
+        _params['target'] = target
         reply = await self.rpc(msg)
         return reply
 
@@ -11430,9 +12395,9 @@ class HostKeyReporterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='HostKeyReporter', request='ReportKeys', version=1, params=params)
-        params['entity-keys'] = entity_keys
+        _params = dict()
+        msg = dict(type='HostKeyReporter', request='ReportKeys', version=1, params=_params)
+        _params['entity-keys'] = entity_keys
         reply = await self.rpc(msg)
         return reply
 
@@ -11504,9 +12469,9 @@ class ImageManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ImageManager', request='DeleteImages', version=2, params=params)
-        params['images'] = images
+        _params = dict()
+        msg = dict(type='ImageManager', request='DeleteImages', version=2, params=_params)
+        _params['images'] = images
         reply = await self.rpc(msg)
         return reply
 
@@ -11519,9 +12484,9 @@ class ImageManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ImageMetadata]<~ImageMetadata>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ImageManager', request='ListImages', version=2, params=params)
-        params['images'] = images
+        _params = dict()
+        msg = dict(type='ImageManager', request='ListImages', version=2, params=_params)
+        _params['images'] = images
         reply = await self.rpc(msg)
         return reply
 
@@ -11616,9 +12581,9 @@ class ImageMetadataFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ImageMetadata', request='Delete', version=2, params=params)
-        params['image-ids'] = image_ids
+        _params = dict()
+        msg = dict(type='ImageMetadata', request='Delete', version=2, params=_params)
+        _params['image-ids'] = image_ids
         reply = await self.rpc(msg)
         return reply
 
@@ -11636,14 +12601,14 @@ class ImageMetadataFacade(Type):
         Returns -> typing.Sequence<+T_co>[~CloudImageMetadata]<~CloudImageMetadata>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ImageMetadata', request='List', version=2, params=params)
-        params['arches'] = arches
-        params['region'] = region
-        params['root-storage-type'] = root_storage_type
-        params['series'] = series
-        params['stream'] = stream
-        params['virt-type'] = virt_type
+        _params = dict()
+        msg = dict(type='ImageMetadata', request='List', version=2, params=_params)
+        _params['arches'] = arches
+        _params['region'] = region
+        _params['root-storage-type'] = root_storage_type
+        _params['series'] = series
+        _params['stream'] = stream
+        _params['virt-type'] = virt_type
         reply = await self.rpc(msg)
         return reply
 
@@ -11656,9 +12621,9 @@ class ImageMetadataFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ImageMetadata', request='Save', version=2, params=params)
-        params['metadata'] = metadata
+        _params = dict()
+        msg = dict(type='ImageMetadata', request='Save', version=2, params=_params)
+        _params['metadata'] = metadata
         reply = await self.rpc(msg)
         return reply
 
@@ -11671,8 +12636,8 @@ class ImageMetadataFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ImageMetadata', request='UpdateFromPublishedImages', version=2, params=params)
+        _params = dict()
+        msg = dict(type='ImageMetadata', request='UpdateFromPublishedImages', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -11866,9 +12831,9 @@ class InstancePollerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~BoolResult]<~BoolResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='InstancePoller', request='AreManuallyProvisioned', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='InstancePoller', request='AreManuallyProvisioned', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11881,9 +12846,9 @@ class InstancePollerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringResult]<~StringResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='InstancePoller', request='InstanceId', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='InstancePoller', request='InstanceId', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11896,9 +12861,9 @@ class InstancePollerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StatusResult]<~StatusResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='InstancePoller', request='InstanceStatus', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='InstancePoller', request='InstanceStatus', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11911,9 +12876,9 @@ class InstancePollerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~LifeResult]<~LifeResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='InstancePoller', request='Life', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='InstancePoller', request='Life', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11926,8 +12891,8 @@ class InstancePollerFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, typing.Any]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='InstancePoller', request='ModelConfig', version=3, params=params)
+        _params = dict()
+        msg = dict(type='InstancePoller', request='ModelConfig', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -11941,9 +12906,9 @@ class InstancePollerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~MachineAddressesResult]<~MachineAddressesResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='InstancePoller', request='ProviderAddresses', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='InstancePoller', request='ProviderAddresses', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11956,9 +12921,9 @@ class InstancePollerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='InstancePoller', request='SetInstanceStatus', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='InstancePoller', request='SetInstanceStatus', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -11971,9 +12936,9 @@ class InstancePollerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='InstancePoller', request='SetProviderAddresses', version=3, params=params)
-        params['machine-addresses'] = machine_addresses
+        _params = dict()
+        msg = dict(type='InstancePoller', request='SetProviderAddresses', version=3, params=_params)
+        _params['machine-addresses'] = machine_addresses
         reply = await self.rpc(msg)
         return reply
 
@@ -11986,9 +12951,9 @@ class InstancePollerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StatusResult]<~StatusResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='InstancePoller', request='Status', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='InstancePoller', request='Status', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -12001,8 +12966,8 @@ class InstancePollerFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='InstancePoller', request='WatchForModelConfigChanges', version=3, params=params)
+        _params = dict()
+        msg = dict(type='InstancePoller', request='WatchForModelConfigChanges', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -12016,8 +12981,8 @@ class InstancePollerFacade(Type):
         Returns -> typing.Union[typing.Sequence<+T_co>[str], _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='InstancePoller', request='WatchModelMachines', version=3, params=params)
+        _params = dict()
+        msg = dict(type='InstancePoller', request='WatchModelMachines', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -12098,10 +13063,10 @@ class KeyManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='KeyManager', request='AddKeys', version=1, params=params)
-        params['ssh-keys'] = ssh_keys
-        params['user'] = user
+        _params = dict()
+        msg = dict(type='KeyManager', request='AddKeys', version=1, params=_params)
+        _params['ssh-keys'] = ssh_keys
+        _params['user'] = user
         reply = await self.rpc(msg)
         return reply
 
@@ -12115,10 +13080,10 @@ class KeyManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='KeyManager', request='DeleteKeys', version=1, params=params)
-        params['ssh-keys'] = ssh_keys
-        params['user'] = user
+        _params = dict()
+        msg = dict(type='KeyManager', request='DeleteKeys', version=1, params=_params)
+        _params['ssh-keys'] = ssh_keys
+        _params['user'] = user
         reply = await self.rpc(msg)
         return reply
 
@@ -12132,10 +13097,10 @@ class KeyManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='KeyManager', request='ImportKeys', version=1, params=params)
-        params['ssh-keys'] = ssh_keys
-        params['user'] = user
+        _params = dict()
+        msg = dict(type='KeyManager', request='ImportKeys', version=1, params=_params)
+        _params['ssh-keys'] = ssh_keys
+        _params['user'] = user
         reply = await self.rpc(msg)
         return reply
 
@@ -12149,10 +13114,10 @@ class KeyManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsResult]<~StringsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='KeyManager', request='ListKeys', version=1, params=params)
-        params['entities'] = entities
-        params['mode'] = mode
+        _params = dict()
+        msg = dict(type='KeyManager', request='ListKeys', version=1, params=_params)
+        _params['entities'] = entities
+        _params['mode'] = mode
         reply = await self.rpc(msg)
         return reply
 
@@ -12216,9 +13181,9 @@ class KeyUpdaterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsResult]<~StringsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='KeyUpdater', request='AuthorisedKeys', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='KeyUpdater', request='AuthorisedKeys', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -12231,9 +13196,9 @@ class KeyUpdaterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='KeyUpdater', request='WatchAuthorisedKeys', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='KeyUpdater', request='WatchAuthorisedKeys', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -12293,9 +13258,9 @@ class LeadershipServiceFacade(Type):
         Returns -> Error
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='LeadershipService', request='BlockUntilLeadershipReleased', version=2, params=params)
-        params['Name'] = name
+        _params = dict()
+        msg = dict(type='LeadershipService', request='BlockUntilLeadershipReleased', version=2, params=_params)
+        _params['Name'] = name
         reply = await self.rpc(msg)
         return reply
 
@@ -12308,9 +13273,9 @@ class LeadershipServiceFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='LeadershipService', request='ClaimLeadership', version=2, params=params)
-        params['params'] = params
+        _params = dict()
+        msg = dict(type='LeadershipService', request='ClaimLeadership', version=2, params=_params)
+        _params['params'] = params
         reply = await self.rpc(msg)
         return reply
 
@@ -12374,9 +13339,9 @@ class LifeFlagFacade(Type):
         Returns -> typing.Sequence<+T_co>[~LifeResult]<~LifeResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='LifeFlag', request='Life', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='LifeFlag', request='Life', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -12389,9 +13354,9 @@ class LifeFlagFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='LifeFlag', request='Watch', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='LifeFlag', request='Watch', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -12470,9 +13435,9 @@ class LogForwardingFacade(Type):
         Returns -> typing.Sequence<+T_co>[~LogForwardingGetLastSentResult]<~LogForwardingGetLastSentResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='LogForwarding', request='GetLastSent', version=1, params=params)
-        params['ids'] = ids
+        _params = dict()
+        msg = dict(type='LogForwarding', request='GetLastSent', version=1, params=_params)
+        _params['ids'] = ids
         reply = await self.rpc(msg)
         return reply
 
@@ -12485,9 +13450,9 @@ class LogForwardingFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='LogForwarding', request='SetLastSent', version=1, params=params)
-        params['params'] = params
+        _params = dict()
+        msg = dict(type='LogForwarding', request='SetLastSent', version=1, params=_params)
+        _params['params'] = params
         reply = await self.rpc(msg)
         return reply
 
@@ -12551,9 +13516,9 @@ class LoggerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringResult]<~StringResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Logger', request='LoggingConfig', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Logger', request='LoggingConfig', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -12566,9 +13531,9 @@ class LoggerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Logger', request='WatchLoggingConfig', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Logger', request='WatchLoggingConfig', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -12692,9 +13657,9 @@ class MachineActionsFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ActionResult]<~ActionResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MachineActions', request='Actions', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MachineActions', request='Actions', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -12707,9 +13672,9 @@ class MachineActionsFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MachineActions', request='BeginActions', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MachineActions', request='BeginActions', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -12722,9 +13687,9 @@ class MachineActionsFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MachineActions', request='FinishActions', version=1, params=params)
-        params['results'] = results
+        _params = dict()
+        msg = dict(type='MachineActions', request='FinishActions', version=1, params=_params)
+        _params['results'] = results
         reply = await self.rpc(msg)
         return reply
 
@@ -12737,9 +13702,9 @@ class MachineActionsFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ActionsByReceiver]<~ActionsByReceiver>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MachineActions', request='RunningActions', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MachineActions', request='RunningActions', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -12752,9 +13717,9 @@ class MachineActionsFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsWatchResult]<~StringsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MachineActions', request='WatchActionNotifications', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MachineActions', request='WatchActionNotifications', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -12835,7 +13800,40 @@ class MachineManagerFacade(Type):
                                                                 'tags': {'items': {'type': 'string'},
                                                                          'type': 'array'}},
                                                  'type': 'object'},
+                     'InstanceType': {'additionalProperties': False,
+                                      'properties': {'arches': {'items': {'type': 'string'},
+                                                                'type': 'array'},
+                                                     'cost': {'type': 'integer'},
+                                                     'cpu-cores': {'type': 'integer'},
+                                                     'deprecated': {'type': 'boolean'},
+                                                     'memory': {'type': 'integer'},
+                                                     'name': {'type': 'string'},
+                                                     'root-disk': {'type': 'integer'},
+                                                     'virt-type': {'type': 'string'}},
+                                      'required': ['arches', 'cpu-cores', 'memory'],
+                                      'type': 'object'},
+                     'InstanceTypesResult': {'additionalProperties': False,
+                                             'properties': {'cost-currency': {'type': 'string'},
+                                                            'cost-divisor': {'type': 'integer'},
+                                                            'cost-unit': {'type': 'string'},
+                                                            'error': {'$ref': '#/definitions/Error'},
+                                                            'instance-types': {'items': {'$ref': '#/definitions/InstanceType'},
+                                                                               'type': 'array'}},
+                                             'type': 'object'},
+                     'InstanceTypesResults': {'additionalProperties': False,
+                                              'properties': {'results': {'items': {'$ref': '#/definitions/InstanceTypesResult'},
+                                                                         'type': 'array'}},
+                                              'required': ['results'],
+                                              'type': 'object'},
                      'Macaroon': {'additionalProperties': False, 'type': 'object'},
+                     'ModelInstanceTypesConstraint': {'additionalProperties': False,
+                                                      'properties': {'value': {'$ref': '#/definitions/Value'}},
+                                                      'type': 'object'},
+                     'ModelInstanceTypesConstraints': {'additionalProperties': False,
+                                                       'properties': {'constraints': {'items': {'$ref': '#/definitions/ModelInstanceTypesConstraint'},
+                                                                                      'type': 'array'}},
+                                                       'required': ['constraints'],
+                                                       'type': 'object'},
                      'Placement': {'additionalProperties': False,
                                    'properties': {'directive': {'type': 'string'},
                                                   'scope': {'type': 'string'}},
@@ -12844,7 +13842,7 @@ class MachineManagerFacade(Type):
                      'Value': {'additionalProperties': False,
                                'properties': {'arch': {'type': 'string'},
                                               'container': {'type': 'string'},
-                                              'cpu-cores': {'type': 'integer'},
+                                              'cores': {'type': 'integer'},
                                               'cpu-power': {'type': 'integer'},
                                               'instance-type': {'type': 'string'},
                                               'mem': {'type': 'integer'},
@@ -12857,7 +13855,10 @@ class MachineManagerFacade(Type):
                                'type': 'object'}},
      'properties': {'AddMachines': {'properties': {'Params': {'$ref': '#/definitions/AddMachines'},
                                                    'Result': {'$ref': '#/definitions/AddMachinesResults'}},
-                                    'type': 'object'}},
+                                    'type': 'object'},
+                    'InstanceTypes': {'properties': {'Params': {'$ref': '#/definitions/ModelInstanceTypesConstraints'},
+                                                     'Result': {'$ref': '#/definitions/InstanceTypesResults'}},
+                                      'type': 'object'}},
      'type': 'object'}
     
 
@@ -12868,9 +13869,24 @@ class MachineManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~AddMachinesResult]<~AddMachinesResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MachineManager', request='AddMachines', version=2, params=params)
-        params['params'] = params
+        _params = dict()
+        msg = dict(type='MachineManager', request='AddMachines', version=2, params=_params)
+        _params['params'] = params
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(InstanceTypesResults)
+    async def InstanceTypes(self, constraints):
+        '''
+        constraints : typing.Sequence<+T_co>[~ModelInstanceTypesConstraint]<~ModelInstanceTypesConstraint>
+        Returns -> typing.Sequence<+T_co>[~InstanceTypesResult]<~InstanceTypesResult>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='MachineManager', request='InstanceTypes', version=2, params=_params)
+        _params['constraints'] = constraints
         reply = await self.rpc(msg)
         return reply
 
@@ -12961,9 +13977,9 @@ class MachineUndertakerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~EntitiesResult]<~EntitiesResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MachineUndertaker', request='AllMachineRemovals', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MachineUndertaker', request='AllMachineRemovals', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -12976,9 +13992,9 @@ class MachineUndertakerFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MachineUndertaker', request='CompleteMachineRemovals', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MachineUndertaker', request='CompleteMachineRemovals', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -12991,9 +14007,9 @@ class MachineUndertakerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ProviderInterfaceInfoResult]<~ProviderInterfaceInfoResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MachineUndertaker', request='GetMachineProviderInterfaceInfo', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MachineUndertaker', request='GetMachineProviderInterfaceInfo', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13006,9 +14022,9 @@ class MachineUndertakerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MachineUndertaker', request='WatchMachineRemovals', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MachineUndertaker', request='WatchMachineRemovals', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13128,6 +14144,8 @@ class MachinerFacade(Type):
                                                       'provider-space-id': {'type': 'string'},
                                                       'provider-subnet-id': {'type': 'string'},
                                                       'provider-vlan-id': {'type': 'string'},
+                                                      'routes': {'items': {'$ref': '#/definitions/NetworkRoute'},
+                                                                 'type': 'array'},
                                                       'vlan-tag': {'type': 'integer'}},
                                        'required': ['device-index',
                                                     'mac-address',
@@ -13144,6 +14162,14 @@ class MachinerFacade(Type):
                                                     'interface-type',
                                                     'disabled'],
                                        'type': 'object'},
+                     'NetworkRoute': {'additionalProperties': False,
+                                      'properties': {'destination-cidr': {'type': 'string'},
+                                                     'gateway-ip': {'type': 'string'},
+                                                     'metric': {'type': 'integer'}},
+                                      'required': ['destination-cidr',
+                                                   'gateway-ip',
+                                                   'metric'],
+                                      'type': 'object'},
                      'NotifyWatchResult': {'additionalProperties': False,
                                            'properties': {'NotifyWatcherId': {'type': 'string'},
                                                           'error': {'$ref': '#/definitions/Error'}},
@@ -13226,8 +14252,8 @@ class MachinerFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), typing.Sequence<+T_co>[str]]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='APIAddresses', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Machiner', request='APIAddresses', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -13241,8 +14267,8 @@ class MachinerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~HostPort]<~HostPort>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='APIHostPorts', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Machiner', request='APIHostPorts', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -13256,8 +14282,8 @@ class MachinerFacade(Type):
         Returns -> typing.Sequence<+T_co>[int]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='CACert', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Machiner', request='CACert', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -13271,9 +14297,9 @@ class MachinerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='EnsureDead', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Machiner', request='EnsureDead', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13286,9 +14312,9 @@ class MachinerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~JobsResult]<~JobsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='Jobs', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Machiner', request='Jobs', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13301,9 +14327,9 @@ class MachinerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~LifeResult]<~LifeResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='Life', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Machiner', request='Life', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13316,8 +14342,8 @@ class MachinerFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='ModelUUID', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Machiner', request='ModelUUID', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -13331,9 +14357,9 @@ class MachinerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='SetMachineAddresses', version=1, params=params)
-        params['machine-addresses'] = machine_addresses
+        _params = dict()
+        msg = dict(type='Machiner', request='SetMachineAddresses', version=1, params=_params)
+        _params['machine-addresses'] = machine_addresses
         reply = await self.rpc(msg)
         return reply
 
@@ -13347,10 +14373,10 @@ class MachinerFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='SetObservedNetworkConfig', version=1, params=params)
-        params['config'] = config
-        params['tag'] = tag
+        _params = dict()
+        msg = dict(type='Machiner', request='SetObservedNetworkConfig', version=1, params=_params)
+        _params['config'] = config
+        _params['tag'] = tag
         reply = await self.rpc(msg)
         return reply
 
@@ -13363,9 +14389,9 @@ class MachinerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='SetProviderNetworkConfig', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Machiner', request='SetProviderNetworkConfig', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13378,9 +14404,9 @@ class MachinerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='SetStatus', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Machiner', request='SetStatus', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13393,9 +14419,9 @@ class MachinerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='UpdateStatus', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Machiner', request='UpdateStatus', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13408,9 +14434,9 @@ class MachinerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='Watch', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Machiner', request='Watch', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13423,8 +14449,8 @@ class MachinerFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Machiner', request='WatchAPIHostPorts', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Machiner', request='WatchAPIHostPorts', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -13490,9 +14516,9 @@ class MeterStatusFacade(Type):
         Returns -> typing.Sequence<+T_co>[~MeterStatusResult]<~MeterStatusResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MeterStatus', request='GetMeterStatus', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MeterStatus', request='GetMeterStatus', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13505,9 +14531,9 @@ class MeterStatusFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MeterStatus', request='WatchMeterStatus', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MeterStatus', request='WatchMeterStatus', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13576,9 +14602,9 @@ class MetricsAdderFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MetricsAdder', request='AddMetricBatches', version=2, params=params)
-        params['batches'] = batches
+        _params = dict()
+        msg = dict(type='MetricsAdder', request='AddMetricBatches', version=2, params=_params)
+        _params['batches'] = batches
         reply = await self.rpc(msg)
         return reply
 
@@ -13634,8 +14660,9 @@ class MetricsDebugFacade(Type):
                                       'properties': {'key': {'type': 'string'},
                                                      'time': {'format': 'date-time',
                                                               'type': 'string'},
+                                                     'unit': {'type': 'string'},
                                                      'value': {'type': 'string'}},
-                                      'required': ['time', 'key', 'value'],
+                                      'required': ['time', 'key', 'value', 'unit'],
                                       'type': 'object'},
                      'MetricResults': {'additionalProperties': False,
                                        'properties': {'results': {'items': {'$ref': '#/definitions/EntityMetrics'},
@@ -13658,9 +14685,9 @@ class MetricsDebugFacade(Type):
         Returns -> typing.Sequence<+T_co>[~EntityMetrics]<~EntityMetrics>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MetricsDebug', request='GetMetrics', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MetricsDebug', request='GetMetrics', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13673,9 +14700,9 @@ class MetricsDebugFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MetricsDebug', request='SetMeterStatus', version=2, params=params)
-        params['statues'] = statues
+        _params = dict()
+        msg = dict(type='MetricsDebug', request='SetMeterStatus', version=2, params=_params)
+        _params['statues'] = statues
         reply = await self.rpc(msg)
         return reply
 
@@ -13727,9 +14754,9 @@ class MetricsManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MetricsManager', request='CleanupOldMetrics', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MetricsManager', request='CleanupOldMetrics', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13742,9 +14769,9 @@ class MetricsManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MetricsManager', request='SendMetrics', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MetricsManager', request='SendMetrics', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13807,9 +14834,9 @@ class MigrationFlagFacade(Type):
         Returns -> typing.Sequence<+T_co>[~PhaseResult]<~PhaseResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationFlag', request='Phase', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MigrationFlag', request='Phase', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13822,9 +14849,9 @@ class MigrationFlagFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationFlag', request='Watch', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='MigrationFlag', request='Watch', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -13856,16 +14883,25 @@ class MigrationMasterFacade(Type):
                                                'type': 'object'},
                      'MigrationModelInfo': {'additionalProperties': False,
                                             'properties': {'agent-version': {'$ref': '#/definitions/Number'},
+                                                           'controller-agent-version': {'$ref': '#/definitions/Number'},
                                                            'name': {'type': 'string'},
+                                                           'owner-tag': {'type': 'string'},
                                                            'uuid': {'type': 'string'}},
                                             'required': ['uuid',
                                                          'name',
-                                                         'agent-version'],
+                                                         'owner-tag',
+                                                         'agent-version',
+                                                         'controller-agent-version'],
                                             'type': 'object'},
                      'MigrationSpec': {'additionalProperties': False,
-                                       'properties': {'model-tag': {'type': 'string'},
+                                       'properties': {'external-control': {'type': 'boolean'},
+                                                      'model-tag': {'type': 'string'},
+                                                      'skip-initial-prechecks': {'type': 'boolean'},
                                                       'target-info': {'$ref': '#/definitions/MigrationTargetInfo'}},
-                                       'required': ['model-tag', 'target-info'],
+                                       'required': ['model-tag',
+                                                    'target-info',
+                                                    'external-control',
+                                                    'skip-initial-prechecks'],
                                        'type': 'object'},
                      'MigrationTargetInfo': {'additionalProperties': False,
                                              'properties': {'addrs': {'items': {'type': 'string'},
@@ -13873,7 +14909,7 @@ class MigrationMasterFacade(Type):
                                                             'auth-tag': {'type': 'string'},
                                                             'ca-cert': {'type': 'string'},
                                                             'controller-tag': {'type': 'string'},
-                                                            'macaroon': {'type': 'string'},
+                                                            'macaroons': {'type': 'string'},
                                                             'password': {'type': 'string'}},
                                              'required': ['controller-tag',
                                                           'addrs',
@@ -13918,10 +14954,48 @@ class MigrationMasterFacade(Type):
                                                                   'type': 'array'},
                                                         'charms': {'items': {'type': 'string'},
                                                                    'type': 'array'},
+                                                        'resources': {'items': {'$ref': '#/definitions/SerializedModelResource'},
+                                                                      'type': 'array'},
                                                         'tools': {'items': {'$ref': '#/definitions/SerializedModelTools'},
                                                                   'type': 'array'}},
-                                         'required': ['bytes', 'charms', 'tools'],
+                                         'required': ['bytes',
+                                                      'charms',
+                                                      'tools',
+                                                      'resources'],
                                          'type': 'object'},
+                     'SerializedModelResource': {'additionalProperties': False,
+                                                 'properties': {'application': {'type': 'string'},
+                                                                'application-revision': {'$ref': '#/definitions/SerializedModelResourceRevision'},
+                                                                'charmstore-revision': {'$ref': '#/definitions/SerializedModelResourceRevision'},
+                                                                'name': {'type': 'string'},
+                                                                'unit-revisions': {'patternProperties': {'.*': {'$ref': '#/definitions/SerializedModelResourceRevision'}},
+                                                                                   'type': 'object'}},
+                                                 'required': ['application',
+                                                              'name',
+                                                              'application-revision',
+                                                              'charmstore-revision',
+                                                              'unit-revisions'],
+                                                 'type': 'object'},
+                     'SerializedModelResourceRevision': {'additionalProperties': False,
+                                                         'properties': {'description': {'type': 'string'},
+                                                                        'fingerprint': {'type': 'string'},
+                                                                        'origin': {'type': 'string'},
+                                                                        'path': {'type': 'string'},
+                                                                        'revision': {'type': 'integer'},
+                                                                        'size': {'type': 'integer'},
+                                                                        'timestamp': {'format': 'date-time',
+                                                                                      'type': 'string'},
+                                                                        'type': {'type': 'string'},
+                                                                        'username': {'type': 'string'}},
+                                                         'required': ['revision',
+                                                                      'type',
+                                                                      'path',
+                                                                      'description',
+                                                                      'origin',
+                                                                      'fingerprint',
+                                                                      'size',
+                                                                      'timestamp'],
+                                                         'type': 'object'},
                      'SerializedModelTools': {'additionalProperties': False,
                                               'properties': {'uri': {'type': 'string'},
                                                              'version': {'type': 'string'}},
@@ -13963,8 +15037,8 @@ class MigrationMasterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~SerializedModelTools]<~SerializedModelTools>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationMaster', request='Export', version=1, params=params)
+        _params = dict()
+        msg = dict(type='MigrationMaster', request='Export', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -13978,8 +15052,8 @@ class MigrationMasterFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('MigrationSpec')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationMaster', request='MigrationStatus', version=1, params=params)
+        _params = dict()
+        msg = dict(type='MigrationMaster', request='MigrationStatus', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -13993,8 +15067,8 @@ class MigrationMasterFacade(Type):
         Returns -> typing.Union[typing.Sequence<+T_co>[str], int]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationMaster', request='MinionReports', version=1, params=params)
+        _params = dict()
+        msg = dict(type='MigrationMaster', request='MinionReports', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -14005,11 +15079,11 @@ class MigrationMasterFacade(Type):
     async def ModelInfo(self):
         '''
 
-        Returns -> typing.Union[_ForwardRef('Number'), str]
+        Returns -> typing.Union[_ForwardRef('Number'), _ForwardRef('Number'), str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationMaster', request='ModelInfo', version=1, params=params)
+        _params = dict()
+        msg = dict(type='MigrationMaster', request='ModelInfo', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -14023,8 +15097,8 @@ class MigrationMasterFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationMaster', request='Prechecks', version=1, params=params)
+        _params = dict()
+        msg = dict(type='MigrationMaster', request='Prechecks', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -14038,8 +15112,8 @@ class MigrationMasterFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationMaster', request='Reap', version=1, params=params)
+        _params = dict()
+        msg = dict(type='MigrationMaster', request='Reap', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -14053,9 +15127,9 @@ class MigrationMasterFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationMaster', request='SetPhase', version=1, params=params)
-        params['phase'] = phase
+        _params = dict()
+        msg = dict(type='MigrationMaster', request='SetPhase', version=1, params=_params)
+        _params['phase'] = phase
         reply = await self.rpc(msg)
         return reply
 
@@ -14068,9 +15142,9 @@ class MigrationMasterFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationMaster', request='SetStatusMessage', version=1, params=params)
-        params['message'] = message
+        _params = dict()
+        msg = dict(type='MigrationMaster', request='SetStatusMessage', version=1, params=_params)
+        _params['message'] = message
         reply = await self.rpc(msg)
         return reply
 
@@ -14083,8 +15157,8 @@ class MigrationMasterFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationMaster', request='Watch', version=1, params=params)
+        _params = dict()
+        msg = dict(type='MigrationMaster', request='Watch', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -14098,8 +15172,8 @@ class MigrationMasterFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationMaster', request='WatchMinionReports', version=1, params=params)
+        _params = dict()
+        msg = dict(type='MigrationMaster', request='WatchMinionReports', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -14148,11 +15222,11 @@ class MigrationMinionFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationMinion', request='Report', version=1, params=params)
-        params['migration-id'] = migration_id
-        params['phase'] = phase
-        params['success'] = success
+        _params = dict()
+        msg = dict(type='MigrationMinion', request='Report', version=1, params=_params)
+        _params['migration-id'] = migration_id
+        _params['phase'] = phase
+        _params['success'] = success
         reply = await self.rpc(msg)
         return reply
 
@@ -14165,8 +15239,8 @@ class MigrationMinionFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationMinion', request='Watch', version=1, params=params)
+        _params = dict()
+        msg = dict(type='MigrationMinion', request='Watch', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -14177,6 +15251,7 @@ class MigrationStatusWatcherFacade(Type):
     version = 1
     schema =     {'definitions': {'MigrationStatus': {'additionalProperties': False,
                                          'properties': {'attempt': {'type': 'integer'},
+                                                        'external-control': {'type': 'boolean'},
                                                         'migration-id': {'type': 'string'},
                                                         'phase': {'type': 'string'},
                                                         'source-api-addrs': {'items': {'type': 'string'},
@@ -14188,6 +15263,7 @@ class MigrationStatusWatcherFacade(Type):
                                          'required': ['migration-id',
                                                       'attempt',
                                                       'phase',
+                                                      'external-control',
                                                       'source-api-addrs',
                                                       'source-ca-cert',
                                                       'target-api-addrs',
@@ -14206,8 +15282,8 @@ class MigrationStatusWatcherFacade(Type):
         Returns -> typing.Union[int, typing.Sequence<+T_co>[str]]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationStatusWatcher', request='Next', version=1, params=params)
+        _params = dict()
+        msg = dict(type='MigrationStatusWatcher', request='Next', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -14221,8 +15297,8 @@ class MigrationStatusWatcherFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationStatusWatcher', request='Stop', version=1, params=params)
+        _params = dict()
+        msg = dict(type='MigrationStatusWatcher', request='Stop', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -14231,7 +15307,25 @@ class MigrationStatusWatcherFacade(Type):
 class MigrationTargetFacade(Type):
     name = 'MigrationTarget'
     version = 1
-    schema =     {'definitions': {'ModelArgs': {'additionalProperties': False,
+    schema =     {'definitions': {'AdoptResourcesArgs': {'additionalProperties': False,
+                                            'properties': {'model-tag': {'type': 'string'},
+                                                           'source-controller-version': {'$ref': '#/definitions/Number'}},
+                                            'required': ['model-tag',
+                                                         'source-controller-version'],
+                                            'type': 'object'},
+                     'MigrationModelInfo': {'additionalProperties': False,
+                                            'properties': {'agent-version': {'$ref': '#/definitions/Number'},
+                                                           'controller-agent-version': {'$ref': '#/definitions/Number'},
+                                                           'name': {'type': 'string'},
+                                                           'owner-tag': {'type': 'string'},
+                                                           'uuid': {'type': 'string'}},
+                                            'required': ['uuid',
+                                                         'name',
+                                                         'owner-tag',
+                                                         'agent-version',
+                                                         'controller-agent-version'],
+                                            'type': 'object'},
+                     'ModelArgs': {'additionalProperties': False,
                                    'properties': {'model-tag': {'type': 'string'}},
                                    'required': ['model-tag'],
                                    'type': 'object'},
@@ -14252,26 +15346,66 @@ class MigrationTargetFacade(Type):
                                                                   'type': 'array'},
                                                         'charms': {'items': {'type': 'string'},
                                                                    'type': 'array'},
+                                                        'resources': {'items': {'$ref': '#/definitions/SerializedModelResource'},
+                                                                      'type': 'array'},
                                                         'tools': {'items': {'$ref': '#/definitions/SerializedModelTools'},
                                                                   'type': 'array'}},
-                                         'required': ['bytes', 'charms', 'tools'],
+                                         'required': ['bytes',
+                                                      'charms',
+                                                      'tools',
+                                                      'resources'],
                                          'type': 'object'},
+                     'SerializedModelResource': {'additionalProperties': False,
+                                                 'properties': {'application': {'type': 'string'},
+                                                                'application-revision': {'$ref': '#/definitions/SerializedModelResourceRevision'},
+                                                                'charmstore-revision': {'$ref': '#/definitions/SerializedModelResourceRevision'},
+                                                                'name': {'type': 'string'},
+                                                                'unit-revisions': {'patternProperties': {'.*': {'$ref': '#/definitions/SerializedModelResourceRevision'}},
+                                                                                   'type': 'object'}},
+                                                 'required': ['application',
+                                                              'name',
+                                                              'application-revision',
+                                                              'charmstore-revision',
+                                                              'unit-revisions'],
+                                                 'type': 'object'},
+                     'SerializedModelResourceRevision': {'additionalProperties': False,
+                                                         'properties': {'description': {'type': 'string'},
+                                                                        'fingerprint': {'type': 'string'},
+                                                                        'origin': {'type': 'string'},
+                                                                        'path': {'type': 'string'},
+                                                                        'revision': {'type': 'integer'},
+                                                                        'size': {'type': 'integer'},
+                                                                        'timestamp': {'format': 'date-time',
+                                                                                      'type': 'string'},
+                                                                        'type': {'type': 'string'},
+                                                                        'username': {'type': 'string'}},
+                                                         'required': ['revision',
+                                                                      'type',
+                                                                      'path',
+                                                                      'description',
+                                                                      'origin',
+                                                                      'fingerprint',
+                                                                      'size',
+                                                                      'timestamp'],
+                                                         'type': 'object'},
                      'SerializedModelTools': {'additionalProperties': False,
                                               'properties': {'uri': {'type': 'string'},
                                                              'version': {'type': 'string'}},
                                               'required': ['version', 'uri'],
-                                              'type': 'object'},
-                     'TargetPrechecksArgs': {'additionalProperties': False,
-                                             'properties': {'agent-version': {'$ref': '#/definitions/Number'}},
-                                             'required': ['agent-version'],
-                                             'type': 'object'}},
+                                              'type': 'object'}},
      'properties': {'Abort': {'properties': {'Params': {'$ref': '#/definitions/ModelArgs'}},
                               'type': 'object'},
                     'Activate': {'properties': {'Params': {'$ref': '#/definitions/ModelArgs'}},
                                  'type': 'object'},
+                    'AdoptResources': {'properties': {'Params': {'$ref': '#/definitions/AdoptResourcesArgs'}},
+                                       'type': 'object'},
                     'Import': {'properties': {'Params': {'$ref': '#/definitions/SerializedModel'}},
                                'type': 'object'},
-                    'Prechecks': {'properties': {'Params': {'$ref': '#/definitions/TargetPrechecksArgs'}},
+                    'LatestLogTime': {'properties': {'Params': {'$ref': '#/definitions/ModelArgs'},
+                                                     'Result': {'format': 'date-time',
+                                                                'type': 'string'}},
+                                      'type': 'object'},
+                    'Prechecks': {'properties': {'Params': {'$ref': '#/definitions/MigrationModelInfo'}},
                                   'type': 'object'}},
      'type': 'object'}
     
@@ -14283,9 +15417,9 @@ class MigrationTargetFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationTarget', request='Abort', version=1, params=params)
-        params['model-tag'] = model_tag
+        _params = dict()
+        msg = dict(type='MigrationTarget', request='Abort', version=1, params=_params)
+        _params['model-tag'] = model_tag
         reply = await self.rpc(msg)
         return reply
 
@@ -14298,51 +15432,85 @@ class MigrationTargetFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationTarget', request='Activate', version=1, params=params)
-        params['model-tag'] = model_tag
+        _params = dict()
+        msg = dict(type='MigrationTarget', request='Activate', version=1, params=_params)
+        _params['model-tag'] = model_tag
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(None)
+    async def AdoptResources(self, model_tag, source_controller_version):
+        '''
+        model_tag : str
+        source_controller_version : Number
+        Returns -> None
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='MigrationTarget', request='AdoptResources', version=1, params=_params)
+        _params['model-tag'] = model_tag
+        _params['source-controller-version'] = source_controller_version
         reply = await self.rpc(msg)
         return reply
 
 
 
     @ReturnMapping(None)
-    async def Import(self, bytes_, charms, tools):
+    async def Import(self, bytes_, charms, resources, tools):
         '''
         bytes_ : typing.Sequence<+T_co>[int]
         charms : typing.Sequence<+T_co>[str]
+        resources : typing.Sequence<+T_co>[~SerializedModelResource]<~SerializedModelResource>
         tools : typing.Sequence<+T_co>[~SerializedModelTools]<~SerializedModelTools>
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationTarget', request='Import', version=1, params=params)
-        params['bytes'] = bytes_
-        params['charms'] = charms
-        params['tools'] = tools
+        _params = dict()
+        msg = dict(type='MigrationTarget', request='Import', version=1, params=_params)
+        _params['bytes'] = bytes_
+        _params['charms'] = charms
+        _params['resources'] = resources
+        _params['tools'] = tools
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(str)
+    async def LatestLogTime(self, model_tag):
+        '''
+        model_tag : str
+        Returns -> str
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='MigrationTarget', request='LatestLogTime', version=1, params=_params)
+        _params['model-tag'] = model_tag
         reply = await self.rpc(msg)
         return reply
 
 
 
     @ReturnMapping(None)
-    async def Prechecks(self, build, major, minor, patch, tag):
+    async def Prechecks(self, agent_version, controller_agent_version, name, owner_tag, uuid):
         '''
-        build : int
-        major : int
-        minor : int
-        patch : int
-        tag : str
+        agent_version : Number
+        controller_agent_version : Number
+        name : str
+        owner_tag : str
+        uuid : str
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='MigrationTarget', request='Prechecks', version=1, params=params)
-        params['Build'] = build
-        params['Major'] = major
-        params['Minor'] = minor
-        params['Patch'] = patch
-        params['Tag'] = tag
+        _params = dict()
+        msg = dict(type='MigrationTarget', request='Prechecks', version=1, params=_params)
+        _params['agent-version'] = agent_version
+        _params['controller-agent-version'] = controller_agent_version
+        _params['name'] = name
+        _params['owner-tag'] = owner_tag
+        _params['uuid'] = uuid
         reply = await self.rpc(msg)
         return reply
 
@@ -14356,51 +15524,11 @@ class ModelConfigFacade(Type):
                                                               'type': 'object'}},
                                      'required': ['value', 'source'],
                                      'type': 'object'},
-                     'Error': {'additionalProperties': False,
-                               'properties': {'code': {'type': 'string'},
-                                              'info': {'$ref': '#/definitions/ErrorInfo'},
-                                              'message': {'type': 'string'}},
-                               'required': ['message', 'code'],
-                               'type': 'object'},
-                     'ErrorInfo': {'additionalProperties': False,
-                                   'properties': {'macaroon': {'$ref': '#/definitions/Macaroon'},
-                                                  'macaroon-path': {'type': 'string'}},
-                                   'type': 'object'},
-                     'ErrorResult': {'additionalProperties': False,
-                                     'properties': {'error': {'$ref': '#/definitions/Error'}},
-                                     'type': 'object'},
-                     'ErrorResults': {'additionalProperties': False,
-                                      'properties': {'results': {'items': {'$ref': '#/definitions/ErrorResult'},
-                                                                 'type': 'array'}},
-                                      'required': ['results'],
-                                      'type': 'object'},
-                     'Macaroon': {'additionalProperties': False, 'type': 'object'},
                      'ModelConfigResults': {'additionalProperties': False,
                                             'properties': {'config': {'patternProperties': {'.*': {'$ref': '#/definitions/ConfigValue'}},
                                                                       'type': 'object'}},
                                             'required': ['config'],
                                             'type': 'object'},
-                     'ModelDefaultValues': {'additionalProperties': False,
-                                            'properties': {'cloud-region': {'type': 'string'},
-                                                           'cloud-tag': {'type': 'string'},
-                                                           'config': {'patternProperties': {'.*': {'additionalProperties': True,
-                                                                                                   'type': 'object'}},
-                                                                      'type': 'object'}},
-                                            'required': ['config'],
-                                            'type': 'object'},
-                     'ModelDefaults': {'additionalProperties': False,
-                                       'properties': {'controller': {'additionalProperties': True,
-                                                                     'type': 'object'},
-                                                      'default': {'additionalProperties': True,
-                                                                  'type': 'object'},
-                                                      'regions': {'items': {'$ref': '#/definitions/RegionDefaults'},
-                                                                  'type': 'array'}},
-                                       'type': 'object'},
-                     'ModelDefaultsResult': {'additionalProperties': False,
-                                             'properties': {'config': {'patternProperties': {'.*': {'$ref': '#/definitions/ModelDefaults'}},
-                                                                       'type': 'object'}},
-                                             'required': ['config'],
-                                             'type': 'object'},
                      'ModelSet': {'additionalProperties': False,
                                   'properties': {'config': {'patternProperties': {'.*': {'additionalProperties': True,
                                                                                          'type': 'object'}},
@@ -14411,62 +15539,16 @@ class ModelConfigFacade(Type):
                                     'properties': {'keys': {'items': {'type': 'string'},
                                                             'type': 'array'}},
                                     'required': ['keys'],
-                                    'type': 'object'},
-                     'ModelUnsetKeys': {'additionalProperties': False,
-                                        'properties': {'cloud-region': {'type': 'string'},
-                                                       'cloud-tag': {'type': 'string'},
-                                                       'keys': {'items': {'type': 'string'},
-                                                                'type': 'array'}},
-                                        'required': ['keys'],
-                                        'type': 'object'},
-                     'RegionDefaults': {'additionalProperties': False,
-                                        'properties': {'region-name': {'type': 'string'},
-                                                       'value': {'additionalProperties': True,
-                                                                 'type': 'object'}},
-                                        'required': ['region-name', 'value'],
-                                        'type': 'object'},
-                     'SetModelDefaults': {'additionalProperties': False,
-                                          'properties': {'config': {'items': {'$ref': '#/definitions/ModelDefaultValues'},
-                                                                    'type': 'array'}},
-                                          'required': ['config'],
-                                          'type': 'object'},
-                     'UnsetModelDefaults': {'additionalProperties': False,
-                                            'properties': {'keys': {'items': {'$ref': '#/definitions/ModelUnsetKeys'},
-                                                                    'type': 'array'}},
-                                            'required': ['keys'],
-                                            'type': 'object'}},
-     'properties': {'ModelDefaults': {'properties': {'Result': {'$ref': '#/definitions/ModelDefaultsResult'}},
-                                      'type': 'object'},
-                    'ModelGet': {'properties': {'Result': {'$ref': '#/definitions/ModelConfigResults'}},
+                                    'type': 'object'}},
+     'properties': {'ModelGet': {'properties': {'Result': {'$ref': '#/definitions/ModelConfigResults'}},
                                  'type': 'object'},
                     'ModelSet': {'properties': {'Params': {'$ref': '#/definitions/ModelSet'}},
                                  'type': 'object'},
                     'ModelUnset': {'properties': {'Params': {'$ref': '#/definitions/ModelUnset'}},
-                                   'type': 'object'},
-                    'SetModelDefaults': {'properties': {'Params': {'$ref': '#/definitions/SetModelDefaults'},
-                                                        'Result': {'$ref': '#/definitions/ErrorResults'}},
-                                         'type': 'object'},
-                    'UnsetModelDefaults': {'properties': {'Params': {'$ref': '#/definitions/UnsetModelDefaults'},
-                                                          'Result': {'$ref': '#/definitions/ErrorResults'}},
-                                           'type': 'object'}},
+                                   'type': 'object'}},
      'type': 'object'}
     
 
-    @ReturnMapping(ModelDefaultsResult)
-    async def ModelDefaults(self):
-        '''
-
-        Returns -> typing.Mapping<~KT, +VT_co>[str, ~ModelDefaults]<~ModelDefaults>
-        '''
-        # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelConfig', request='ModelDefaults', version=1, params=params)
-
-        reply = await self.rpc(msg)
-        return reply
-
-
-
     @ReturnMapping(ModelConfigResults)
     async def ModelGet(self):
         '''
@@ -14474,8 +15556,8 @@ class ModelConfigFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, ~ConfigValue]<~ConfigValue>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelConfig', request='ModelGet', version=1, params=params)
+        _params = dict()
+        msg = dict(type='ModelConfig', request='ModelGet', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -14489,9 +15571,9 @@ class ModelConfigFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelConfig', request='ModelSet', version=1, params=params)
-        params['config'] = config
+        _params = dict()
+        msg = dict(type='ModelConfig', request='ModelSet', version=1, params=_params)
+        _params['config'] = config
         reply = await self.rpc(msg)
         return reply
 
@@ -14504,39 +15586,9 @@ class ModelConfigFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelConfig', request='ModelUnset', version=1, params=params)
-        params['keys'] = keys
-        reply = await self.rpc(msg)
-        return reply
-
-
-
-    @ReturnMapping(ErrorResults)
-    async def SetModelDefaults(self, config):
-        '''
-        config : typing.Sequence<+T_co>[~ModelDefaultValues]<~ModelDefaultValues>
-        Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
-        '''
-        # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelConfig', request='SetModelDefaults', version=1, params=params)
-        params['config'] = config
-        reply = await self.rpc(msg)
-        return reply
-
-
-
-    @ReturnMapping(ErrorResults)
-    async def UnsetModelDefaults(self, keys):
-        '''
-        keys : typing.Sequence<+T_co>[~ModelUnsetKeys]<~ModelUnsetKeys>
-        Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
-        '''
-        # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelConfig', request='UnsetModelDefaults', version=1, params=params)
-        params['keys'] = keys
+        _params = dict()
+        msg = dict(type='ModelConfig', request='ModelUnset', version=1, params=_params)
+        _params['keys'] = keys
         reply = await self.rpc(msg)
         return reply
 
@@ -14582,6 +15634,16 @@ class ModelManagerFacade(Type):
                                       'required': ['results'],
                                       'type': 'object'},
                      'Macaroon': {'additionalProperties': False, 'type': 'object'},
+                     'MachineHardware': {'additionalProperties': False,
+                                         'properties': {'arch': {'type': 'string'},
+                                                        'availability-zone': {'type': 'string'},
+                                                        'cores': {'type': 'integer'},
+                                                        'cpu-power': {'type': 'integer'},
+                                                        'mem': {'type': 'integer'},
+                                                        'root-disk': {'type': 'integer'},
+                                                        'tags': {'items': {'type': 'string'},
+                                                                 'type': 'array'}},
+                                         'type': 'object'},
                      'MapResult': {'additionalProperties': False,
                                    'properties': {'error': {'$ref': '#/definitions/Error'},
                                                   'result': {'patternProperties': {'.*': {'additionalProperties': True,
@@ -14611,13 +15673,37 @@ class ModelManagerFacade(Type):
                                                         'region': {'type': 'string'}},
                                          'required': ['name', 'owner-tag'],
                                          'type': 'object'},
+                     'ModelDefaultValues': {'additionalProperties': False,
+                                            'properties': {'cloud-region': {'type': 'string'},
+                                                           'cloud-tag': {'type': 'string'},
+                                                           'config': {'patternProperties': {'.*': {'additionalProperties': True,
+                                                                                                   'type': 'object'}},
+                                                                      'type': 'object'}},
+                                            'required': ['config'],
+                                            'type': 'object'},
+                     'ModelDefaults': {'additionalProperties': False,
+                                       'properties': {'controller': {'additionalProperties': True,
+                                                                     'type': 'object'},
+                                                      'default': {'additionalProperties': True,
+                                                                  'type': 'object'},
+                                                      'regions': {'items': {'$ref': '#/definitions/RegionDefaults'},
+                                                                  'type': 'array'}},
+                                       'type': 'object'},
+                     'ModelDefaultsResult': {'additionalProperties': False,
+                                             'properties': {'config': {'patternProperties': {'.*': {'$ref': '#/definitions/ModelDefaults'}},
+                                                                       'type': 'object'}},
+                                             'required': ['config'],
+                                             'type': 'object'},
                      'ModelInfo': {'additionalProperties': False,
-                                   'properties': {'cloud': {'type': 'string'},
-                                                  'cloud-credential-tag': {'type': 'string'},
+                                   'properties': {'cloud-credential-tag': {'type': 'string'},
                                                   'cloud-region': {'type': 'string'},
+                                                  'cloud-tag': {'type': 'string'},
                                                   'controller-uuid': {'type': 'string'},
                                                   'default-series': {'type': 'string'},
                                                   'life': {'type': 'string'},
+                                                  'machines': {'items': {'$ref': '#/definitions/ModelMachineInfo'},
+                                                               'type': 'array'},
+                                                  'migration': {'$ref': '#/definitions/ModelMigrationStatus'},
                                                   'name': {'type': 'string'},
                                                   'owner-tag': {'type': 'string'},
                                                   'provider-type': {'type': 'string'},
@@ -14630,11 +15716,12 @@ class ModelManagerFacade(Type):
                                                 'controller-uuid',
                                                 'provider-type',
                                                 'default-series',
-                                                'cloud',
+                                                'cloud-tag',
                                                 'owner-tag',
                                                 'life',
                                                 'status',
-                                                'users'],
+                                                'users',
+                                                'machines'],
                                    'type': 'object'},
                      'ModelInfoResult': {'additionalProperties': False,
                                          'properties': {'error': {'$ref': '#/definitions/Error'},
@@ -14645,6 +15732,49 @@ class ModelManagerFacade(Type):
                                                                      'type': 'array'}},
                                           'required': ['results'],
                                           'type': 'object'},
+                     'ModelMachineInfo': {'additionalProperties': False,
+                                          'properties': {'hardware': {'$ref': '#/definitions/MachineHardware'},
+                                                         'has-vote': {'type': 'boolean'},
+                                                         'id': {'type': 'string'},
+                                                         'instance-id': {'type': 'string'},
+                                                         'status': {'type': 'string'},
+                                                         'wants-vote': {'type': 'boolean'}},
+                                          'required': ['id'],
+                                          'type': 'object'},
+                     'ModelMigrationStatus': {'additionalProperties': False,
+                                              'properties': {'end': {'format': 'date-time',
+                                                                     'type': 'string'},
+                                                             'start': {'format': 'date-time',
+                                                                       'type': 'string'},
+                                                             'status': {'type': 'string'}},
+                                              'required': ['status', 'start'],
+                                              'type': 'object'},
+                     'ModelStatus': {'additionalProperties': False,
+                                     'properties': {'application-count': {'type': 'integer'},
+                                                    'hosted-machine-count': {'type': 'integer'},
+                                                    'life': {'type': 'string'},
+                                                    'machines': {'items': {'$ref': '#/definitions/ModelMachineInfo'},
+                                                                 'type': 'array'},
+                                                    'model-tag': {'type': 'string'},
+                                                    'owner-tag': {'type': 'string'}},
+                                     'required': ['model-tag',
+                                                  'life',
+                                                  'hosted-machine-count',
+                                                  'application-count',
+                                                  'owner-tag'],
+                                     'type': 'object'},
+                     'ModelStatusResults': {'additionalProperties': False,
+                                            'properties': {'models': {'items': {'$ref': '#/definitions/ModelStatus'},
+                                                                      'type': 'array'}},
+                                            'required': ['models'],
+                                            'type': 'object'},
+                     'ModelUnsetKeys': {'additionalProperties': False,
+                                        'properties': {'cloud-region': {'type': 'string'},
+                                                       'cloud-tag': {'type': 'string'},
+                                                       'keys': {'items': {'type': 'string'},
+                                                                'type': 'array'}},
+                                        'required': ['keys'],
+                                        'type': 'object'},
                      'ModelUserInfo': {'additionalProperties': False,
                                        'properties': {'access': {'type': 'string'},
                                                       'display-name': {'type': 'string'},
@@ -14671,6 +15801,22 @@ class ModelManagerFacade(Type):
                                                                              'type': 'array'}},
                                                   'required': ['changes'],
                                                   'type': 'object'},
+                     'RegionDefaults': {'additionalProperties': False,
+                                        'properties': {'region-name': {'type': 'string'},
+                                                       'value': {'additionalProperties': True,
+                                                                 'type': 'object'}},
+                                        'required': ['region-name', 'value'],
+                                        'type': 'object'},
+                     'SetModelDefaults': {'additionalProperties': False,
+                                          'properties': {'config': {'items': {'$ref': '#/definitions/ModelDefaultValues'},
+                                                                    'type': 'array'}},
+                                          'required': ['config'],
+                                          'type': 'object'},
+                     'UnsetModelDefaults': {'additionalProperties': False,
+                                            'properties': {'keys': {'items': {'$ref': '#/definitions/ModelUnsetKeys'},
+                                                                    'type': 'array'}},
+                                            'required': ['keys'],
+                                            'type': 'object'},
                      'UserModel': {'additionalProperties': False,
                                    'properties': {'last-connection': {'format': 'date-time',
                                                                       'type': 'string'},
@@ -14685,7 +15831,6 @@ class ModelManagerFacade(Type):
      'properties': {'CreateModel': {'properties': {'Params': {'$ref': '#/definitions/ModelCreateArgs'},
                                                    'Result': {'$ref': '#/definitions/ModelInfo'}},
                                     'type': 'object'},
-                    'DestroyModel': {'type': 'object'},
                     'DestroyModels': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
                                                      'Result': {'$ref': '#/definitions/ErrorResults'}},
                                       'type': 'object'},
@@ -14698,12 +15843,23 @@ class ModelManagerFacade(Type):
                     'ListModels': {'properties': {'Params': {'$ref': '#/definitions/Entity'},
                                                   'Result': {'$ref': '#/definitions/UserModelList'}},
                                    'type': 'object'},
+                    'ModelDefaults': {'properties': {'Result': {'$ref': '#/definitions/ModelDefaultsResult'}},
+                                      'type': 'object'},
                     'ModelInfo': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
                                                  'Result': {'$ref': '#/definitions/ModelInfoResults'}},
                                   'type': 'object'},
+                    'ModelStatus': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
+                                                   'Result': {'$ref': '#/definitions/ModelStatusResults'}},
+                                    'type': 'object'},
                     'ModifyModelAccess': {'properties': {'Params': {'$ref': '#/definitions/ModifyModelAccessRequest'},
                                                          'Result': {'$ref': '#/definitions/ErrorResults'}},
-                                          'type': 'object'}},
+                                          'type': 'object'},
+                    'SetModelDefaults': {'properties': {'Params': {'$ref': '#/definitions/SetModelDefaults'},
+                                                        'Result': {'$ref': '#/definitions/ErrorResults'}},
+                                         'type': 'object'},
+                    'UnsetModelDefaults': {'properties': {'Params': {'$ref': '#/definitions/UnsetModelDefaults'},
+                                                          'Result': {'$ref': '#/definitions/ErrorResults'}},
+                                           'type': 'object'}},
      'type': 'object'}
     
 
@@ -14716,32 +15872,17 @@ class ModelManagerFacade(Type):
         name : str
         owner_tag : str
         region : str
-        Returns -> typing.Union[_ForwardRef('EntityStatus'), typing.Sequence<+T_co>[~ModelUserInfo]<~ModelUserInfo>]
-        '''
-        # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelManager', request='CreateModel', version=2, params=params)
-        params['cloud-tag'] = cloud_tag
-        params['config'] = config
-        params['credential'] = credential
-        params['name'] = name
-        params['owner-tag'] = owner_tag
-        params['region'] = region
-        reply = await self.rpc(msg)
-        return reply
-
-
-
-    @ReturnMapping(None)
-    async def DestroyModel(self):
-        '''
-
-        Returns -> None
+        Returns -> typing.Union[_ForwardRef('ModelMigrationStatus'), _ForwardRef('EntityStatus'), typing.Sequence<+T_co>[~ModelUserInfo]<~ModelUserInfo>]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelManager', request='DestroyModel', version=2, params=params)
-
+        _params = dict()
+        msg = dict(type='ModelManager', request='CreateModel', version=2, params=_params)
+        _params['cloud-tag'] = cloud_tag
+        _params['config'] = config
+        _params['credential'] = credential
+        _params['name'] = name
+        _params['owner-tag'] = owner_tag
+        _params['region'] = region
         reply = await self.rpc(msg)
         return reply
 
@@ -14754,9 +15895,9 @@ class ModelManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelManager', request='DestroyModels', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='ModelManager', request='DestroyModels', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -14769,9 +15910,9 @@ class ModelManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~MapResult]<~MapResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelManager', request='DumpModels', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='ModelManager', request='DumpModels', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -14784,9 +15925,9 @@ class ModelManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~MapResult]<~MapResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelManager', request='DumpModelsDB', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='ModelManager', request='DumpModelsDB', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -14799,9 +15940,24 @@ class ModelManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~UserModel]<~UserModel>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelManager', request='ListModels', version=2, params=params)
-        params['tag'] = tag
+        _params = dict()
+        msg = dict(type='ModelManager', request='ListModels', version=2, params=_params)
+        _params['tag'] = tag
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(ModelDefaultsResult)
+    async def ModelDefaults(self):
+        '''
+
+        Returns -> typing.Mapping<~KT, +VT_co>[str, ~ModelDefaults]<~ModelDefaults>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='ModelManager', request='ModelDefaults', version=2, params=_params)
+
         reply = await self.rpc(msg)
         return reply
 
@@ -14814,9 +15970,24 @@ class ModelManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ModelInfoResult]<~ModelInfoResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelManager', request='ModelInfo', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='ModelManager', request='ModelInfo', version=2, params=_params)
+        _params['entities'] = entities
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(ModelStatusResults)
+    async def ModelStatus(self, entities):
+        '''
+        entities : typing.Sequence<+T_co>[~Entity]<~Entity>
+        Returns -> typing.Sequence<+T_co>[~ModelStatus]<~ModelStatus>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='ModelManager', request='ModelStatus', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -14829,9 +16000,39 @@ class ModelManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ModelManager', request='ModifyModelAccess', version=2, params=params)
-        params['changes'] = changes
+        _params = dict()
+        msg = dict(type='ModelManager', request='ModifyModelAccess', version=2, params=_params)
+        _params['changes'] = changes
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(ErrorResults)
+    async def SetModelDefaults(self, config):
+        '''
+        config : typing.Sequence<+T_co>[~ModelDefaultValues]<~ModelDefaultValues>
+        Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='ModelManager', request='SetModelDefaults', version=2, params=_params)
+        _params['config'] = config
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(ErrorResults)
+    async def UnsetModelDefaults(self, keys):
+        '''
+        keys : typing.Sequence<+T_co>[~ModelUnsetKeys]<~ModelUnsetKeys>
+        Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='ModelManager', request='UnsetModelDefaults', version=2, params=_params)
+        _params['keys'] = keys
         reply = await self.rpc(msg)
         return reply
 
@@ -14850,8 +16051,8 @@ class NotifyWatcherFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='NotifyWatcher', request='Next', version=1, params=params)
+        _params = dict()
+        msg = dict(type='NotifyWatcher', request='Next', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -14865,9 +16066,230 @@ class NotifyWatcherFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='NotifyWatcher', request='Stop', version=1, params=params)
+        _params = dict()
+        msg = dict(type='NotifyWatcher', request='Stop', version=1, params=_params)
+
+        reply = await self.rpc(msg)
+        return reply
+
+
+class PayloadsFacade(Type):
+    name = 'Payloads'
+    version = 1
+    schema =     {'definitions': {'EnvListArgs': {'additionalProperties': False,
+                                     'properties': {'patterns': {'items': {'type': 'string'},
+                                                                 'type': 'array'}},
+                                     'required': ['patterns'],
+                                     'type': 'object'},
+                     'EnvListResults': {'additionalProperties': False,
+                                        'properties': {'results': {'items': {'$ref': '#/definitions/Payload'},
+                                                                   'type': 'array'}},
+                                        'required': ['results'],
+                                        'type': 'object'},
+                     'Payload': {'additionalProperties': False,
+                                 'properties': {'class': {'type': 'string'},
+                                                'id': {'type': 'string'},
+                                                'labels': {'items': {'type': 'string'},
+                                                           'type': 'array'},
+                                                'machine': {'type': 'string'},
+                                                'status': {'type': 'string'},
+                                                'type': {'type': 'string'},
+                                                'unit': {'type': 'string'}},
+                                 'required': ['class',
+                                              'type',
+                                              'id',
+                                              'status',
+                                              'labels',
+                                              'unit',
+                                              'machine'],
+                                 'type': 'object'}},
+     'properties': {'List': {'properties': {'Params': {'$ref': '#/definitions/EnvListArgs'},
+                                            'Result': {'$ref': '#/definitions/EnvListResults'}},
+                             'type': 'object'}},
+     'type': 'object'}
+    
+
+    @ReturnMapping(EnvListResults)
+    async def List(self, patterns):
+        '''
+        patterns : typing.Sequence<+T_co>[str]
+        Returns -> typing.Sequence<+T_co>[~Payload]<~Payload>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Payloads', request='List', version=1, params=_params)
+        _params['patterns'] = patterns
+        reply = await self.rpc(msg)
+        return reply
+
+
+class PayloadsHookContextFacade(Type):
+    name = 'PayloadsHookContext'
+    version = 1
+    schema =     {'definitions': {'Entities': {'additionalProperties': False,
+                                  'properties': {'entities': {'items': {'$ref': '#/definitions/Entity'},
+                                                              'type': 'array'}},
+                                  'required': ['entities'],
+                                  'type': 'object'},
+                     'Entity': {'additionalProperties': False,
+                                'properties': {'tag': {'type': 'string'}},
+                                'required': ['tag'],
+                                'type': 'object'},
+                     'Error': {'additionalProperties': False,
+                               'properties': {'code': {'type': 'string'},
+                                              'info': {'$ref': '#/definitions/ErrorInfo'},
+                                              'message': {'type': 'string'}},
+                               'required': ['message', 'code'],
+                               'type': 'object'},
+                     'ErrorInfo': {'additionalProperties': False,
+                                   'properties': {'macaroon': {'$ref': '#/definitions/Macaroon'},
+                                                  'macaroon-path': {'type': 'string'}},
+                                   'type': 'object'},
+                     'LookUpArg': {'additionalProperties': False,
+                                   'properties': {'id': {'type': 'string'},
+                                                  'name': {'type': 'string'}},
+                                   'required': ['name', 'id'],
+                                   'type': 'object'},
+                     'LookUpArgs': {'additionalProperties': False,
+                                    'properties': {'args': {'items': {'$ref': '#/definitions/LookUpArg'},
+                                                            'type': 'array'}},
+                                    'required': ['args'],
+                                    'type': 'object'},
+                     'Macaroon': {'additionalProperties': False, 'type': 'object'},
+                     'Payload': {'additionalProperties': False,
+                                 'properties': {'class': {'type': 'string'},
+                                                'id': {'type': 'string'},
+                                                'labels': {'items': {'type': 'string'},
+                                                           'type': 'array'},
+                                                'machine': {'type': 'string'},
+                                                'status': {'type': 'string'},
+                                                'type': {'type': 'string'},
+                                                'unit': {'type': 'string'}},
+                                 'required': ['class',
+                                              'type',
+                                              'id',
+                                              'status',
+                                              'labels',
+                                              'unit',
+                                              'machine'],
+                                 'type': 'object'},
+                     'PayloadResult': {'additionalProperties': False,
+                                       'properties': {'Entity': {'$ref': '#/definitions/Entity'},
+                                                      'error': {'$ref': '#/definitions/Error'},
+                                                      'not-found': {'type': 'boolean'},
+                                                      'payload': {'$ref': '#/definitions/Payload'}},
+                                       'required': ['Entity',
+                                                    'payload',
+                                                    'not-found'],
+                                       'type': 'object'},
+                     'PayloadResults': {'additionalProperties': False,
+                                        'properties': {'results': {'items': {'$ref': '#/definitions/PayloadResult'},
+                                                                   'type': 'array'}},
+                                        'required': ['results'],
+                                        'type': 'object'},
+                     'SetStatusArg': {'additionalProperties': False,
+                                      'properties': {'Entity': {'$ref': '#/definitions/Entity'},
+                                                     'status': {'type': 'string'}},
+                                      'required': ['Entity', 'status'],
+                                      'type': 'object'},
+                     'SetStatusArgs': {'additionalProperties': False,
+                                       'properties': {'args': {'items': {'$ref': '#/definitions/SetStatusArg'},
+                                                               'type': 'array'}},
+                                       'required': ['args'],
+                                       'type': 'object'},
+                     'TrackArgs': {'additionalProperties': False,
+                                   'properties': {'payloads': {'items': {'$ref': '#/definitions/Payload'},
+                                                               'type': 'array'}},
+                                   'required': ['payloads'],
+                                   'type': 'object'}},
+     'properties': {'List': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
+                                            'Result': {'$ref': '#/definitions/PayloadResults'}},
+                             'type': 'object'},
+                    'LookUp': {'properties': {'Params': {'$ref': '#/definitions/LookUpArgs'},
+                                              'Result': {'$ref': '#/definitions/PayloadResults'}},
+                               'type': 'object'},
+                    'SetStatus': {'properties': {'Params': {'$ref': '#/definitions/SetStatusArgs'},
+                                                 'Result': {'$ref': '#/definitions/PayloadResults'}},
+                                  'type': 'object'},
+                    'Track': {'properties': {'Params': {'$ref': '#/definitions/TrackArgs'},
+                                             'Result': {'$ref': '#/definitions/PayloadResults'}},
+                              'type': 'object'},
+                    'Untrack': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
+                                               'Result': {'$ref': '#/definitions/PayloadResults'}},
+                                'type': 'object'}},
+     'type': 'object'}
+    
+
+    @ReturnMapping(PayloadResults)
+    async def List(self, entities):
+        '''
+        entities : typing.Sequence<+T_co>[~Entity]<~Entity>
+        Returns -> typing.Sequence<+T_co>[~PayloadResult]<~PayloadResult>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='PayloadsHookContext', request='List', version=1, params=_params)
+        _params['entities'] = entities
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(PayloadResults)
+    async def LookUp(self, args):
+        '''
+        args : typing.Sequence<+T_co>[~LookUpArg]<~LookUpArg>
+        Returns -> typing.Sequence<+T_co>[~PayloadResult]<~PayloadResult>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='PayloadsHookContext', request='LookUp', version=1, params=_params)
+        _params['args'] = args
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(PayloadResults)
+    async def SetStatus(self, args):
+        '''
+        args : typing.Sequence<+T_co>[~SetStatusArg]<~SetStatusArg>
+        Returns -> typing.Sequence<+T_co>[~PayloadResult]<~PayloadResult>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='PayloadsHookContext', request='SetStatus', version=1, params=_params)
+        _params['args'] = args
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(PayloadResults)
+    async def Track(self, payloads):
+        '''
+        payloads : typing.Sequence<+T_co>[~Payload]<~Payload>
+        Returns -> typing.Sequence<+T_co>[~PayloadResult]<~PayloadResult>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='PayloadsHookContext', request='Track', version=1, params=_params)
+        _params['payloads'] = payloads
+        reply = await self.rpc(msg)
+        return reply
+
+
 
+    @ReturnMapping(PayloadResults)
+    async def Untrack(self, entities):
+        '''
+        entities : typing.Sequence<+T_co>[~Entity]<~Entity>
+        Returns -> typing.Sequence<+T_co>[~PayloadResult]<~PayloadResult>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='PayloadsHookContext', request='Untrack', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -14886,8 +16308,8 @@ class PingerFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Pinger', request='Ping', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Pinger', request='Ping', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -14901,8 +16323,8 @@ class PingerFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Pinger', request='Stop', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Pinger', request='Stop', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -14996,6 +16418,12 @@ class ProvisionerFacade(Type):
                                                                           'type': 'object'}},
                                                 'required': ['config'],
                                                 'type': 'object'},
+                     'DeviceBridgeInfo': {'additionalProperties': False,
+                                          'properties': {'bridge-name': {'type': 'string'},
+                                                         'host-device-name': {'type': 'string'}},
+                                          'required': ['host-device-name',
+                                                       'bridge-name'],
+                                          'type': 'object'},
                      'DistributionGroupResult': {'additionalProperties': False,
                                                  'properties': {'error': {'$ref': '#/definitions/Error'},
                                                                 'result': {'items': {'type': 'string'},
@@ -15084,6 +16512,19 @@ class ProvisionerFacade(Type):
                                                                 'tags': {'items': {'type': 'string'},
                                                                          'type': 'array'}},
                                                  'type': 'object'},
+                     'HostNetworkChange': {'additionalProperties': False,
+                                           'properties': {'error': {'$ref': '#/definitions/Error'},
+                                                          'new-bridges': {'items': {'$ref': '#/definitions/DeviceBridgeInfo'},
+                                                                          'type': 'array'},
+                                                          'reconfigure-delay': {'type': 'integer'}},
+                                           'required': ['new-bridges',
+                                                        'reconfigure-delay'],
+                                           'type': 'object'},
+                     'HostNetworkChangeResults': {'additionalProperties': False,
+                                                  'properties': {'results': {'items': {'$ref': '#/definitions/HostNetworkChange'},
+                                                                             'type': 'array'}},
+                                                  'required': ['results'],
+                                                  'type': 'object'},
                      'HostPort': {'additionalProperties': False,
                                   'properties': {'Address': {'$ref': '#/definitions/Address'},
                                                  'port': {'type': 'integer'}},
@@ -15175,6 +16616,8 @@ class ProvisionerFacade(Type):
                                                       'provider-space-id': {'type': 'string'},
                                                       'provider-subnet-id': {'type': 'string'},
                                                       'provider-vlan-id': {'type': 'string'},
+                                                      'routes': {'items': {'$ref': '#/definitions/NetworkRoute'},
+                                                                 'type': 'array'},
                                                       'vlan-tag': {'type': 'integer'}},
                                        'required': ['device-index',
                                                     'mac-address',
@@ -15191,6 +16634,14 @@ class ProvisionerFacade(Type):
                                                     'interface-type',
                                                     'disabled'],
                                        'type': 'object'},
+                     'NetworkRoute': {'additionalProperties': False,
+                                      'properties': {'destination-cidr': {'type': 'string'},
+                                                     'gateway-ip': {'type': 'string'},
+                                                     'metric': {'type': 'integer'}},
+                                      'required': ['destination-cidr',
+                                                   'gateway-ip',
+                                                   'metric'],
+                                      'type': 'object'},
                      'NotifyWatchResult': {'additionalProperties': False,
                                            'properties': {'NotifyWatcherId': {'type': 'string'},
                                                           'error': {'$ref': '#/definitions/Error'}},
@@ -15243,6 +16694,12 @@ class ProvisionerFacade(Type):
                                                                             'type': 'array'}},
                                                  'required': ['results'],
                                                  'type': 'object'},
+                     'SetMachineNetworkConfig': {'additionalProperties': False,
+                                                 'properties': {'config': {'items': {'$ref': '#/definitions/NetworkConfig'},
+                                                                           'type': 'array'},
+                                                                'tag': {'type': 'string'}},
+                                                 'required': ['tag', 'config'],
+                                                 'type': 'object'},
                      'SetStatus': {'additionalProperties': False,
                                    'properties': {'entities': {'items': {'$ref': '#/definitions/EntityStatusArgs'},
                                                                'type': 'array'}},
@@ -15334,7 +16791,7 @@ class ProvisionerFacade(Type):
                      'Value': {'additionalProperties': False,
                                'properties': {'arch': {'type': 'string'},
                                               'container': {'type': 'string'},
-                                              'cpu-cores': {'type': 'integer'},
+                                              'cores': {'type': 'integer'},
                                               'cpu-power': {'type': 'integer'},
                                               'instance-type': {'type': 'string'},
                                               'mem': {'type': 'integer'},
@@ -15427,6 +16884,9 @@ class ProvisionerFacade(Type):
                     'GetContainerInterfaceInfo': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
                                                                  'Result': {'$ref': '#/definitions/MachineNetworkConfigResults'}},
                                                   'type': 'object'},
+                    'HostChangesForContainers': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
+                                                                'Result': {'$ref': '#/definitions/HostNetworkChangeResults'}},
+                                                 'type': 'object'},
                     'InstanceId': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
                                                   'Result': {'$ref': '#/definitions/StringResults'}},
                                    'type': 'object'},
@@ -15460,12 +16920,16 @@ class ProvisionerFacade(Type):
                     'Series': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
                                               'Result': {'$ref': '#/definitions/StringResults'}},
                                'type': 'object'},
+                    'SetHostMachineNetworkConfig': {'properties': {'Params': {'$ref': '#/definitions/SetMachineNetworkConfig'}},
+                                                    'type': 'object'},
                     'SetInstanceInfo': {'properties': {'Params': {'$ref': '#/definitions/InstancesInfo'},
                                                        'Result': {'$ref': '#/definitions/ErrorResults'}},
                                         'type': 'object'},
                     'SetInstanceStatus': {'properties': {'Params': {'$ref': '#/definitions/SetStatus'},
                                                          'Result': {'$ref': '#/definitions/ErrorResults'}},
                                           'type': 'object'},
+                    'SetObservedNetworkConfig': {'properties': {'Params': {'$ref': '#/definitions/SetMachineNetworkConfig'}},
+                                                 'type': 'object'},
                     'SetPasswords': {'properties': {'Params': {'$ref': '#/definitions/EntityPasswords'},
                                                     'Result': {'$ref': '#/definitions/ErrorResults'}},
                                      'type': 'object'},
@@ -15510,8 +16974,8 @@ class ProvisionerFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), typing.Sequence<+T_co>[str]]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='APIAddresses', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Provisioner', request='APIAddresses', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -15525,8 +16989,8 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~HostPort]<~HostPort>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='APIHostPorts', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Provisioner', request='APIHostPorts', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -15540,8 +17004,8 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[int]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='CACert', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Provisioner', request='CACert', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -15555,9 +17019,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ConstraintsResult]<~ConstraintsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='Constraints', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='Constraints', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15570,8 +17034,8 @@ class ProvisionerFacade(Type):
         Returns -> typing.Union[_ForwardRef('UpdateBehavior'), str, _ForwardRef('Settings'), _ForwardRef('Settings'), bool]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='ContainerConfig', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Provisioner', request='ContainerConfig', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -15585,9 +17049,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='ContainerManagerConfig', version=3, params=params)
-        params['type'] = type_
+        _params = dict()
+        msg = dict(type='Provisioner', request='ContainerManagerConfig', version=3, params=_params)
+        _params['type'] = type_
         reply = await self.rpc(msg)
         return reply
 
@@ -15600,8 +17064,8 @@ class ProvisionerFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, typing.Any]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='ControllerConfig', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Provisioner', request='ControllerConfig', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -15615,9 +17079,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~DistributionGroupResult]<~DistributionGroupResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='DistributionGroup', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='DistributionGroup', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15630,9 +17094,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='EnsureDead', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='EnsureDead', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15649,13 +17113,13 @@ class ProvisionerFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), typing.Sequence<+T_co>[~Tools]<~Tools>]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='FindTools', version=3, params=params)
-        params['arch'] = arch
-        params['major'] = major
-        params['minor'] = minor
-        params['number'] = number
-        params['series'] = series
+        _params = dict()
+        msg = dict(type='Provisioner', request='FindTools', version=3, params=_params)
+        _params['arch'] = arch
+        _params['major'] = major
+        _params['minor'] = minor
+        _params['number'] = number
+        _params['series'] = series
         reply = await self.rpc(msg)
         return reply
 
@@ -15668,9 +17132,24 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~MachineNetworkConfigResult]<~MachineNetworkConfigResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='GetContainerInterfaceInfo', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='GetContainerInterfaceInfo', version=3, params=_params)
+        _params['entities'] = entities
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(HostNetworkChangeResults)
+    async def HostChangesForContainers(self, entities):
+        '''
+        entities : typing.Sequence<+T_co>[~Entity]<~Entity>
+        Returns -> typing.Sequence<+T_co>[~HostNetworkChange]<~HostNetworkChange>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Provisioner', request='HostChangesForContainers', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15683,9 +17162,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringResult]<~StringResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='InstanceId', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='InstanceId', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15698,9 +17177,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StatusResult]<~StatusResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='InstanceStatus', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='InstanceStatus', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15713,9 +17192,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~LifeResult]<~LifeResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='Life', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='Life', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15728,8 +17207,8 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StatusResult]<~StatusResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='MachinesWithTransientErrors', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Provisioner', request='MachinesWithTransientErrors', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -15743,9 +17222,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='MarkMachinesForRemoval', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='MarkMachinesForRemoval', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15758,8 +17237,8 @@ class ProvisionerFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, typing.Any]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='ModelConfig', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Provisioner', request='ModelConfig', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -15773,8 +17252,8 @@ class ProvisionerFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='ModelUUID', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Provisioner', request='ModelUUID', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -15788,9 +17267,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~MachineNetworkConfigResult]<~MachineNetworkConfigResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='PrepareContainerInterfaceInfo', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='PrepareContainerInterfaceInfo', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15803,9 +17282,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ProvisioningInfoResult]<~ProvisioningInfoResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='ProvisioningInfo', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='ProvisioningInfo', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15818,9 +17297,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='ReleaseContainerAddresses', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='ReleaseContainerAddresses', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15833,9 +17312,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='Remove', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='Remove', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15848,9 +17327,26 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringResult]<~StringResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='Series', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='Series', version=3, params=_params)
+        _params['entities'] = entities
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(None)
+    async def SetHostMachineNetworkConfig(self, config, tag):
+        '''
+        config : typing.Sequence<+T_co>[~NetworkConfig]<~NetworkConfig>
+        tag : str
+        Returns -> None
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Provisioner', request='SetHostMachineNetworkConfig', version=3, params=_params)
+        _params['config'] = config
+        _params['tag'] = tag
         reply = await self.rpc(msg)
         return reply
 
@@ -15863,9 +17359,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='SetInstanceInfo', version=3, params=params)
-        params['machines'] = machines
+        _params = dict()
+        msg = dict(type='Provisioner', request='SetInstanceInfo', version=3, params=_params)
+        _params['machines'] = machines
         reply = await self.rpc(msg)
         return reply
 
@@ -15878,9 +17374,26 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='SetInstanceStatus', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='SetInstanceStatus', version=3, params=_params)
+        _params['entities'] = entities
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(None)
+    async def SetObservedNetworkConfig(self, config, tag):
+        '''
+        config : typing.Sequence<+T_co>[~NetworkConfig]<~NetworkConfig>
+        tag : str
+        Returns -> None
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Provisioner', request='SetObservedNetworkConfig', version=3, params=_params)
+        _params['config'] = config
+        _params['tag'] = tag
         reply = await self.rpc(msg)
         return reply
 
@@ -15893,9 +17406,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='SetPasswords', version=3, params=params)
-        params['changes'] = changes
+        _params = dict()
+        msg = dict(type='Provisioner', request='SetPasswords', version=3, params=_params)
+        _params['changes'] = changes
         reply = await self.rpc(msg)
         return reply
 
@@ -15908,9 +17421,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='SetStatus', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='SetStatus', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15923,9 +17436,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='SetSupportedContainers', version=3, params=params)
-        params['params'] = params
+        _params = dict()
+        msg = dict(type='Provisioner', request='SetSupportedContainers', version=3, params=_params)
+        _params['params'] = params
         reply = await self.rpc(msg)
         return reply
 
@@ -15938,8 +17451,8 @@ class ProvisionerFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), typing.Sequence<+T_co>[str]]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='StateAddresses', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Provisioner', request='StateAddresses', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -15953,9 +17466,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StatusResult]<~StatusResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='Status', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='Status', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15968,9 +17481,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ToolsResult]<~ToolsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='Tools', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='Tools', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15983,9 +17496,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='UpdateStatus', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Provisioner', request='UpdateStatus', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -15998,8 +17511,8 @@ class ProvisionerFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='WatchAPIHostPorts', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Provisioner', request='WatchAPIHostPorts', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -16013,9 +17526,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsWatchResult]<~StringsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='WatchAllContainers', version=3, params=params)
-        params['params'] = params
+        _params = dict()
+        msg = dict(type='Provisioner', request='WatchAllContainers', version=3, params=_params)
+        _params['params'] = params
         reply = await self.rpc(msg)
         return reply
 
@@ -16028,9 +17541,9 @@ class ProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsWatchResult]<~StringsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='WatchContainers', version=3, params=params)
-        params['params'] = params
+        _params = dict()
+        msg = dict(type='Provisioner', request='WatchContainers', version=3, params=_params)
+        _params['params'] = params
         reply = await self.rpc(msg)
         return reply
 
@@ -16043,8 +17556,8 @@ class ProvisionerFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='WatchForModelConfigChanges', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Provisioner', request='WatchForModelConfigChanges', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -16058,8 +17571,8 @@ class ProvisionerFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='WatchMachineErrorRetry', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Provisioner', request='WatchMachineErrorRetry', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -16073,8 +17586,8 @@ class ProvisionerFacade(Type):
         Returns -> typing.Union[typing.Sequence<+T_co>[str], _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Provisioner', request='WatchModelMachines', version=3, params=params)
+        _params = dict()
+        msg = dict(type='Provisioner', request='WatchModelMachines', version=3, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -16151,9 +17664,9 @@ class ProxyUpdaterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ProxyConfigResult]<~ProxyConfigResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ProxyUpdater', request='ProxyConfig', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='ProxyUpdater', request='ProxyConfig', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -16166,9 +17679,9 @@ class ProxyUpdaterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='ProxyUpdater', request='WatchForProxyConfigAndAPIHostPortChanges', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='ProxyUpdater', request='WatchForProxyConfigAndAPIHostPortChanges', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -16238,9 +17751,9 @@ class RebootFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Reboot', request='ClearReboot', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Reboot', request='ClearReboot', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -16253,9 +17766,9 @@ class RebootFacade(Type):
         Returns -> typing.Sequence<+T_co>[~RebootActionResult]<~RebootActionResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Reboot', request='GetRebootAction', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Reboot', request='GetRebootAction', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -16268,9 +17781,9 @@ class RebootFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Reboot', request='RequestReboot', version=2, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Reboot', request='RequestReboot', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -16283,8 +17796,8 @@ class RebootFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Reboot', request='WatchForRebootEvent', version=2, params=params)
+        _params = dict()
+        msg = dict(type='Reboot', request='WatchForRebootEvent', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -16335,8 +17848,100 @@ class RelationUnitsWatcherFacade(Type):
         Returns -> typing.Union[_ForwardRef('RelationUnitsChange'), _ForwardRef('Error'), str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='RelationUnitsWatcher', request='Next', version=1, params=params)
+        _params = dict()
+        msg = dict(type='RelationUnitsWatcher', request='Next', version=1, params=_params)
+
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(None)
+    async def Stop(self):
+        '''
+
+        Returns -> None
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='RelationUnitsWatcher', request='Stop', version=1, params=_params)
+
+        reply = await self.rpc(msg)
+        return reply
+
+
+class RemoteApplicationWatcherFacade(Type):
+    name = 'RemoteApplicationWatcher'
+    version = 1
+    schema =     {'definitions': {'Error': {'additionalProperties': False,
+                               'properties': {'code': {'type': 'string'},
+                                              'info': {'$ref': '#/definitions/ErrorInfo'},
+                                              'message': {'type': 'string'}},
+                               'required': ['message', 'code'],
+                               'type': 'object'},
+                     'ErrorInfo': {'additionalProperties': False,
+                                   'properties': {'macaroon': {'$ref': '#/definitions/Macaroon'},
+                                                  'macaroon-path': {'type': 'string'}},
+                                   'type': 'object'},
+                     'Macaroon': {'additionalProperties': False, 'type': 'object'},
+                     'RemoteApplicationChange': {'additionalProperties': False,
+                                                 'properties': {'application-tag': {'type': 'string'},
+                                                                'life': {'type': 'string'},
+                                                                'relations': {'$ref': '#/definitions/RemoteRelationsChange'}},
+                                                 'required': ['application-tag',
+                                                              'life',
+                                                              'relations'],
+                                                 'type': 'object'},
+                     'RemoteApplicationWatchResult': {'additionalProperties': False,
+                                                      'properties': {'change': {'$ref': '#/definitions/RemoteApplicationChange'},
+                                                                     'error': {'$ref': '#/definitions/Error'},
+                                                                     'id': {'type': 'string'}},
+                                                      'required': ['id'],
+                                                      'type': 'object'},
+                     'RemoteEntityId': {'additionalProperties': False,
+                                        'properties': {'model-uuid': {'type': 'string'},
+                                                       'token': {'type': 'string'}},
+                                        'required': ['model-uuid', 'token'],
+                                        'type': 'object'},
+                     'RemoteRelationChange': {'additionalProperties': False,
+                                              'properties': {'changed-units': {'patternProperties': {'.*': {'$ref': '#/definitions/RemoteRelationUnitChange'}},
+                                                                               'type': 'object'},
+                                                             'departed-units': {'items': {'type': 'string'},
+                                                                                'type': 'array'},
+                                                             'id': {'type': 'integer'},
+                                                             'life': {'type': 'string'}},
+                                              'required': ['id', 'life'],
+                                              'type': 'object'},
+                     'RemoteRelationUnitChange': {'additionalProperties': False,
+                                                  'properties': {'settings': {'patternProperties': {'.*': {'additionalProperties': True,
+                                                                                                           'type': 'object'}},
+                                                                              'type': 'object'},
+                                                                 'unit-id': {'$ref': '#/definitions/RemoteEntityId'}},
+                                                  'required': ['unit-id'],
+                                                  'type': 'object'},
+                     'RemoteRelationsChange': {'additionalProperties': False,
+                                               'properties': {'changed': {'items': {'$ref': '#/definitions/RemoteRelationChange'},
+                                                                          'type': 'array'},
+                                                              'initial': {'type': 'boolean'},
+                                                              'removed': {'items': {'type': 'integer'},
+                                                                          'type': 'array'}},
+                                               'required': ['initial'],
+                                               'type': 'object'}},
+     'properties': {'Next': {'properties': {'Result': {'$ref': '#/definitions/RemoteApplicationWatchResult'}},
+                             'type': 'object'},
+                    'Stop': {'type': 'object'}},
+     'type': 'object'}
+    
+
+    @ReturnMapping(RemoteApplicationWatchResult)
+    async def Next(self):
+        '''
+
+        Returns -> typing.Union[_ForwardRef('RemoteApplicationChange'), _ForwardRef('Error'), str]
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='RemoteApplicationWatcher', request='Next', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -16350,9 +17955,332 @@ class RelationUnitsWatcherFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='RelationUnitsWatcher', request='Stop', version=1, params=params)
+        _params = dict()
+        msg = dict(type='RemoteApplicationWatcher', request='Stop', version=1, params=_params)
+
+        reply = await self.rpc(msg)
+        return reply
+
+
+class RemoteRelationsWatcherFacade(Type):
+    name = 'RemoteRelationsWatcher'
+    version = 1
+    schema =     {'definitions': {'Error': {'additionalProperties': False,
+                               'properties': {'code': {'type': 'string'},
+                                              'info': {'$ref': '#/definitions/ErrorInfo'},
+                                              'message': {'type': 'string'}},
+                               'required': ['message', 'code'],
+                               'type': 'object'},
+                     'ErrorInfo': {'additionalProperties': False,
+                                   'properties': {'macaroon': {'$ref': '#/definitions/Macaroon'},
+                                                  'macaroon-path': {'type': 'string'}},
+                                   'type': 'object'},
+                     'Macaroon': {'additionalProperties': False, 'type': 'object'},
+                     'RemoteEntityId': {'additionalProperties': False,
+                                        'properties': {'model-uuid': {'type': 'string'},
+                                                       'token': {'type': 'string'}},
+                                        'required': ['model-uuid', 'token'],
+                                        'type': 'object'},
+                     'RemoteRelationChange': {'additionalProperties': False,
+                                              'properties': {'changed-units': {'patternProperties': {'.*': {'$ref': '#/definitions/RemoteRelationUnitChange'}},
+                                                                               'type': 'object'},
+                                                             'departed-units': {'items': {'type': 'string'},
+                                                                                'type': 'array'},
+                                                             'id': {'type': 'integer'},
+                                                             'life': {'type': 'string'}},
+                                              'required': ['id', 'life'],
+                                              'type': 'object'},
+                     'RemoteRelationUnitChange': {'additionalProperties': False,
+                                                  'properties': {'settings': {'patternProperties': {'.*': {'additionalProperties': True,
+                                                                                                           'type': 'object'}},
+                                                                              'type': 'object'},
+                                                                 'unit-id': {'$ref': '#/definitions/RemoteEntityId'}},
+                                                  'required': ['unit-id'],
+                                                  'type': 'object'},
+                     'RemoteRelationsChange': {'additionalProperties': False,
+                                               'properties': {'changed': {'items': {'$ref': '#/definitions/RemoteRelationChange'},
+                                                                          'type': 'array'},
+                                                              'initial': {'type': 'boolean'},
+                                                              'removed': {'items': {'type': 'integer'},
+                                                                          'type': 'array'}},
+                                               'required': ['initial'],
+                                               'type': 'object'},
+                     'RemoteRelationsWatchResult': {'additionalProperties': False,
+                                                    'properties': {'RemoteRelationsWatcherId': {'type': 'string'},
+                                                                   'change': {'$ref': '#/definitions/RemoteRelationsChange'},
+                                                                   'error': {'$ref': '#/definitions/Error'}},
+                                                    'required': ['RemoteRelationsWatcherId'],
+                                                    'type': 'object'}},
+     'properties': {'Next': {'properties': {'Result': {'$ref': '#/definitions/RemoteRelationsWatchResult'}},
+                             'type': 'object'},
+                    'Stop': {'type': 'object'}},
+     'type': 'object'}
+    
+
+    @ReturnMapping(RemoteRelationsWatchResult)
+    async def Next(self):
+        '''
+
+        Returns -> typing.Union[str, _ForwardRef('RemoteRelationsChange'), _ForwardRef('Error')]
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='RemoteRelationsWatcher', request='Next', version=1, params=_params)
+
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(None)
+    async def Stop(self):
+        '''
+
+        Returns -> None
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='RemoteRelationsWatcher', request='Stop', version=1, params=_params)
+
+        reply = await self.rpc(msg)
+        return reply
+
+
+class ResourcesFacade(Type):
+    name = 'Resources'
+    version = 1
+    schema =     {'definitions': {'AddCharmWithAuthorization': {'additionalProperties': False,
+                                                   'properties': {'channel': {'type': 'string'},
+                                                                  'macaroon': {'$ref': '#/definitions/Macaroon'},
+                                                                  'url': {'type': 'string'}},
+                                                   'required': ['url',
+                                                                'channel',
+                                                                'macaroon'],
+                                                   'type': 'object'},
+                     'AddPendingResourcesArgs': {'additionalProperties': False,
+                                                 'properties': {'AddCharmWithAuthorization': {'$ref': '#/definitions/AddCharmWithAuthorization'},
+                                                                'Entity': {'$ref': '#/definitions/Entity'},
+                                                                'Resources': {'items': {'$ref': '#/definitions/CharmResource'},
+                                                                              'type': 'array'}},
+                                                 'required': ['Entity',
+                                                              'AddCharmWithAuthorization',
+                                                              'Resources'],
+                                                 'type': 'object'},
+                     'AddPendingResourcesResult': {'additionalProperties': False,
+                                                   'properties': {'ErrorResult': {'$ref': '#/definitions/ErrorResult'},
+                                                                  'pending-ids': {'items': {'type': 'string'},
+                                                                                  'type': 'array'}},
+                                                   'required': ['ErrorResult',
+                                                                'pending-ids'],
+                                                   'type': 'object'},
+                     'CharmResource': {'additionalProperties': False,
+                                       'properties': {'description': {'type': 'string'},
+                                                      'fingerprint': {'items': {'type': 'integer'},
+                                                                      'type': 'array'},
+                                                      'name': {'type': 'string'},
+                                                      'origin': {'type': 'string'},
+                                                      'path': {'type': 'string'},
+                                                      'revision': {'type': 'integer'},
+                                                      'size': {'type': 'integer'},
+                                                      'type': {'type': 'string'}},
+                                       'required': ['name',
+                                                    'type',
+                                                    'path',
+                                                    'origin',
+                                                    'revision',
+                                                    'fingerprint',
+                                                    'size'],
+                                       'type': 'object'},
+                     'Entity': {'additionalProperties': False,
+                                'properties': {'tag': {'type': 'string'}},
+                                'required': ['tag'],
+                                'type': 'object'},
+                     'Error': {'additionalProperties': False,
+                               'properties': {'code': {'type': 'string'},
+                                              'info': {'$ref': '#/definitions/ErrorInfo'},
+                                              'message': {'type': 'string'}},
+                               'required': ['message', 'code'],
+                               'type': 'object'},
+                     'ErrorInfo': {'additionalProperties': False,
+                                   'properties': {'macaroon': {'$ref': '#/definitions/Macaroon'},
+                                                  'macaroon-path': {'type': 'string'}},
+                                   'type': 'object'},
+                     'ErrorResult': {'additionalProperties': False,
+                                     'properties': {'error': {'$ref': '#/definitions/Error'}},
+                                     'type': 'object'},
+                     'ListResourcesArgs': {'additionalProperties': False,
+                                           'properties': {'entities': {'items': {'$ref': '#/definitions/Entity'},
+                                                                       'type': 'array'}},
+                                           'required': ['entities'],
+                                           'type': 'object'},
+                     'Macaroon': {'additionalProperties': False, 'type': 'object'},
+                     'Resource': {'additionalProperties': False,
+                                  'properties': {'CharmResource': {'$ref': '#/definitions/CharmResource'},
+                                                 'application': {'type': 'string'},
+                                                 'id': {'type': 'string'},
+                                                 'pending-id': {'type': 'string'},
+                                                 'timestamp': {'format': 'date-time',
+                                                               'type': 'string'},
+                                                 'username': {'type': 'string'}},
+                                  'required': ['CharmResource',
+                                               'id',
+                                               'pending-id',
+                                               'application',
+                                               'username',
+                                               'timestamp'],
+                                  'type': 'object'},
+                     'ResourcesResult': {'additionalProperties': False,
+                                         'properties': {'ErrorResult': {'$ref': '#/definitions/ErrorResult'},
+                                                        'charm-store-resources': {'items': {'$ref': '#/definitions/CharmResource'},
+                                                                                  'type': 'array'},
+                                                        'resources': {'items': {'$ref': '#/definitions/Resource'},
+                                                                      'type': 'array'},
+                                                        'unit-resources': {'items': {'$ref': '#/definitions/UnitResources'},
+                                                                           'type': 'array'}},
+                                         'required': ['ErrorResult',
+                                                      'resources',
+                                                      'charm-store-resources',
+                                                      'unit-resources'],
+                                         'type': 'object'},
+                     'ResourcesResults': {'additionalProperties': False,
+                                          'properties': {'results': {'items': {'$ref': '#/definitions/ResourcesResult'},
+                                                                     'type': 'array'}},
+                                          'required': ['results'],
+                                          'type': 'object'},
+                     'UnitResources': {'additionalProperties': False,
+                                       'properties': {'Entity': {'$ref': '#/definitions/Entity'},
+                                                      'download-progress': {'patternProperties': {'.*': {'type': 'integer'}},
+                                                                            'type': 'object'},
+                                                      'resources': {'items': {'$ref': '#/definitions/Resource'},
+                                                                    'type': 'array'}},
+                                       'required': ['Entity',
+                                                    'resources',
+                                                    'download-progress'],
+                                       'type': 'object'}},
+     'properties': {'AddPendingResources': {'properties': {'Params': {'$ref': '#/definitions/AddPendingResourcesArgs'},
+                                                           'Result': {'$ref': '#/definitions/AddPendingResourcesResult'}},
+                                            'type': 'object'},
+                    'ListResources': {'properties': {'Params': {'$ref': '#/definitions/ListResourcesArgs'},
+                                                     'Result': {'$ref': '#/definitions/ResourcesResults'}},
+                                      'type': 'object'}},
+     'type': 'object'}
+    
+
+    @ReturnMapping(AddPendingResourcesResult)
+    async def AddPendingResources(self, addcharmwithauthorization, entity, resources):
+        '''
+        addcharmwithauthorization : AddCharmWithAuthorization
+        entity : Entity
+        resources : typing.Sequence<+T_co>[~CharmResource]<~CharmResource>
+        Returns -> typing.Union[_ForwardRef('ErrorResult'), typing.Sequence<+T_co>[str]]
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Resources', request='AddPendingResources', version=1, params=_params)
+        _params['AddCharmWithAuthorization'] = addcharmwithauthorization
+        _params['Entity'] = entity
+        _params['Resources'] = resources
+        reply = await self.rpc(msg)
+        return reply
+
+
+
+    @ReturnMapping(ResourcesResults)
+    async def ListResources(self, entities):
+        '''
+        entities : typing.Sequence<+T_co>[~Entity]<~Entity>
+        Returns -> typing.Sequence<+T_co>[~ResourcesResult]<~ResourcesResult>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='Resources', request='ListResources', version=1, params=_params)
+        _params['entities'] = entities
+        reply = await self.rpc(msg)
+        return reply
+
+
+class ResourcesHookContextFacade(Type):
+    name = 'ResourcesHookContext'
+    version = 1
+    schema =     {'definitions': {'CharmResource': {'additionalProperties': False,
+                                       'properties': {'description': {'type': 'string'},
+                                                      'fingerprint': {'items': {'type': 'integer'},
+                                                                      'type': 'array'},
+                                                      'name': {'type': 'string'},
+                                                      'origin': {'type': 'string'},
+                                                      'path': {'type': 'string'},
+                                                      'revision': {'type': 'integer'},
+                                                      'size': {'type': 'integer'},
+                                                      'type': {'type': 'string'}},
+                                       'required': ['name',
+                                                    'type',
+                                                    'path',
+                                                    'origin',
+                                                    'revision',
+                                                    'fingerprint',
+                                                    'size'],
+                                       'type': 'object'},
+                     'Error': {'additionalProperties': False,
+                               'properties': {'code': {'type': 'string'},
+                                              'info': {'$ref': '#/definitions/ErrorInfo'},
+                                              'message': {'type': 'string'}},
+                               'required': ['message', 'code'],
+                               'type': 'object'},
+                     'ErrorInfo': {'additionalProperties': False,
+                                   'properties': {'macaroon': {'$ref': '#/definitions/Macaroon'},
+                                                  'macaroon-path': {'type': 'string'}},
+                                   'type': 'object'},
+                     'ErrorResult': {'additionalProperties': False,
+                                     'properties': {'error': {'$ref': '#/definitions/Error'}},
+                                     'type': 'object'},
+                     'ListResourcesArgs': {'additionalProperties': False,
+                                           'properties': {'resource-names': {'items': {'type': 'string'},
+                                                                             'type': 'array'}},
+                                           'required': ['resource-names'],
+                                           'type': 'object'},
+                     'Macaroon': {'additionalProperties': False, 'type': 'object'},
+                     'Resource': {'additionalProperties': False,
+                                  'properties': {'CharmResource': {'$ref': '#/definitions/CharmResource'},
+                                                 'application': {'type': 'string'},
+                                                 'id': {'type': 'string'},
+                                                 'pending-id': {'type': 'string'},
+                                                 'timestamp': {'format': 'date-time',
+                                                               'type': 'string'},
+                                                 'username': {'type': 'string'}},
+                                  'required': ['CharmResource',
+                                               'id',
+                                               'pending-id',
+                                               'application',
+                                               'username',
+                                               'timestamp'],
+                                  'type': 'object'},
+                     'ResourceResult': {'additionalProperties': False,
+                                        'properties': {'ErrorResult': {'$ref': '#/definitions/ErrorResult'},
+                                                       'resource': {'$ref': '#/definitions/Resource'}},
+                                        'required': ['ErrorResult', 'resource'],
+                                        'type': 'object'},
+                     'ResourcesResult': {'additionalProperties': False,
+                                         'properties': {'ErrorResult': {'$ref': '#/definitions/ErrorResult'},
+                                                        'resources': {'items': {'$ref': '#/definitions/ResourceResult'},
+                                                                      'type': 'array'}},
+                                         'required': ['ErrorResult', 'resources'],
+                                         'type': 'object'}},
+     'properties': {'GetResourceInfo': {'properties': {'Params': {'$ref': '#/definitions/ListResourcesArgs'},
+                                                       'Result': {'$ref': '#/definitions/ResourcesResult'}},
+                                        'type': 'object'}},
+     'type': 'object'}
+    
 
+    @ReturnMapping(ResourcesResult)
+    async def GetResourceInfo(self, entities):
+        '''
+        entities : typing.Sequence<+T_co>[~Entity]<~Entity>
+        Returns -> typing.Union[_ForwardRef('ErrorResult'), typing.Sequence<+T_co>[~UnitResources]<~UnitResources>]
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='ResourcesHookContext', request='GetResourceInfo', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -16370,8 +18298,8 @@ class ResumerFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Resumer', request='ResumeTransactions', version=2, params=params)
+        _params = dict()
+        msg = dict(type='Resumer', request='ResumeTransactions', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -16447,9 +18375,9 @@ class RetryStrategyFacade(Type):
         Returns -> typing.Sequence<+T_co>[~RetryStrategyResult]<~RetryStrategyResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='RetryStrategy', request='RetryStrategy', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='RetryStrategy', request='RetryStrategy', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -16462,16 +18390,16 @@ class RetryStrategyFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='RetryStrategy', request='WatchRetryStrategy', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='RetryStrategy', request='WatchRetryStrategy', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
 
 class SSHClientFacade(Type):
     name = 'SSHClient'
-    version = 1
+    version = 2
     schema =     {'definitions': {'Entities': {'additionalProperties': False,
                                   'properties': {'entities': {'items': {'$ref': '#/definitions/Entity'},
                                                               'type': 'array'}},
@@ -16501,6 +18429,17 @@ class SSHClientFacade(Type):
                                                                       'type': 'array'}},
                                            'required': ['results'],
                                            'type': 'object'},
+                     'SSHAddressesResult': {'additionalProperties': False,
+                                            'properties': {'addresses': {'items': {'type': 'string'},
+                                                                         'type': 'array'},
+                                                           'error': {'$ref': '#/definitions/Error'}},
+                                            'required': ['addresses'],
+                                            'type': 'object'},
+                     'SSHAddressesResults': {'additionalProperties': False,
+                                             'properties': {'results': {'items': {'$ref': '#/definitions/SSHAddressesResult'},
+                                                                        'type': 'array'}},
+                                             'required': ['results'],
+                                             'type': 'object'},
                      'SSHProxyResult': {'additionalProperties': False,
                                         'properties': {'use-proxy': {'type': 'boolean'}},
                                         'required': ['use-proxy'],
@@ -16515,7 +18454,10 @@ class SSHClientFacade(Type):
                                                                          'type': 'array'}},
                                               'required': ['results'],
                                               'type': 'object'}},
-     'properties': {'PrivateAddress': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
+     'properties': {'AllAddresses': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
+                                                    'Result': {'$ref': '#/definitions/SSHAddressesResults'}},
+                                     'type': 'object'},
+                    'PrivateAddress': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
                                                       'Result': {'$ref': '#/definitions/SSHAddressResults'}},
                                        'type': 'object'},
                     'Proxy': {'properties': {'Result': {'$ref': '#/definitions/SSHProxyResult'}},
@@ -16529,6 +18471,21 @@ class SSHClientFacade(Type):
      'type': 'object'}
     
 
+    @ReturnMapping(SSHAddressesResults)
+    async def AllAddresses(self, entities):
+        '''
+        entities : typing.Sequence<+T_co>[~Entity]<~Entity>
+        Returns -> typing.Sequence<+T_co>[~SSHAddressesResult]<~SSHAddressesResult>
+        '''
+        # map input types to rpc msg
+        _params = dict()
+        msg = dict(type='SSHClient', request='AllAddresses', version=2, params=_params)
+        _params['entities'] = entities
+        reply = await self.rpc(msg)
+        return reply
+
+
+
     @ReturnMapping(SSHAddressResults)
     async def PrivateAddress(self, entities):
         '''
@@ -16536,9 +18493,9 @@ class SSHClientFacade(Type):
         Returns -> typing.Sequence<+T_co>[~SSHAddressResult]<~SSHAddressResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='SSHClient', request='PrivateAddress', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='SSHClient', request='PrivateAddress', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -16551,8 +18508,8 @@ class SSHClientFacade(Type):
         Returns -> bool
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='SSHClient', request='Proxy', version=1, params=params)
+        _params = dict()
+        msg = dict(type='SSHClient', request='Proxy', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -16566,9 +18523,9 @@ class SSHClientFacade(Type):
         Returns -> typing.Sequence<+T_co>[~SSHAddressResult]<~SSHAddressResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='SSHClient', request='PublicAddress', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='SSHClient', request='PublicAddress', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -16581,9 +18538,9 @@ class SSHClientFacade(Type):
         Returns -> typing.Sequence<+T_co>[~SSHPublicKeysResult]<~SSHPublicKeysResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='SSHClient', request='PublicKeys', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='SSHClient', request='PublicKeys', version=2, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -16648,9 +18605,9 @@ class SingularFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Singular', request='Claim', version=1, params=params)
-        params['claims'] = claims
+        _params = dict()
+        msg = dict(type='Singular', request='Claim', version=1, params=_params)
+        _params['claims'] = claims
         reply = await self.rpc(msg)
         return reply
 
@@ -16663,9 +18620,9 @@ class SingularFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Singular', request='Wait', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Singular', request='Wait', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -16749,9 +18706,9 @@ class SpacesFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Spaces', request='CreateSpaces', version=2, params=params)
-        params['spaces'] = spaces
+        _params = dict()
+        msg = dict(type='Spaces', request='CreateSpaces', version=2, params=_params)
+        _params['spaces'] = spaces
         reply = await self.rpc(msg)
         return reply
 
@@ -16764,8 +18721,8 @@ class SpacesFacade(Type):
         Returns -> typing.Sequence<+T_co>[~Space]<~Space>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Spaces', request='ListSpaces', version=2, params=params)
+        _params = dict()
+        msg = dict(type='Spaces', request='ListSpaces', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -16793,10 +18750,10 @@ class StatusHistoryFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StatusHistory', request='Prune', version=2, params=params)
-        params['max-history-mb'] = max_history_mb
-        params['max-history-time'] = max_history_time
+        _params = dict()
+        msg = dict(type='StatusHistory', request='Prune', version=2, params=_params)
+        _params['max-history-mb'] = max_history_mb
+        _params['max-history-time'] = max_history_time
         reply = await self.rpc(msg)
         return reply
 
@@ -17038,9 +18995,9 @@ class StorageFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Storage', request='AddToUnit', version=3, params=params)
-        params['storages'] = storages
+        _params = dict()
+        msg = dict(type='Storage', request='AddToUnit', version=3, params=_params)
+        _params['storages'] = storages
         reply = await self.rpc(msg)
         return reply
 
@@ -17055,11 +19012,11 @@ class StorageFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Storage', request='CreatePool', version=3, params=params)
-        params['attrs'] = attrs
-        params['name'] = name
-        params['provider'] = provider
+        _params = dict()
+        msg = dict(type='Storage', request='CreatePool', version=3, params=_params)
+        _params['attrs'] = attrs
+        _params['name'] = name
+        _params['provider'] = provider
         reply = await self.rpc(msg)
         return reply
 
@@ -17072,9 +19029,9 @@ class StorageFacade(Type):
         Returns -> typing.Sequence<+T_co>[~FilesystemDetailsListResult]<~FilesystemDetailsListResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Storage', request='ListFilesystems', version=3, params=params)
-        params['filters'] = filters
+        _params = dict()
+        msg = dict(type='Storage', request='ListFilesystems', version=3, params=_params)
+        _params['filters'] = filters
         reply = await self.rpc(msg)
         return reply
 
@@ -17087,9 +19044,9 @@ class StorageFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StoragePoolsResult]<~StoragePoolsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Storage', request='ListPools', version=3, params=params)
-        params['filters'] = filters
+        _params = dict()
+        msg = dict(type='Storage', request='ListPools', version=3, params=_params)
+        _params['filters'] = filters
         reply = await self.rpc(msg)
         return reply
 
@@ -17102,9 +19059,9 @@ class StorageFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StorageDetailsListResult]<~StorageDetailsListResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Storage', request='ListStorageDetails', version=3, params=params)
-        params['filters'] = filters
+        _params = dict()
+        msg = dict(type='Storage', request='ListStorageDetails', version=3, params=_params)
+        _params['filters'] = filters
         reply = await self.rpc(msg)
         return reply
 
@@ -17117,9 +19074,9 @@ class StorageFacade(Type):
         Returns -> typing.Sequence<+T_co>[~VolumeDetailsListResult]<~VolumeDetailsListResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Storage', request='ListVolumes', version=3, params=params)
-        params['filters'] = filters
+        _params = dict()
+        msg = dict(type='Storage', request='ListVolumes', version=3, params=_params)
+        _params['filters'] = filters
         reply = await self.rpc(msg)
         return reply
 
@@ -17132,9 +19089,9 @@ class StorageFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StorageDetailsResult]<~StorageDetailsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Storage', request='StorageDetails', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Storage', request='StorageDetails', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17569,9 +19526,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~LifeResult]<~LifeResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='AttachmentLife', version=3, params=params)
-        params['ids'] = ids
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='AttachmentLife', version=3, params=_params)
+        _params['ids'] = ids
         reply = await self.rpc(msg)
         return reply
 
@@ -17584,9 +19541,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='EnsureDead', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='EnsureDead', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17599,9 +19556,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~FilesystemAttachmentParamsResult]<~FilesystemAttachmentParamsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='FilesystemAttachmentParams', version=3, params=params)
-        params['ids'] = ids
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='FilesystemAttachmentParams', version=3, params=_params)
+        _params['ids'] = ids
         reply = await self.rpc(msg)
         return reply
 
@@ -17614,9 +19571,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~FilesystemAttachmentResult]<~FilesystemAttachmentResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='FilesystemAttachments', version=3, params=params)
-        params['ids'] = ids
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='FilesystemAttachments', version=3, params=_params)
+        _params['ids'] = ids
         reply = await self.rpc(msg)
         return reply
 
@@ -17629,9 +19586,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~FilesystemParamsResult]<~FilesystemParamsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='FilesystemParams', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='FilesystemParams', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17644,9 +19601,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~FilesystemResult]<~FilesystemResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='Filesystems', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='Filesystems', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17659,9 +19616,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringResult]<~StringResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='InstanceId', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='InstanceId', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17674,9 +19631,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~LifeResult]<~LifeResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='Life', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='Life', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17689,9 +19646,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='Remove', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='Remove', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17704,9 +19661,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='RemoveAttachment', version=3, params=params)
-        params['ids'] = ids
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='RemoveAttachment', version=3, params=_params)
+        _params['ids'] = ids
         reply = await self.rpc(msg)
         return reply
 
@@ -17719,9 +19676,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='SetFilesystemAttachmentInfo', version=3, params=params)
-        params['filesystem-attachments'] = filesystem_attachments
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='SetFilesystemAttachmentInfo', version=3, params=_params)
+        _params['filesystem-attachments'] = filesystem_attachments
         reply = await self.rpc(msg)
         return reply
 
@@ -17734,9 +19691,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='SetFilesystemInfo', version=3, params=params)
-        params['filesystems'] = filesystems
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='SetFilesystemInfo', version=3, params=_params)
+        _params['filesystems'] = filesystems
         reply = await self.rpc(msg)
         return reply
 
@@ -17749,9 +19706,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='SetStatus', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='SetStatus', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17764,9 +19721,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='SetVolumeAttachmentInfo', version=3, params=params)
-        params['volume-attachments'] = volume_attachments
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='SetVolumeAttachmentInfo', version=3, params=_params)
+        _params['volume-attachments'] = volume_attachments
         reply = await self.rpc(msg)
         return reply
 
@@ -17779,9 +19736,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='SetVolumeInfo', version=3, params=params)
-        params['volumes'] = volumes
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='SetVolumeInfo', version=3, params=_params)
+        _params['volumes'] = volumes
         reply = await self.rpc(msg)
         return reply
 
@@ -17794,9 +19751,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='UpdateStatus', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='UpdateStatus', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17809,9 +19766,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~VolumeAttachmentParamsResult]<~VolumeAttachmentParamsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='VolumeAttachmentParams', version=3, params=params)
-        params['ids'] = ids
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='VolumeAttachmentParams', version=3, params=_params)
+        _params['ids'] = ids
         reply = await self.rpc(msg)
         return reply
 
@@ -17824,9 +19781,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~VolumeAttachmentResult]<~VolumeAttachmentResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='VolumeAttachments', version=3, params=params)
-        params['ids'] = ids
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='VolumeAttachments', version=3, params=_params)
+        _params['ids'] = ids
         reply = await self.rpc(msg)
         return reply
 
@@ -17839,9 +19796,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~BlockDeviceResult]<~BlockDeviceResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='VolumeBlockDevices', version=3, params=params)
-        params['ids'] = ids
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='VolumeBlockDevices', version=3, params=_params)
+        _params['ids'] = ids
         reply = await self.rpc(msg)
         return reply
 
@@ -17854,9 +19811,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~VolumeParamsResult]<~VolumeParamsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='VolumeParams', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='VolumeParams', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17869,9 +19826,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~VolumeResult]<~VolumeResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='Volumes', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='Volumes', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17884,9 +19841,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='WatchBlockDevices', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='WatchBlockDevices', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17899,9 +19856,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~MachineStorageIdsWatchResult]<~MachineStorageIdsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='WatchFilesystemAttachments', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='WatchFilesystemAttachments', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17914,9 +19871,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsWatchResult]<~StringsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='WatchFilesystems', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='WatchFilesystems', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17929,9 +19886,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='WatchMachines', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='WatchMachines', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17944,9 +19901,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~MachineStorageIdsWatchResult]<~MachineStorageIdsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='WatchVolumeAttachments', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='WatchVolumeAttachments', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -17959,9 +19916,9 @@ class StorageProvisionerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsWatchResult]<~StringsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StorageProvisioner', request='WatchVolumes', version=3, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='StorageProvisioner', request='WatchVolumes', version=3, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -18000,8 +19957,8 @@ class StringsWatcherFacade(Type):
         Returns -> typing.Union[typing.Sequence<+T_co>[str], _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StringsWatcher', request='Next', version=1, params=params)
+        _params = dict()
+        msg = dict(type='StringsWatcher', request='Next', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -18015,8 +19972,8 @@ class StringsWatcherFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='StringsWatcher', request='Stop', version=1, params=params)
+        _params = dict()
+        msg = dict(type='StringsWatcher', request='Stop', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -18122,9 +20079,9 @@ class SubnetsFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Subnets', request='AddSubnets', version=2, params=params)
-        params['subnets'] = subnets
+        _params = dict()
+        msg = dict(type='Subnets', request='AddSubnets', version=2, params=_params)
+        _params['subnets'] = subnets
         reply = await self.rpc(msg)
         return reply
 
@@ -18137,8 +20094,8 @@ class SubnetsFacade(Type):
         Returns -> typing.Sequence<+T_co>[~SpaceResult]<~SpaceResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Subnets', request='AllSpaces', version=2, params=params)
+        _params = dict()
+        msg = dict(type='Subnets', request='AllSpaces', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -18152,8 +20109,8 @@ class SubnetsFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ZoneResult]<~ZoneResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Subnets', request='AllZones', version=2, params=params)
+        _params = dict()
+        msg = dict(type='Subnets', request='AllZones', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -18168,10 +20125,10 @@ class SubnetsFacade(Type):
         Returns -> typing.Sequence<+T_co>[~Subnet]<~Subnet>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Subnets', request='ListSubnets', version=2, params=params)
-        params['space-tag'] = space_tag
-        params['zone'] = zone
+        _params = dict()
+        msg = dict(type='Subnets', request='ListSubnets', version=2, params=_params)
+        _params['space-tag'] = space_tag
+        _params['zone'] = zone
         reply = await self.rpc(msg)
         return reply
 
@@ -18272,8 +20229,8 @@ class UndertakerFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, typing.Any]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Undertaker', request='ModelConfig', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Undertaker', request='ModelConfig', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -18287,8 +20244,8 @@ class UndertakerFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), _ForwardRef('UndertakerModelInfo')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Undertaker', request='ModelInfo', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Undertaker', request='ModelInfo', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -18302,8 +20259,8 @@ class UndertakerFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Undertaker', request='ProcessDyingModel', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Undertaker', request='ProcessDyingModel', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -18317,8 +20274,8 @@ class UndertakerFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Undertaker', request='RemoveModel', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Undertaker', request='RemoveModel', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -18332,9 +20289,9 @@ class UndertakerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Undertaker', request='SetStatus', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Undertaker', request='SetStatus', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -18347,9 +20304,9 @@ class UndertakerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Undertaker', request='UpdateStatus', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Undertaker', request='UpdateStatus', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -18362,8 +20319,8 @@ class UndertakerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Undertaker', request='WatchModelResources', version=1, params=params)
+        _params = dict()
+        msg = dict(type='Undertaker', request='WatchModelResources', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -18442,9 +20399,9 @@ class UnitAssignerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='UnitAssigner', request='AssignUnits', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='UnitAssigner', request='AssignUnits', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -18457,9 +20414,9 @@ class UnitAssignerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='UnitAssigner', request='SetAgentStatus', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='UnitAssigner', request='SetAgentStatus', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -18472,8 +20429,8 @@ class UnitAssignerFacade(Type):
         Returns -> typing.Union[typing.Sequence<+T_co>[str], _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='UnitAssigner', request='WatchUnitAssignments', version=1, params=params)
+        _params = dict()
+        msg = dict(type='UnitAssigner', request='WatchUnitAssignments', version=1, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -18821,6 +20778,8 @@ class UniterFacade(Type):
                                                       'provider-space-id': {'type': 'string'},
                                                       'provider-subnet-id': {'type': 'string'},
                                                       'provider-vlan-id': {'type': 'string'},
+                                                      'routes': {'items': {'$ref': '#/definitions/NetworkRoute'},
+                                                                 'type': 'array'},
                                                       'vlan-tag': {'type': 'integer'}},
                                        'required': ['device-index',
                                                     'mac-address',
@@ -18837,6 +20796,14 @@ class UniterFacade(Type):
                                                     'interface-type',
                                                     'disabled'],
                                        'type': 'object'},
+                     'NetworkRoute': {'additionalProperties': False,
+                                      'properties': {'destination-cidr': {'type': 'string'},
+                                                     'gateway-ip': {'type': 'string'},
+                                                     'metric': {'type': 'integer'}},
+                                      'required': ['destination-cidr',
+                                                   'gateway-ip',
+                                                   'metric'],
+                                      'type': 'object'},
                      'NotifyWatchResult': {'additionalProperties': False,
                                            'properties': {'NotifyWatcherId': {'type': 'string'},
                                                           'error': {'$ref': '#/definitions/Error'}},
@@ -19317,8 +21284,8 @@ class UniterFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), typing.Sequence<+T_co>[str]]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='APIAddresses', version=4, params=params)
+        _params = dict()
+        msg = dict(type='Uniter', request='APIAddresses', version=4, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -19332,8 +21299,8 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~HostPort]<~HostPort>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='APIHostPorts', version=4, params=params)
+        _params = dict()
+        msg = dict(type='Uniter', request='APIHostPorts', version=4, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -19347,9 +21314,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ActionResult]<~ActionResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='Actions', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='Actions', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19362,9 +21329,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='AddMetricBatches', version=4, params=params)
-        params['batches'] = batches
+        _params = dict()
+        msg = dict(type='Uniter', request='AddMetricBatches', version=4, params=_params)
+        _params['batches'] = batches
         reply = await self.rpc(msg)
         return reply
 
@@ -19377,9 +21344,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='AddUnitStorage', version=4, params=params)
-        params['storages'] = storages
+        _params = dict()
+        msg = dict(type='Uniter', request='AddUnitStorage', version=4, params=_params)
+        _params['storages'] = storages
         reply = await self.rpc(msg)
         return reply
 
@@ -19392,9 +21359,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~MachinePortsResult]<~MachinePortsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='AllMachinePorts', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='AllMachinePorts', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19407,9 +21374,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ApplicationStatusResult]<~ApplicationStatusResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='ApplicationStatus', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='ApplicationStatus', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19422,9 +21389,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringResult]<~StringResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='AssignedMachine', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='AssignedMachine', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19437,9 +21404,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringResult]<~StringResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='AvailabilityZone', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='AvailabilityZone', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19452,9 +21419,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='BeginActions', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='BeginActions', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19467,8 +21434,8 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[int]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='CACert', version=4, params=params)
+        _params = dict()
+        msg = dict(type='Uniter', request='CACert', version=4, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -19482,9 +21449,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringResult]<~StringResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='CharmArchiveSha256', version=4, params=params)
-        params['urls'] = urls
+        _params = dict()
+        msg = dict(type='Uniter', request='CharmArchiveSha256', version=4, params=_params)
+        _params['urls'] = urls
         reply = await self.rpc(msg)
         return reply
 
@@ -19497,9 +21464,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~IntResult]<~IntResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='CharmModifiedVersion', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='CharmModifiedVersion', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19512,9 +21479,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringBoolResult]<~StringBoolResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='CharmURL', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='CharmURL', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19527,9 +21494,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='ClearResolved', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='ClearResolved', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19542,9 +21509,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='ClosePorts', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='ClosePorts', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19557,9 +21524,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ConfigSettingsResult]<~ConfigSettingsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='ConfigSettings', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='ConfigSettings', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19572,8 +21539,8 @@ class UniterFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='CurrentModel', version=4, params=params)
+        _params = dict()
+        msg = dict(type='Uniter', request='CurrentModel', version=4, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -19587,9 +21554,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='Destroy', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='Destroy', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19602,9 +21569,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='DestroyAllSubordinates', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='DestroyAllSubordinates', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19617,9 +21584,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='DestroyUnitStorageAttachments', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='DestroyUnitStorageAttachments', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19632,9 +21599,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='EnsureDead', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='EnsureDead', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19647,9 +21614,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='EnterScope', version=4, params=params)
-        params['relation-units'] = relation_units
+        _params = dict()
+        msg = dict(type='Uniter', request='EnterScope', version=4, params=_params)
+        _params['relation-units'] = relation_units
         reply = await self.rpc(msg)
         return reply
 
@@ -19662,9 +21629,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='FinishActions', version=4, params=params)
-        params['results'] = results
+        _params = dict()
+        msg = dict(type='Uniter', request='FinishActions', version=4, params=_params)
+        _params['results'] = results
         reply = await self.rpc(msg)
         return reply
 
@@ -19677,9 +21644,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~MeterStatusResult]<~MeterStatusResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='GetMeterStatus', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='GetMeterStatus', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19692,9 +21659,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringBoolResult]<~StringBoolResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='GetPrincipal', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='GetPrincipal', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19707,9 +21674,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~BoolResult]<~BoolResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='HasSubordinates', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='HasSubordinates', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19722,9 +21689,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsResult]<~StringsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='JoinedRelations', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='JoinedRelations', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19737,9 +21704,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='LeaveScope', version=4, params=params)
-        params['relation-units'] = relation_units
+        _params = dict()
+        msg = dict(type='Uniter', request='LeaveScope', version=4, params=_params)
+        _params['relation-units'] = relation_units
         reply = await self.rpc(msg)
         return reply
 
@@ -19752,9 +21719,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~LifeResult]<~LifeResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='Life', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='Life', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19767,9 +21734,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='Merge', version=4, params=params)
-        params['params'] = params
+        _params = dict()
+        msg = dict(type='Uniter', request='Merge', version=4, params=_params)
+        _params['params'] = params
         reply = await self.rpc(msg)
         return reply
 
@@ -19782,8 +21749,8 @@ class UniterFacade(Type):
         Returns -> typing.Mapping<~KT, +VT_co>[str, typing.Any]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='ModelConfig', version=4, params=params)
+        _params = dict()
+        msg = dict(type='Uniter', request='ModelConfig', version=4, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -19797,8 +21764,8 @@ class UniterFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='ModelUUID', version=4, params=params)
+        _params = dict()
+        msg = dict(type='Uniter', request='ModelUUID', version=4, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -19812,9 +21779,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~UnitNetworkConfigResult]<~UnitNetworkConfigResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='NetworkConfig', version=4, params=params)
-        params['args'] = args
+        _params = dict()
+        msg = dict(type='Uniter', request='NetworkConfig', version=4, params=_params)
+        _params['args'] = args
         reply = await self.rpc(msg)
         return reply
 
@@ -19827,9 +21794,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='OpenPorts', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='OpenPorts', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19842,9 +21809,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringResult]<~StringResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='PrivateAddress', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='PrivateAddress', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19857,8 +21824,8 @@ class UniterFacade(Type):
         Returns -> typing.Union[_ForwardRef('Error'), str]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='ProviderType', version=4, params=params)
+        _params = dict()
+        msg = dict(type='Uniter', request='ProviderType', version=4, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -19872,9 +21839,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringResult]<~StringResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='PublicAddress', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='PublicAddress', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19887,9 +21854,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~GetLeadershipSettingsResult]<~GetLeadershipSettingsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='Read', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='Read', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19902,9 +21869,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~SettingsResult]<~SettingsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='ReadRemoteSettings', version=4, params=params)
-        params['relation-unit-pairs'] = relation_unit_pairs
+        _params = dict()
+        msg = dict(type='Uniter', request='ReadRemoteSettings', version=4, params=_params)
+        _params['relation-unit-pairs'] = relation_unit_pairs
         reply = await self.rpc(msg)
         return reply
 
@@ -19917,9 +21884,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~SettingsResult]<~SettingsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='ReadSettings', version=4, params=params)
-        params['relation-units'] = relation_units
+        _params = dict()
+        msg = dict(type='Uniter', request='ReadSettings', version=4, params=_params)
+        _params['relation-units'] = relation_units
         reply = await self.rpc(msg)
         return reply
 
@@ -19932,9 +21899,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~RelationResult]<~RelationResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='Relation', version=4, params=params)
-        params['relation-units'] = relation_units
+        _params = dict()
+        msg = dict(type='Uniter', request='Relation', version=4, params=_params)
+        _params['relation-units'] = relation_units
         reply = await self.rpc(msg)
         return reply
 
@@ -19947,9 +21914,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~RelationResult]<~RelationResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='RelationById', version=4, params=params)
-        params['relation-ids'] = relation_ids
+        _params = dict()
+        msg = dict(type='Uniter', request='RelationById', version=4, params=_params)
+        _params['relation-ids'] = relation_ids
         reply = await self.rpc(msg)
         return reply
 
@@ -19962,9 +21929,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='RemoveStorageAttachments', version=4, params=params)
-        params['ids'] = ids
+        _params = dict()
+        msg = dict(type='Uniter', request='RemoveStorageAttachments', version=4, params=_params)
+        _params['ids'] = ids
         reply = await self.rpc(msg)
         return reply
 
@@ -19977,9 +21944,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='RequestReboot', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='RequestReboot', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -19992,9 +21959,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ResolvedModeResult]<~ResolvedModeResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='Resolved', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='Resolved', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20007,9 +21974,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='SetAgentStatus', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='SetAgentStatus', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20022,9 +21989,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='SetApplicationStatus', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='SetApplicationStatus', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20037,9 +22004,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='SetCharmURL', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='SetCharmURL', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20052,9 +22019,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='SetStatus', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='SetStatus', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20067,9 +22034,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='SetUnitStatus', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='SetUnitStatus', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20082,9 +22049,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='SetWorkloadVersion', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='SetWorkloadVersion', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20097,9 +22064,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~LifeResult]<~LifeResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='StorageAttachmentLife', version=4, params=params)
-        params['ids'] = ids
+        _params = dict()
+        msg = dict(type='Uniter', request='StorageAttachmentLife', version=4, params=_params)
+        _params['ids'] = ids
         reply = await self.rpc(msg)
         return reply
 
@@ -20112,9 +22079,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StorageAttachmentResult]<~StorageAttachmentResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='StorageAttachments', version=4, params=params)
-        params['ids'] = ids
+        _params = dict()
+        msg = dict(type='Uniter', request='StorageAttachments', version=4, params=_params)
+        _params['ids'] = ids
         reply = await self.rpc(msg)
         return reply
 
@@ -20127,9 +22094,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StatusResult]<~StatusResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='UnitStatus', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='UnitStatus', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20142,9 +22109,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StorageAttachmentIdsResult]<~StorageAttachmentIdsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='UnitStorageAttachments', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='UnitStorageAttachments', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20157,9 +22124,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='UpdateSettings', version=4, params=params)
-        params['relation-units'] = relation_units
+        _params = dict()
+        msg = dict(type='Uniter', request='UpdateSettings', version=4, params=_params)
+        _params['relation-units'] = relation_units
         reply = await self.rpc(msg)
         return reply
 
@@ -20172,9 +22139,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='Watch', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='Watch', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20187,8 +22154,8 @@ class UniterFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='WatchAPIHostPorts', version=4, params=params)
+        _params = dict()
+        msg = dict(type='Uniter', request='WatchAPIHostPorts', version=4, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -20202,9 +22169,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsWatchResult]<~StringsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='WatchActionNotifications', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='WatchActionNotifications', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20217,9 +22184,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsWatchResult]<~StringsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='WatchApplicationRelations', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='WatchApplicationRelations', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20232,9 +22199,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='WatchConfigSettings', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='WatchConfigSettings', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20247,8 +22214,8 @@ class UniterFacade(Type):
         Returns -> typing.Union[str, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='WatchForModelConfigChanges', version=4, params=params)
+        _params = dict()
+        msg = dict(type='Uniter', request='WatchForModelConfigChanges', version=4, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -20262,9 +22229,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='WatchLeadershipSettings', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='WatchLeadershipSettings', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20277,9 +22244,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='WatchMeterStatus', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='WatchMeterStatus', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20292,9 +22259,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~RelationUnitsWatchResult]<~RelationUnitsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='WatchRelationUnits', version=4, params=params)
-        params['relation-units'] = relation_units
+        _params = dict()
+        msg = dict(type='Uniter', request='WatchRelationUnits', version=4, params=_params)
+        _params['relation-units'] = relation_units
         reply = await self.rpc(msg)
         return reply
 
@@ -20307,9 +22274,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='WatchStorageAttachments', version=4, params=params)
-        params['ids'] = ids
+        _params = dict()
+        msg = dict(type='Uniter', request='WatchStorageAttachments', version=4, params=_params)
+        _params['ids'] = ids
         reply = await self.rpc(msg)
         return reply
 
@@ -20322,9 +22289,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='WatchUnitAddresses', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='WatchUnitAddresses', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20337,9 +22304,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringsWatchResult]<~StringsWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='WatchUnitStorageAttachments', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='WatchUnitStorageAttachments', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20352,9 +22319,9 @@ class UniterFacade(Type):
         Returns -> typing.Sequence<+T_co>[~StringResult]<~StringResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Uniter', request='WorkloadVersion', version=4, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Uniter', request='WorkloadVersion', version=4, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20483,9 +22450,9 @@ class UpgraderFacade(Type):
         Returns -> typing.Sequence<+T_co>[~VersionResult]<~VersionResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Upgrader', request='DesiredVersion', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Upgrader', request='DesiredVersion', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20498,9 +22465,9 @@ class UpgraderFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Upgrader', request='SetTools', version=1, params=params)
-        params['agent-tools'] = agent_tools
+        _params = dict()
+        msg = dict(type='Upgrader', request='SetTools', version=1, params=_params)
+        _params['agent-tools'] = agent_tools
         reply = await self.rpc(msg)
         return reply
 
@@ -20513,9 +22480,9 @@ class UpgraderFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ToolsResult]<~ToolsResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Upgrader', request='Tools', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Upgrader', request='Tools', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20528,9 +22495,9 @@ class UpgraderFacade(Type):
         Returns -> typing.Sequence<+T_co>[~NotifyWatchResult]<~NotifyWatchResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='Upgrader', request='WatchAPIVersion', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='Upgrader', request='WatchAPIVersion', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20598,15 +22565,6 @@ class UserManagerFacade(Type):
                                       'required': ['results'],
                                       'type': 'object'},
                      'Macaroon': {'additionalProperties': False, 'type': 'object'},
-                     'MacaroonResult': {'additionalProperties': False,
-                                        'properties': {'error': {'$ref': '#/definitions/Error'},
-                                                       'result': {'$ref': '#/definitions/Macaroon'}},
-                                        'type': 'object'},
-                     'MacaroonResults': {'additionalProperties': False,
-                                         'properties': {'results': {'items': {'$ref': '#/definitions/MacaroonResult'},
-                                                                    'type': 'array'}},
-                                         'required': ['results'],
-                                         'type': 'object'},
                      'UserInfo': {'additionalProperties': False,
                                   'properties': {'access': {'type': 'string'},
                                                  'created-by': {'type': 'string'},
@@ -20643,9 +22601,6 @@ class UserManagerFacade(Type):
      'properties': {'AddUser': {'properties': {'Params': {'$ref': '#/definitions/AddUsers'},
                                                'Result': {'$ref': '#/definitions/AddUserResults'}},
                                 'type': 'object'},
-                    'CreateLocalLoginMacaroon': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
-                                                                'Result': {'$ref': '#/definitions/MacaroonResults'}},
-                                                 'type': 'object'},
                     'DisableUser': {'properties': {'Params': {'$ref': '#/definitions/Entities'},
                                                    'Result': {'$ref': '#/definitions/ErrorResults'}},
                                     'type': 'object'},
@@ -20671,24 +22626,9 @@ class UserManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~AddUserResult]<~AddUserResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='UserManager', request='AddUser', version=1, params=params)
-        params['users'] = users
-        reply = await self.rpc(msg)
-        return reply
-
-
-
-    @ReturnMapping(MacaroonResults)
-    async def CreateLocalLoginMacaroon(self, entities):
-        '''
-        entities : typing.Sequence<+T_co>[~Entity]<~Entity>
-        Returns -> typing.Sequence<+T_co>[~MacaroonResult]<~MacaroonResult>
-        '''
-        # map input types to rpc msg
-        params = dict()
-        msg = dict(type='UserManager', request='CreateLocalLoginMacaroon', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='UserManager', request='AddUser', version=1, params=_params)
+        _params['users'] = users
         reply = await self.rpc(msg)
         return reply
 
@@ -20701,9 +22641,9 @@ class UserManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='UserManager', request='DisableUser', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='UserManager', request='DisableUser', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20716,9 +22656,9 @@ class UserManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='UserManager', request='EnableUser', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='UserManager', request='EnableUser', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20731,9 +22671,9 @@ class UserManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='UserManager', request='RemoveUser', version=1, params=params)
-        params['entities'] = entities
+        _params = dict()
+        msg = dict(type='UserManager', request='RemoveUser', version=1, params=_params)
+        _params['entities'] = entities
         reply = await self.rpc(msg)
         return reply
 
@@ -20746,9 +22686,9 @@ class UserManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~ErrorResult]<~ErrorResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='UserManager', request='SetPassword', version=1, params=params)
-        params['changes'] = changes
+        _params = dict()
+        msg = dict(type='UserManager', request='SetPassword', version=1, params=_params)
+        _params['changes'] = changes
         reply = await self.rpc(msg)
         return reply
 
@@ -20762,10 +22702,10 @@ class UserManagerFacade(Type):
         Returns -> typing.Sequence<+T_co>[~UserInfoResult]<~UserInfoResult>
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='UserManager', request='UserInfo', version=1, params=params)
-        params['entities'] = entities
-        params['include-disabled'] = include_disabled
+        _params = dict()
+        msg = dict(type='UserManager', request='UserInfo', version=1, params=_params)
+        _params['entities'] = entities
+        _params['include-disabled'] = include_disabled
         reply = await self.rpc(msg)
         return reply
 
@@ -20811,8 +22751,8 @@ class VolumeAttachmentsWatcherFacade(Type):
         Returns -> typing.Union[typing.Sequence<+T_co>[~MachineStorageId]<~MachineStorageId>, _ForwardRef('Error')]
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='VolumeAttachmentsWatcher', request='Next', version=2, params=params)
+        _params = dict()
+        msg = dict(type='VolumeAttachmentsWatcher', request='Next', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply
@@ -20826,8 +22766,8 @@ class VolumeAttachmentsWatcherFacade(Type):
         Returns -> None
         '''
         # map input types to rpc msg
-        params = dict()
-        msg = dict(type='VolumeAttachmentsWatcher', request='Stop', version=2, params=params)
+        _params = dict()
+        msg = dict(type='VolumeAttachmentsWatcher', request='Stop', version=2, params=_params)
 
         reply = await self.rpc(msg)
         return reply