f40169327b
Instead of using user's auth token (which can expire) for interactions with other services engine creates Keystone trust that impersonate user and create new tokens on demand. Heat stack is created on deployment start using token rather than trust so that Heat could establish trust of its own (trusts cannot be chained). New behavior is disabled by default and can be enabled using [engine]/use_trusts = True in murano.conf. With trusts enabled engine will not work with Heat prior to Juno. For Heat stacks with deferred actions or long deployment time to work it is also required to turn on trusts in Heat itself. This can be done via [DEFAULT]/deferred_auth_method=trusts in heat.conf and ensuring that current user has heat_stack_owner role (or any other that is in [DEFAULT]/trusts_delegated_roles=trusts in heat.conf) Change-Id: Ic9f3f956ddb6ff2a300a08056ee841cf3c0db870 Implements: blueprint auth-for-long-running-requests
75 lines
1.9 KiB
YAML
75 lines
1.9 KiB
YAML
Namespaces:
|
|
=: io.murano
|
|
res: io.murano.resources
|
|
sys: io.murano.system
|
|
|
|
Name: Environment
|
|
|
|
Properties:
|
|
name:
|
|
Contract: $.string().notNull()
|
|
|
|
applications:
|
|
Contract: [$.class(Application).owned().notNull()]
|
|
|
|
agentListener:
|
|
Contract: $.class(sys:AgentListener)
|
|
Usage: Runtime
|
|
|
|
stack:
|
|
Contract: $.class(sys:HeatStack)
|
|
Usage: Runtime
|
|
|
|
instanceNotifier:
|
|
Contract: $.class(sys:InstanceNotifier)
|
|
Usage: Runtime
|
|
|
|
defaultNetworks:
|
|
Contract:
|
|
environment: $.class(res:Network)
|
|
flat: $.class(res:Network)
|
|
Usage: In
|
|
|
|
securityGroupManager:
|
|
Contract: $.class(sys:SecurityGroupManager)
|
|
Usage: Runtime
|
|
|
|
reporter:
|
|
Contract: $.class(sys:StatusReporter)
|
|
Usage: Runtime
|
|
|
|
Methods:
|
|
initialize:
|
|
Body:
|
|
- $generatedEnvironmentName: $.getAttr(generatedEnvironmentName)
|
|
- If: $generatedEnvironmentName = null
|
|
Then:
|
|
- $generatedEnvironmentName: randomName()
|
|
- $.setAttr(generatedEnvironmentName, $generatedEnvironmentName)
|
|
- $this.agentListener: new(sys:AgentListener, name => $generatedEnvironmentName)
|
|
- $stackDescriptionFormat: 'This stack was generated by Murano for environment {0} (ID: {1})'
|
|
- $this.stack: new(sys:HeatStack,
|
|
name => 'murano-' + $generatedEnvironmentName,
|
|
description => $stackDescriptionFormat.format($.name, $.id()))
|
|
- $this.instanceNotifier: new(sys:InstanceNotifier, environment => $this)
|
|
- $this.reporter: new(sys:StatusReporter, environment => $this)
|
|
- $this.securityGroupManager: new(sys:SecurityGroupManager, environment => $this)
|
|
|
|
|
|
deploy:
|
|
Usage: Action
|
|
Body:
|
|
- $minimalStack:
|
|
resources: {}
|
|
- $.stack.updateTemplate($minimalStack)
|
|
- $.stack.push()
|
|
- Try:
|
|
- $.agentListener.start()
|
|
- $.applications.pselect($.deploy())
|
|
Finally:
|
|
- $.agentListener.stop()
|
|
|
|
destroy:
|
|
Body:
|
|
- $.stack.delete()
|