Puppet Class: octavia::keystone::auth

Defined in:
manifests/keystone/auth.pp

Overview

Class: octavia::keystone::auth

Configures octavia user, service and endpoint in Keystone.

Parameters

password

(Required) Password for octavia user.

auth_name

(Optional) Username for octavia service. Defaults to ‘octavia’.

email

(Optional) Email for octavia user. Defaults to ‘octavia@localhost’.

tenant

(Optional) Tenant for octavia user. Defaults to ‘services’.

roles

(Optional) List of roles assigned to octavia user. Defaults to [‘admin’, ‘service’]

system_scope

(Optional) Scope for system operations. Defaults to ‘all’

system_roles

(Optional) List of system roles assigned to octavia user. Defaults to []

configure_endpoint

(Optional) Should octavia endpoint be configured? Defaults to true.

configure_user

(Optional) Should the service user be configured? Defaults to true.

configure_user_role

(Optional) Should the admin role be configured for the service user? Defaults to true.

configure_service

(Optional) Should the service be configurd? Defaults to True

service_type

(Optional) Type of service. Defaults to ‘load-balancer’.

region

(Optional) Region for endpoint. Defaults to ‘RegionOne’.

service_name

(Optional) Name of the service. Defaults to ‘octavia’

service_description

(Optional) Description of the service. Default to ‘OpenStack Load Balancing Service’

public_url

(Optional) The endpoint’s public url. This url should not contain any trailing ‘/’. Defaults to ‘127.0.0.1:9876

admin_url

(Optional) The endpoint’s admin url. This url should not contain any trailing ‘/’. Defaults to ‘127.0.0.1:9876

internal_url

(Optional) The endpoint’s internal url. This url should not contain any trailing ‘/’. Defaults to ‘127.0.0.1:9876

Parameters:

  • password (String[1])
  • auth_name (String[1]) (defaults to: 'octavia')
  • email (String[1]) (defaults to: 'octavia@localhost')
  • tenant (String[1]) (defaults to: 'services')
  • roles (Array[String[1]]) (defaults to: ['admin', 'service'])
  • system_scope (String[1]) (defaults to: 'all')
  • system_roles (Array[String[1]]) (defaults to: [])
  • configure_endpoint (Boolean) (defaults to: true)
  • configure_user (Boolean) (defaults to: true)
  • configure_user_role (Boolean) (defaults to: true)
  • configure_service (Boolean) (defaults to: true)
  • service_description (String[1]) (defaults to: 'OpenStack Load Balancing Service')
  • service_name (String[1]) (defaults to: 'octavia')
  • service_type (String[1]) (defaults to: 'load-balancer')
  • region (String[1]) (defaults to: 'RegionOne')
  • public_url (Keystone::PublicEndpointUrl) (defaults to: 'http://127.0.0.1:9876')
  • admin_url (Keystone::EndpointUrl) (defaults to: 'http://127.0.0.1:9876')
  • internal_url (Keystone::EndpointUrl) (defaults to: 'http://127.0.0.1:9876')


81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
# File 'manifests/keystone/auth.pp', line 81

class octavia::keystone::auth (
  String[1] $password,
  String[1] $auth_name                    = 'octavia',
  String[1] $email                        = 'octavia@localhost',
  String[1] $tenant                       = 'services',
  Array[String[1]] $roles                 = ['admin', 'service'],
  String[1] $system_scope                 = 'all',
  Array[String[1]] $system_roles          = [],
  Boolean $configure_endpoint             = true,
  Boolean $configure_user                 = true,
  Boolean $configure_user_role            = true,
  Boolean $configure_service              = true,
  String[1] $service_description          = 'OpenStack Load Balancing Service',
  String[1] $service_name                 = 'octavia',
  String[1] $service_type                 = 'load-balancer',
  String[1] $region                       = 'RegionOne',
  Keystone::PublicEndpointUrl $public_url = 'http://127.0.0.1:9876',
  Keystone::EndpointUrl $admin_url        = 'http://127.0.0.1:9876',
  Keystone::EndpointUrl $internal_url     = 'http://127.0.0.1:9876',
) {
  include octavia::deps

  Keystone::Resource::Service_identity['octavia'] -> Anchor['octavia::service::end']

  keystone::resource::service_identity { 'octavia':
    configure_user      => $configure_user,
    configure_user_role => $configure_user_role,
    configure_endpoint  => $configure_endpoint,
    configure_service   => $configure_service,
    service_name        => $service_name,
    service_type        => $service_type,
    service_description => $service_description,
    region              => $region,
    auth_name           => $auth_name,
    password            => $password,
    email               => $email,
    tenant              => $tenant,
    roles               => $roles,
    system_scope        => $system_scope,
    system_roles        => $system_roles,
    public_url          => $public_url,
    internal_url        => $internal_url,
    admin_url           => $admin_url,
  }
}