Puppet Class: keystone

Inherits:
keystone::params
Defined in:
manifests/init.pp

Overview

Module for managing keystone config.

Parameters

package_ensure

(Optional) Desired ensure state of packages. accepts latest or specific versions. Defaults to present.

client_package_ensure

(Optional) Desired ensure state of the client package. accepts latest or specific versions. Defaults to present.

catalog_driver

(Optional) Catalog driver used by Keystone to store endpoints and services. Defaults to false.

catalog_template_file

(Optional) Path to the catalog used if ‘templated’ catalog driver is used. Defaults to ‘/etc/keystone/default_catalog.templates’

token_provider

(Optional) Format keystone uses for tokens. Defaults to ‘fernet’ Supports fernet or uuid.

token_expiration

(Optional) Amount of time a token should remain valid (seconds). Defaults to 3600 (1 hour).

password_hash_algorithm

(Optional) The password hash algorithm to use. Defaults to $::os_service_default

password_hash_rounds

(Optional) The amount of rounds to do on the hash. Defaults to $::os_service_default

revoke_driver

(Optional) Driver for token revocation. Defaults to $::os_service_default

revoke_by_id

(Optional) Revoke token by token identifier. Setting revoke_by_id to true enables various forms of enumerating tokens. These enumerations are processed to determine the list of tokens to revoke. Only disable if you are switching to using the Revoke extension with a backend other than KVS, which stores events in memory. Defaults to true.

manage_service

(Optional) If Puppet should manage service startup / shutdown. Defaults to true.

enabled

(Optional) If the keystone services should be enabled. Default to true.

default_transport_url

(Optional) A URL representing the messaging driver to use and its full configuration. Transport URLs take the form:

transport://user:pass@host1:port[,hostN:portN]/virtual_host

Defaults to $::os_service_default

rabbit_ha_queues

(Optional) Use HA queues in RabbitMQ. Defaults to $::os_service_default

rabbit_heartbeat_timeout_threshold

(Optional) Number of seconds after which the RabbitMQ broker is considered down if the heartbeat keepalive fails. Any value >0 enables heartbeats. Heartbeating helps to ensure the TCP connection to RabbitMQ isn’t silently closed, resulting in missed or lost messages from the queue. (Requires kombu >= 3.0.7 and amqp >= 1.4.0) Defaults to $::os_service_default

rabbit_heartbeat_rate

(Optional) How often during the rabbit_heartbeat_timeout_threshold period to check the heartbeat on RabbitMQ connection. (i.e. rabbit_heartbeat_rate=2 when rabbit_heartbeat_timeout_threshold=60, the heartbeat will be checked every 30 seconds. Defaults to $::os_service_default

rabbit_heartbeat_in_pthread

(Optional) EXPERIMENTAL: Run the health check heartbeat thread through a native python thread. By default if this option isn’t provided the health check heartbeat will inherit the execution model from the parent process. By example if the parent process have monkey patched the stdlib by using eventlet/greenlet then the heartbeat will be run through a green thread. Defaults to $::os_service_default

rabbit_use_ssl

(Optional) Connect over SSL for RabbitMQ Defaults to $::os_service_default

kombu_ssl_ca_certs

(Optional) SSL certification authority file (valid only if SSL enabled). Defaults to $::os_service_default

kombu_ssl_certfile

(Optional) SSL cert file (valid only if SSL enabled). Defaults to $::os_service_default

kombu_ssl_keyfile

(Optional) SSL key file (valid only if SSL enabled). Defaults to $::os_service_default

kombu_ssl_version

(Optional) SSL version to use (valid only if SSL enabled). Valid values are TLSv1, SSLv23 and SSLv3. SSLv2 may be available on some distributions. Defaults to $::os_service_default

kombu_reconnect_delay

(Optional) How long to wait before reconnecting in response to an AMQP consumer cancel notification. (floating point value) Defaults to $::os_service_default

kombu_failover_strategy

(Optional) Determines how the next RabbitMQ node is chosen in case the one we are currently connected to becomes unavailable. Takes effect only if more than one RabbitMQ node is provided in config. (string value) Defaults to $::os_service_default

kombu_compression

(Optional) Possible values are: gzip, bz2. If not set compression will not be used. This option may notbe available in future versions. EXPERIMENTAL. (string value) Defaults to $::os_service_default

notification_transport_url

(Optional) A URL representing the messaging driver to use for notifications and its full configuration. Transport URLs take the form:

transport://user:pass@host1:port[,hostN:portN]/virtual_host

Defaults to $::os_service_default

notification_driver

RPC driver. Not enabled by default (list value) Defaults to $::os_service_default

notification_topics

(Optional) AMQP topics to publish to when using the RPC notification driver. (list value) Default to $::os_service_default

notification_format

(Optional) Define the notification format for identity service events. Valid values are ‘basic’ and ‘cadf’. Default to $::os_service_default

notification_opt_out

(Optional) Opt out notifications that match the patterns expressed in this list. Defaults to $::os_service_default

control_exchange

(Optional) AMQP exchange to connect to if using RabbitMQ (string value) Default to $::os_service_default

rpc_response_timeout

(Optional) Seconds to wait for a response from a call. Defaults to $::os_service_default

public_endpoint

(Optional) The base public endpoint URL for keystone that are advertised to clients (NOTE: this does NOT affect how keystone listens for connections) (string value) Defaults to $::os_service_default

service_name

(Optional) Name of the service that will be providing the server functionality of keystone. For example, the default is just ‘keystone’, which means keystone will be run as a standalone service, and will able to be managed separately by the operating system’s service manager. For example, under Red Hat based systems, you will be able to use: systemctl restart openstack-keystone to restart the service. Under Debian, which uses uwsgi (as opposed to eventlet), the service name is simply keystone, so this will work: systemctl restart keystone If the value is ‘httpd’, this means keystone will be a web service, and you must use another class to configure that web service. After calling class ‘keystone’… use class { ‘keystone::wsgi::apache’…} to make keystone be a web app using apache mod_wsgi. Defaults to ‘$::keystone::params::service_name’

max_token_size

(Optional) maximum allowable Keystone token size Defaults to $::os_service_default

sync_db

(Optional) Run db sync on the node. Defaults to true

enable_fernet_setup

(Optional) Setup keystone for fernet tokens. This is typically only run on a single node, then the keys are replicated to the other nodes in a cluster. You would typically also pair this with a fernet token provider setting. Defaults to true

fernet_key_repository

(Optional) Location for the fernet key repository. This value must be set if enable_fernet_setup is set to true. Defaults to ‘/etc/keystone/fernet-keys’

fernet_max_active_keys

(Optional) Number of maximum active Fernet keys. Integer > 0. Defaults to $::os_service_default

fernet_keys

(Optional) Hash of Keystone fernet keys If you enable this parameter, make sure enable_fernet_setup is set to True. Example of valid value: fernet_keys:

/etc/keystone/fernet-keys/0:
  content: c_aJfy6At9y-toNS9SF1NQMTSkSzQ-OBYeYulTqKsWU=
/etc/keystone/fernet-keys/1:
  content: zx0hNG7CStxFz5KXZRsf7sE4lju0dLYvXdGDIKGcd7k=

Puppet will create a file per key in $fernet_key_repository. Note: defaults to false so keystone-manage fernet_setup will be executed. Otherwise Puppet will manage keys with File resource. Defaults to false

fernet_replace_keys

(Optional) Whether or not to replace the fernet keys if they are already in the filesystem Defaults to true

enable_credential_setup

(Optional) Setup keystone for credentials. In a cluster environment where multiple Keystone nodes are running, you might need the same keys everywhere; so you’ll have to set credential_keys parameter in order to let Puppet manage Keystone keys in a consistent way, otherwise keystone-manage will generate different set of keys on keystone nodes and the service won’t work. Defaults to False

credential_key_repository

(Optional) Location for the Credential key repository. This value must be set if enable_credential_setup is set to true. Defaults to ‘/etc/keystone/credential-keys’

credential_keys

(Optional) Hash of Keystone credential keys If you enable this parameter, make sure enable_credential_setup is set to True. Example of valid value: credential_keys:

/etc/keystone/credential-keys/0:
  content: t-WdduhORSqoyAykuqWAQSYjg2rSRuJYySgI2xh48CI=
/etc/keystone/credential-keys/1:
  content: GLlnyygEVJP4-H2OMwClXn3sdSQUZsM5F194139Unv8=

Puppet will create a file per key in $credential_key_repository. Note: defaults to false so keystone-manage credential_setup will be executed. Otherwise Puppet will manage keys with File resource. Defaults to false

default_domain

(Optional) When Keystone v3 support is enabled, v2 clients will need to have a domain assigned for certain operations. For example, doing a user create operation must have a domain associated with it. This is the domain which will be used if a domain is needed and not explicitly set in the request. Using this means that you will have to add it to every user/tenant/user_role you create, as without a domain qualification those resources goes into “Default” domain. See README. Defaults to undef (will use built-in Keystone default)

policy_driver

Policy backend driver. (string value) Defaults to $::os_service_default.

using_domain_config

(Optional) Eases the use of the keystone_domain_config resource type. It ensures that a directory for holding the domain configuration is present and the associated configuration in keystone.conf is set up right. Defaults to false

domain_config_directory

(Optional) Specify a domain configuration directory. For this to work the using_domain_config must be set to true. Raise an error if it’s not the case. Defaults to ‘/etc/keystone/domains’

keystone_user

(Optional) Specify the keystone system user to be used with keystone-manage. Defaults to $::keystone::params::user

keystone_group

(Optional) Specify the keystone system group to be used with keystone-manage. Defaults to $::keystone::params::group

manage_policyrcd

(Optional) Whether to manage the policy-rc.d on debian based systems to prevent keystone eventlet and apache from auto-starting on package install. Defaults to false

enable_proxy_headers_parsing

(Optional) Enable oslo middleware to parse proxy headers. Defaults to $::os_service_default.

max_request_body_size

(Optional) Set max request body size Defaults to $::os_service_default.

purge_config

(Optional) Whether to set only the specified config options in the keystone config. Defaults to false.

amqp_durable_queues

(Optional) Whether to use durable queues in AMQP. Defaults to $::os_service_default.

DEPRECATED PARAMETERS

catalog_type

(Optional) Type of catalog that keystone uses to store endpoints, services. This accepts sql or template. Defaults to undef.

log_dir

(Optional) Directory where logs should be stored If set to $::os_service_default, it will not log to any directory Defaults to undef.

log_file

(Optional) Where to log Defaults to undef.

enable_ssl

(Optional) Toggle for SSL support on the keystone eventlet servers. (boolean value) Defaults to undef

ssl_certfile

(Optional) Path of the certfile for SSL. (string value) Defaults to undef

ssl_keyfile

(Optional) Path of the keyfile for SSL. (string value) Defaults to undef

ssl_ca_certs

(Optional) Path of the ca cert file for SSL. (string value) Defaults to undef

ssl_ca_key

(Optional) Path of the CA key file for SSL (string value) Defaults to undef

ssl_cert_subject

(Optional) SSL Certificate Subject (auto generated certificate) (string value) Defaults to undef

Authors

Dan Bode dan@puppetlabs.com

Copyright 2012 Puppetlabs Inc, unless otherwise noted.

Parameters:

  • package_ensure (Any) (defaults to: 'present')
  • client_package_ensure (Any) (defaults to: 'present')
  • catalog_driver (Any) (defaults to: false)
  • catalog_template_file (Any) (defaults to: '/etc/keystone/default_catalog.templates')
  • token_provider (Any) (defaults to: 'fernet')
  • token_expiration (Any) (defaults to: 3600)
  • password_hash_algorithm (Any) (defaults to: $::os_service_default)
  • password_hash_rounds (Any) (defaults to: $::os_service_default)
  • revoke_driver (Any) (defaults to: $::os_service_default)
  • revoke_by_id (Any) (defaults to: true)
  • public_endpoint (Any) (defaults to: $::os_service_default)
  • manage_service (Any) (defaults to: true)
  • enabled (Any) (defaults to: true)
  • rabbit_heartbeat_timeout_threshold (Any) (defaults to: $::os_service_default)
  • rabbit_heartbeat_rate (Any) (defaults to: $::os_service_default)
  • rabbit_heartbeat_in_pthread (Any) (defaults to: $::os_service_default)
  • rabbit_use_ssl (Any) (defaults to: $::os_service_default)
  • default_transport_url (Any) (defaults to: $::os_service_default)
  • rabbit_ha_queues (Any) (defaults to: $::os_service_default)
  • kombu_ssl_ca_certs (Any) (defaults to: $::os_service_default)
  • kombu_ssl_certfile (Any) (defaults to: $::os_service_default)
  • kombu_ssl_keyfile (Any) (defaults to: $::os_service_default)
  • kombu_ssl_version (Any) (defaults to: $::os_service_default)
  • kombu_reconnect_delay (Any) (defaults to: $::os_service_default)
  • kombu_failover_strategy (Any) (defaults to: $::os_service_default)
  • kombu_compression (Any) (defaults to: $::os_service_default)
  • notification_transport_url (Any) (defaults to: $::os_service_default)
  • notification_driver (Any) (defaults to: $::os_service_default)
  • notification_topics (Any) (defaults to: $::os_service_default)
  • notification_format (Any) (defaults to: $::os_service_default)
  • notification_opt_out (Any) (defaults to: $::os_service_default)
  • control_exchange (Any) (defaults to: $::os_service_default)
  • rpc_response_timeout (Any) (defaults to: $::os_service_default)
  • service_name (Any) (defaults to: $::keystone::params::service_name)
  • max_token_size (Any) (defaults to: $::os_service_default)
  • sync_db (Any) (defaults to: true)
  • enable_fernet_setup (Any) (defaults to: true)
  • fernet_key_repository (Any) (defaults to: '/etc/keystone/fernet-keys')
  • fernet_max_active_keys (Any) (defaults to: $::os_service_default)
  • fernet_keys (Any) (defaults to: false)
  • fernet_replace_keys (Any) (defaults to: true)
  • enable_credential_setup (Any) (defaults to: true)
  • credential_key_repository (Any) (defaults to: '/etc/keystone/credential-keys')
  • credential_keys (Any) (defaults to: false)
  • default_domain (Any) (defaults to: undef)
  • policy_driver (Any) (defaults to: $::os_service_default)
  • using_domain_config (Any) (defaults to: false)
  • domain_config_directory (Any) (defaults to: '/etc/keystone/domains')
  • keystone_user (Any) (defaults to: $::keystone::params::user)
  • keystone_group (Any) (defaults to: $::keystone::params::group)
  • manage_policyrcd (Any) (defaults to: false)
  • enable_proxy_headers_parsing (Any) (defaults to: $::os_service_default)
  • max_request_body_size (Any) (defaults to: $::os_service_default)
  • purge_config (Any) (defaults to: false)
  • amqp_durable_queues (Any) (defaults to: $::os_service_default)
  • catalog_type (Any) (defaults to: undef)
  • log_dir (Any) (defaults to: undef)
  • log_file (Any) (defaults to: undef)
  • enable_ssl (Any) (defaults to: undef)
  • ssl_certfile (Any) (defaults to: undef)
  • ssl_keyfile (Any) (defaults to: undef)
  • ssl_ca_certs (Any) (defaults to: undef)
  • ssl_ca_key (Any) (defaults to: undef)
  • ssl_cert_subject (Any) (defaults to: undef)


371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
# File 'manifests/init.pp', line 371

class keystone(
  $package_ensure                       = 'present',
  $client_package_ensure                = 'present',
  $catalog_driver                       = false,
  $catalog_template_file                = '/etc/keystone/default_catalog.templates',
  $token_provider                       = 'fernet',
  $token_expiration                     = 3600,
  $password_hash_algorithm              = $::os_service_default,
  $password_hash_rounds                 = $::os_service_default,
  $revoke_driver                        = $::os_service_default,
  $revoke_by_id                         = true,
  $public_endpoint                      = $::os_service_default,
  $manage_service                       = true,
  $enabled                              = true,
  $rabbit_heartbeat_timeout_threshold   = $::os_service_default,
  $rabbit_heartbeat_rate                = $::os_service_default,
  $rabbit_heartbeat_in_pthread          = $::os_service_default,
  $rabbit_use_ssl                       = $::os_service_default,
  $default_transport_url                = $::os_service_default,
  $rabbit_ha_queues                     = $::os_service_default,
  $kombu_ssl_ca_certs                   = $::os_service_default,
  $kombu_ssl_certfile                   = $::os_service_default,
  $kombu_ssl_keyfile                    = $::os_service_default,
  $kombu_ssl_version                    = $::os_service_default,
  $kombu_reconnect_delay                = $::os_service_default,
  $kombu_failover_strategy              = $::os_service_default,
  $kombu_compression                    = $::os_service_default,
  $notification_transport_url           = $::os_service_default,
  $notification_driver                  = $::os_service_default,
  $notification_topics                  = $::os_service_default,
  $notification_format                  = $::os_service_default,
  $notification_opt_out                 = $::os_service_default,
  $control_exchange                     = $::os_service_default,
  $rpc_response_timeout                 = $::os_service_default,
  $service_name                         = $::keystone::params::service_name,
  $max_token_size                       = $::os_service_default,
  $sync_db                              = true,
  $enable_fernet_setup                  = true,
  $fernet_key_repository                = '/etc/keystone/fernet-keys',
  $fernet_max_active_keys               = $::os_service_default,
  $fernet_keys                          = false,
  $fernet_replace_keys                  = true,
  $enable_credential_setup              = true,
  $credential_key_repository            = '/etc/keystone/credential-keys',
  $credential_keys                      = false,
  $default_domain                       = undef,
  $policy_driver                        = $::os_service_default,
  $using_domain_config                  = false,
  $domain_config_directory              = '/etc/keystone/domains',
  $keystone_user                        = $::keystone::params::user,
  $keystone_group                       = $::keystone::params::group,
  $manage_policyrcd                     = false,
  $enable_proxy_headers_parsing         = $::os_service_default,
  $max_request_body_size                = $::os_service_default,
  $purge_config                         = false,
  $amqp_durable_queues                  = $::os_service_default,
  # DEPRECATED PARAMETERS
  $catalog_type                         = undef,
  $log_dir                              = undef,
  $log_file                             = undef,
  $enable_ssl                           = undef,
  $ssl_certfile                         = undef,
  $ssl_keyfile                          = undef,
  $ssl_ca_certs                         = undef,
  $ssl_ca_key                           = undef,
  $ssl_cert_subject                     = undef,
) inherits keystone::params {

  include keystone::deps
  include keystone::logging
  include keystone::policy

  if $catalog_type != undef {
    warning('The catalog_type parameter is deprecated. Use the catalog_driver parameter instead.')
    if ! $catalog_driver {
      validate_legacy(Enum['template', 'sql'], 'validate_re', $catalog_type)
    }
  }

  [
    'enable_ssl',
    'ssl_certfile',
    'ssl_ca_certs',
    'ssl_ca_key',
    'ssl_cert_subject'
  ].each |String $ssl_opt| {
    if getvar($ssl_opt) != undef {
      warning("The ${ssl_opt} parameter has been deprecated and has no effect.")
    }
  }

  if $manage_policyrcd {
    # openstacklib policy_rcd only affects debian based systems.
    Policy_rcd <| title == 'keystone' |> -> Package['keystone']
    Policy_rcd['apache2'] -> Package['httpd']
    if ($::operatingsystem == 'Ubuntu') {
      $policy_services = 'apache2'
    } else {
      $policy_services = ['keystone', 'apache2']
    }
    ensure_resource('policy_rcd', $policy_services, { ensure => present, 'set_code' => '101' })
  }

  include keystone::db
  include keystone::params

  if $log_dir != undef {
    warning('The keystone::log_dir parameter is deprecated and has no effect.')
  }

  if $log_file != undef {
    warning('The keystone::log_file parameter is deprecated and has no effect.')
  }

  package { 'keystone':
    ensure => $package_ensure,
    name   => $::keystone::params::package_name,
    tag    => ['openstack', 'keystone-package'],
  }
  if $client_package_ensure == 'present' {
    include keystone::client
  } else {
    class { 'keystone::client':
      ensure => $client_package_ensure,
    }
  }

  resources { 'keystone_config':
    purge  => $purge_config,
  }

  # Endpoint configuration
  keystone_config {
    'DEFAULT/public_endpoint': value => $public_endpoint;
  }

  keystone_config {
    'token/expiration': value => $token_expiration;
  }

  keystone_config {
    'identity/password_hash_algorithm': value => $password_hash_algorithm;
    'identity/password_hash_rounds':    value => $password_hash_rounds;
  }

  keystone_config {
    'revoke/driver': value => $revoke_driver;
  }

  keystone_config {
    'policy/driver': value => $policy_driver;
  }

  # TODO(tkajinam): Remove this after Z-release
  keystone_config {
    'ssl/enable':       ensure => absent;
    'ssl/certfile':     ensure => absent;
    'ssl/keyfile':      ensure => absent;
    'ssl/ca_certs':     ensure => absent;
    'ssl/ca_key':       ensure => absent;
    'ssl/cert_subject': ensure => absent;
  }

  oslo::middleware { 'keystone_config':
    enable_proxy_headers_parsing => $enable_proxy_headers_parsing,
    max_request_body_size        => $max_request_body_size,
  }

  # configure based on the catalog backend
  if $catalog_driver {
    $catalog_driver_real = $catalog_driver
  }
  elsif ($catalog_type == 'template') {
    $catalog_driver_real = 'templated'
  }
  else {
    $catalog_driver_real = 'sql'
  }

  keystone_config {
    'catalog/driver':        value => $catalog_driver_real;
    'catalog/template_file': value => $catalog_template_file;
  }

  keystone_config {
    'token/provider':              value => $token_provider;
    'DEFAULT/max_token_size':      value => $max_token_size;
  }

  keystone_config {
    'DEFAULT/notification_format':  value => $notification_format;
    'DEFAULT/notification_opt_out': value => $notification_opt_out;
  }

  oslo::messaging::default { 'keystone_config':
    transport_url        => $default_transport_url,
    control_exchange     => $control_exchange,
    rpc_response_timeout => $rpc_response_timeout,
  }

  oslo::messaging::notifications { 'keystone_config':
    transport_url => $notification_transport_url,
    driver        => $notification_driver,
    topics        => $notification_topics,
  }

  oslo::messaging::rabbit { 'keystone_config':
    kombu_ssl_version           => $kombu_ssl_version,
    kombu_ssl_keyfile           => $kombu_ssl_keyfile,
    kombu_ssl_certfile          => $kombu_ssl_certfile,
    kombu_ssl_ca_certs          => $kombu_ssl_ca_certs,
    kombu_reconnect_delay       => $kombu_reconnect_delay,
    kombu_failover_strategy     => $kombu_failover_strategy,
    kombu_compression           => $kombu_compression,
    rabbit_use_ssl              => $rabbit_use_ssl,
    rabbit_ha_queues            => $rabbit_ha_queues,
    heartbeat_timeout_threshold => $rabbit_heartbeat_timeout_threshold,
    heartbeat_rate              => $rabbit_heartbeat_rate,
    heartbeat_in_pthread        => $rabbit_heartbeat_in_pthread,
    amqp_durable_queues         => $amqp_durable_queues,
  }

  if $manage_service {
    if $enabled {
      $service_ensure = 'running'
    } else {
      $service_ensure = 'stopped'
    }

    case $service_name {
      $::keystone::params::service_name: {
        if $::operatingsystem != 'Debian' {
          # TODO(tkajinam): Make this hard-fail
          warning('Keystone under Eventlet is no longer supported by this operating system')
        }

        $service_name_real = $::keystone::params::service_name

        service { 'keystone':
          ensure     => $service_ensure,
          name       => $service_name,
          enable     => $enabled,
          hasstatus  => true,
          hasrestart => true,
          tag        => 'keystone-service',
        }
      }
      'httpd': {
        include apache::params
        $service_name_real = $::apache::params::service_name
        Service <| title == 'httpd' |> { tag +> 'keystone-service' }

        if $::operatingsystem == 'Debian' {
          service { 'keystone':
            ensure => 'stopped',
            name   => $::keystone::params::service_name,
            enable => false,
            tag    => 'keystone-service',
          }
          # we need to make sure keystone/eventlet is stopped before trying to start apache
          Service['keystone'] -> Service[$service_name]
        }
      }
      default: {
        fail('Invalid service_name.')
      }
    }
  }

  if $sync_db {
    include keystone::db::sync
  }

  # Fernet tokens support
  if $enable_fernet_setup {
    validate_legacy(String, 'validate_string', $fernet_key_repository)
    ensure_resource('file', $fernet_key_repository, {
      ensure    => 'directory',
      owner     => $keystone_user,
      group     => $keystone_group,
      mode      => '0600',
      subscribe => Anchor['keystone::install::end'],
    })

  if $fernet_keys {
      validate_legacy(Hash, 'validate_hash', $fernet_keys)
      create_resources('file', $fernet_keys, {
          'owner'     => $keystone_user,
          'group'     => $keystone_group,
          'mode'      => '0600',
          'replace'   => $fernet_replace_keys,
          'show_diff' => false,
          'subscribe' => 'Anchor[keystone::install::end]',
          'tag'       => 'keystone-fernet-key',
        }
      )
    } else {
      exec { 'keystone-manage fernet_setup':
        command     => "keystone-manage fernet_setup --keystone-user ${keystone_user} --keystone-group ${keystone_group}",
        path        => '/usr/bin',
        user        => $keystone_user,
        refreshonly => true,
        creates     => "${fernet_key_repository}/0",
        notify      => Anchor['keystone::service::begin'],
        subscribe   => [Anchor['keystone::install::end'], Anchor['keystone::config::end']],
        require     => File[$fernet_key_repository],
        tag         => 'keystone-exec',
      }
    }
  }

  # Credential support
  if $enable_credential_setup {
    validate_legacy(String, 'validate_string', $credential_key_repository)
    ensure_resource('file', $credential_key_repository, {
      ensure    => 'directory',
      owner     => $keystone_user,
      group     => $keystone_group,
      mode      => '0600',
      subscribe => Anchor['keystone::install::end'],
    })

    if $credential_keys {
      validate_legacy(Hash, 'validate_hash', $credential_keys)
      create_resources('file', $credential_keys, {
          'owner'     => $keystone_user,
          'group'     => $keystone_group,
          'mode'      => '0600',
          'show_diff' => false,
          'subscribe' => 'Anchor[keystone::install::end]',
        }
      )
    } else {
      exec { 'keystone-manage credential_setup':
        command     => "keystone-manage credential_setup --keystone-user ${keystone_user} --keystone-group ${keystone_group}",
        path        => '/usr/bin',
        user        => $keystone_user,
        refreshonly => true,
        creates     => "${credential_key_repository}/0",
        notify      => Anchor['keystone::service::begin'],
        subscribe   => [Anchor['keystone::install::end'], Anchor['keystone::config::end']],
        require     => File[$credential_key_repository],
        tag         => 'keystone-exec',
      }
    }
  }

  if $fernet_key_repository {
    keystone_config {
      'fernet_tokens/key_repository': value => $fernet_key_repository;
    }
  } else {
    keystone_config {
      'fernet_tokens/key_repository': ensure => absent;
    }
  }

  keystone_config {
    'token/revoke_by_id':            value => $revoke_by_id;
    'fernet_tokens/max_active_keys': value => $fernet_max_active_keys;
    'credential/key_repository':     value => $credential_key_repository;
  }

  # Update this code when https://bugs.launchpad.net/keystone/+bug/1472285 is addressed.
  # 1/ Keystone needs to be started before creating the default domain
  # 2/ Once the default domain is created, we can query Keystone to get the default domain ID
  # 3/ The Keystone_domain provider has in charge of doing the query and configure keystone.conf
  # 4/ After such a change, we need to restart Keystone service.
  # restart_keystone exec is doing 4/, it restart Keystone if we have a new default domain setted
  # and if we manage the service to be enabled.
  if $manage_service and $enabled {
    exec { 'restart_keystone':
      path        => ['/usr/sbin', '/usr/bin', '/sbin', '/bin/'],
      command     => "systemctl restart ${service_name_real}",
      refreshonly => true,
    }
  }

  if $default_domain {
    keystone_domain { $default_domain:
      ensure     => present,
      enabled    => true,
      is_default => true,
    } ~> Exec<| title == 'restart_keystone' |>

    if $manage_service {
      Service[$service_name] -> Keystone_domain[$default_domain]
    }

    anchor { 'default_domain_created':
      require => Keystone_domain[$default_domain],
    }
  }
  if $domain_config_directory != '/etc/keystone/domains' and !$using_domain_config {
    fail('You must activate domain configuration using "using_domain_config" parameter to keystone class.')
  }

  if $using_domain_config {
    validate_legacy(Stdlib::Absolutepath, 'validate_absolute_path', $domain_config_directory)

    # Better than ensure resource.  We don't want to conflict with any
    # user definition even if they don't match exactly our parameters.
    # The error catching mechanism in the provider will remind them if
    # they did something silly, like defining a file rather than a
    # directory.  For the permission it's their choice.
    if (!defined(File[$domain_config_directory])) {
      file { $domain_config_directory:
        ensure  => directory,
        owner   => $keystone_user,
        group   => $keystone_group,
        mode    => '0750',
        require => Anchor['keystone::install::end'],
      }
      if $manage_service {
        File[$domain_config_directory] ~> Service[$service_name]
      }
    }
    # Here we want the creation to fail if the user has created those
    # resources with different values. That means that the user
    # wrongly uses using_domain_config parameter.
    ensure_resource(
      'keystone_config',
      'identity/domain_specific_drivers_enabled',
      {'value' => true}
    )
    ensure_resource(
      'keystone_config',
      'identity/domain_config_dir',
      {'value' => $domain_config_directory}
    )
  }
}